BLE test

Fork of X_NUCLEO_IDB0XA1 by ST

Committer:
Andrea Palmieri
Date:
Mon Jun 13 10:22:23 2016 +0200
Revision:
237:64c2ddbd9329
Parent:
236:2a73f3a97452
Child:
238:b6454c839f42
Fix Appearance setting

Signed-off-by: Andrea Palmieri <andrea.palmieri@st.com>

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Wolfgang Betz 130:770ce14d3d15 1 /* mbed Microcontroller Library
Wolfgang Betz 130:770ce14d3d15 2 * Copyright (c) 2006-2013 ARM Limited
Wolfgang Betz 130:770ce14d3d15 3 *
Wolfgang Betz 130:770ce14d3d15 4 * Licensed under the Apache License, Version 2.0 (the "License");
Wolfgang Betz 130:770ce14d3d15 5 * you may not use this file except in compliance with the License.
Wolfgang Betz 130:770ce14d3d15 6 * You may obtain a copy of the License at
Wolfgang Betz 130:770ce14d3d15 7 *
Wolfgang Betz 130:770ce14d3d15 8 * http://www.apache.org/licenses/LICENSE-2.0
Wolfgang Betz 130:770ce14d3d15 9 *
Wolfgang Betz 130:770ce14d3d15 10 * Unless required by applicable law or agreed to in writing, software
Wolfgang Betz 130:770ce14d3d15 11 * distributed under the License is distributed on an "AS IS" BASIS,
Wolfgang Betz 130:770ce14d3d15 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Wolfgang Betz 130:770ce14d3d15 13 * See the License for the specific language governing permissions and
Wolfgang Betz 130:770ce14d3d15 14 * limitations under the License.
Wolfgang Betz 130:770ce14d3d15 15 */
Wolfgang Betz 130:770ce14d3d15 16
Wolfgang Betz 130:770ce14d3d15 17
Wolfgang Betz 130:770ce14d3d15 18 /**
Wolfgang Betz 130:770ce14d3d15 19 ******************************************************************************
Wolfgang Betz 130:770ce14d3d15 20 * @file BlueNRGGap.cpp
Wolfgang Betz 130:770ce14d3d15 21 * @author STMicroelectronics
Wolfgang Betz 130:770ce14d3d15 22 * @brief Implementation of BLE_API Gap Class
Wolfgang Betz 130:770ce14d3d15 23 ******************************************************************************
Wolfgang Betz 130:770ce14d3d15 24 * @copy
Wolfgang Betz 130:770ce14d3d15 25 *
Wolfgang Betz 130:770ce14d3d15 26 * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
Wolfgang Betz 130:770ce14d3d15 27 * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
Wolfgang Betz 130:770ce14d3d15 28 * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
Wolfgang Betz 130:770ce14d3d15 29 * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
Wolfgang Betz 130:770ce14d3d15 30 * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
Wolfgang Betz 130:770ce14d3d15 31 * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
Wolfgang Betz 130:770ce14d3d15 32 *
Wolfgang Betz 130:770ce14d3d15 33 * <h2><center>&copy; COPYRIGHT 2013 STMicroelectronics</center></h2>
Andrea Palmieri 229:9981f62cdb1a 34 */
Wolfgang Betz 130:770ce14d3d15 35
Wolfgang Betz 130:770ce14d3d15 36 /** @defgroup BlueNRGGap
Wolfgang Betz 130:770ce14d3d15 37 * @brief BlueNRG BLE_API GAP Adaptation
Wolfgang Betz 130:770ce14d3d15 38 * @{
Wolfgang Betz 130:770ce14d3d15 39 */
Wolfgang Betz 130:770ce14d3d15 40
Wolfgang Betz 130:770ce14d3d15 41 #include "BlueNRGDevice.h"
Wolfgang Betz 144:bdf5e8432131 42 #include "mbed-drivers/mbed.h"
Wolfgang Betz 130:770ce14d3d15 43 #include "Payload.h"
Wolfgang Betz 130:770ce14d3d15 44 #include "Utils.h"
Wolfgang Betz 132:51056160fa4a 45 #include "debug.h"
Wolfgang Betz 130:770ce14d3d15 46
Wolfgang Betz 130:770ce14d3d15 47 //Local Variables
Wolfgang Betz 130:770ce14d3d15 48 //const char *local_name = NULL;
Wolfgang Betz 130:770ce14d3d15 49 //uint8_t local_name_length = 0;
Wolfgang Betz 130:770ce14d3d15 50
Wolfgang Betz 130:770ce14d3d15 51 /*
Wolfgang Betz 130:770ce14d3d15 52 * Utility to process GAP specific events (e.g., Advertising timeout)
Wolfgang Betz 130:770ce14d3d15 53 */
Wolfgang Betz 130:770ce14d3d15 54 void BlueNRGGap::Process(void)
Wolfgang Betz 130:770ce14d3d15 55 {
Wolfgang Betz 130:770ce14d3d15 56 if(AdvToFlag) {
Wolfgang Betz 130:770ce14d3d15 57 stopAdvertising();
Wolfgang Betz 130:770ce14d3d15 58 }
Wolfgang Betz 130:770ce14d3d15 59
Wolfgang Betz 130:770ce14d3d15 60 }
Wolfgang Betz 130:770ce14d3d15 61
Wolfgang Betz 130:770ce14d3d15 62 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 63 /*!
Wolfgang Betz 130:770ce14d3d15 64 @brief Sets the advertising parameters and payload for the device.
Wolfgang Betz 130:770ce14d3d15 65 Note: Some data types give error when their adv data is updated using aci_gap_update_adv_data() API
Wolfgang Betz 130:770ce14d3d15 66
Wolfgang Betz 130:770ce14d3d15 67 @params[in] advData
Wolfgang Betz 130:770ce14d3d15 68 The primary advertising data payload
Wolfgang Betz 130:770ce14d3d15 69 @params[in] scanResponse
Wolfgang Betz 130:770ce14d3d15 70 The optional Scan Response payload if the advertising
Wolfgang Betz 130:770ce14d3d15 71 type is set to \ref GapAdvertisingParams::ADV_SCANNABLE_UNDIRECTED
Wolfgang Betz 130:770ce14d3d15 72 in \ref GapAdveritinngParams
Wolfgang Betz 130:770ce14d3d15 73
Wolfgang Betz 130:770ce14d3d15 74 @returns \ref ble_error_t
Wolfgang Betz 130:770ce14d3d15 75
Wolfgang Betz 130:770ce14d3d15 76 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 77 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 78
Wolfgang Betz 130:770ce14d3d15 79 @retval BLE_ERROR_BUFFER_OVERFLOW
Wolfgang Betz 130:770ce14d3d15 80 The proposed action would cause a buffer overflow. All
Wolfgang Betz 130:770ce14d3d15 81 advertising payloads must be <= 31 bytes, for example.
Wolfgang Betz 130:770ce14d3d15 82
Wolfgang Betz 130:770ce14d3d15 83 @retval BLE_ERROR_NOT_IMPLEMENTED
Wolfgang Betz 130:770ce14d3d15 84 A feature was requested that is not yet supported in the
Wolfgang Betz 130:770ce14d3d15 85 nRF51 firmware or hardware.
Wolfgang Betz 130:770ce14d3d15 86
Wolfgang Betz 130:770ce14d3d15 87 @retval BLE_ERROR_PARAM_OUT_OF_RANGE
Wolfgang Betz 130:770ce14d3d15 88 One of the proposed values is outside the valid range.
Wolfgang Betz 130:770ce14d3d15 89
Wolfgang Betz 130:770ce14d3d15 90 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 91
Wolfgang Betz 130:770ce14d3d15 92 @code
Wolfgang Betz 130:770ce14d3d15 93
Wolfgang Betz 130:770ce14d3d15 94 @endcode
Wolfgang Betz 130:770ce14d3d15 95 */
Wolfgang Betz 130:770ce14d3d15 96 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 97 ble_error_t BlueNRGGap::setAdvertisingData(const GapAdvertisingData &advData, const GapAdvertisingData &scanResponse)
Wolfgang Betz 130:770ce14d3d15 98 {
Wolfgang Betz 132:51056160fa4a 99 PRINTF("BlueNRGGap::setAdvertisingData\n\r");
Wolfgang Betz 130:770ce14d3d15 100 /* Make sure we don't exceed the advertising payload length */
Wolfgang Betz 130:770ce14d3d15 101 if (advData.getPayloadLen() > GAP_ADVERTISING_DATA_MAX_PAYLOAD) {
Andrea Palmieri 237:64c2ddbd9329 102 PRINTF("Exceeded the advertising payload length\n\r");
Wolfgang Betz 130:770ce14d3d15 103 return BLE_ERROR_BUFFER_OVERFLOW;
Wolfgang Betz 130:770ce14d3d15 104 }
Wolfgang Betz 130:770ce14d3d15 105
Wolfgang Betz 130:770ce14d3d15 106 /* Make sure we have a payload! */
Andrea Palmieri 229:9981f62cdb1a 107 if (advData.getPayloadLen() == 0) {
Andrea Palmieri 229:9981f62cdb1a 108 PRINTF("advData.getPayloadLen() == 0\n\r");
Andrea Palmieri 229:9981f62cdb1a 109 //return BLE_ERROR_PARAM_OUT_OF_RANGE;
Andrea Palmieri 229:9981f62cdb1a 110 local_name_length = 0;
Andrea Palmieri 229:9981f62cdb1a 111 servUuidlength = 0;
Andrea Palmieri 229:9981f62cdb1a 112 AdvLen = 0;
Andrea Palmieri 236:2a73f3a97452 113 } else {
Andrea Palmieri 236:2a73f3a97452 114 PayloadPtr loadPtr(advData.getPayload(), advData.getPayloadLen());
Andrea Palmieri 236:2a73f3a97452 115
Wolfgang Betz 130:770ce14d3d15 116 for(uint8_t index=0; index<loadPtr.getPayloadUnitCount(); index++) {
Wolfgang Betz 130:770ce14d3d15 117 loadPtr.getUnitAtIndex(index);
Wolfgang Betz 130:770ce14d3d15 118
Wolfgang Betz 132:51056160fa4a 119 PRINTF("adData[%d].length=%d\n\r", index,(uint8_t)(*loadPtr.getUnitAtIndex(index).getLenPtr()));
Wolfgang Betz 132:51056160fa4a 120 PRINTF("adData[%d].AdType=0x%x\n\r", index,(uint8_t)(*loadPtr.getUnitAtIndex(index).getAdTypePtr()));
Wolfgang Betz 130:770ce14d3d15 121
Wolfgang Betz 130:770ce14d3d15 122 switch(*loadPtr.getUnitAtIndex(index).getAdTypePtr()) {
Wolfgang Betz 130:770ce14d3d15 123 case GapAdvertisingData::FLAGS: /* ref *Flags */
Wolfgang Betz 130:770ce14d3d15 124 {
Wolfgang Betz 132:51056160fa4a 125 PRINTF("Advertising type: FLAGS\n\r");
Wolfgang Betz 130:770ce14d3d15 126 //Check if Flags are OK. BlueNRG only supports LE Mode.
Wolfgang Betz 130:770ce14d3d15 127 uint8_t *flags = loadPtr.getUnitAtIndex(index).getDataPtr();
Wolfgang Betz 130:770ce14d3d15 128 if((*flags & GapAdvertisingData::BREDR_NOT_SUPPORTED) != GapAdvertisingData::BREDR_NOT_SUPPORTED) {
Wolfgang Betz 132:51056160fa4a 129 PRINTF("BlueNRG does not support BR/EDR Mode");
Wolfgang Betz 130:770ce14d3d15 130 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 131 }
Wolfgang Betz 130:770ce14d3d15 132
Wolfgang Betz 130:770ce14d3d15 133 break;
Wolfgang Betz 130:770ce14d3d15 134 }
Wolfgang Betz 130:770ce14d3d15 135 case GapAdvertisingData::INCOMPLETE_LIST_16BIT_SERVICE_IDS: /**< Incomplete list of 16-bit Service IDs */
Wolfgang Betz 130:770ce14d3d15 136 case GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS: /**< Complete list of 16-bit Service IDs */
Andrea Palmieri 189:30fa96fa8ec4 137 case GapAdvertisingData::INCOMPLETE_LIST_128BIT_SERVICE_IDS: /**< Incomplete list of 128-bit Service IDs */
Andrea Palmieri 189:30fa96fa8ec4 138 case GapAdvertisingData::COMPLETE_LIST_128BIT_SERVICE_IDS: /**< Complete list of 128-bit Service IDs */
Wolfgang Betz 130:770ce14d3d15 139 {
Andrea Palmieri 189:30fa96fa8ec4 140 PRINTF("Advertising type: INCOMPLETE_LIST SERVICE_IDS/COMPLETE_LIST SERVICE_IDS\n\r");
Wolfgang Betz 130:770ce14d3d15 141
Wolfgang Betz 130:770ce14d3d15 142 uint8_t buffSize = *loadPtr.getUnitAtIndex(index).getLenPtr()-1;
Wolfgang Betz 130:770ce14d3d15 143 // The total lenght should include the Data Type Value
Wolfgang Betz 130:770ce14d3d15 144 if(buffSize>UUID_BUFFER_SIZE-1) {
Andrea Palmieri 189:30fa96fa8ec4 145 return BLE_ERROR_INVALID_PARAM;
Wolfgang Betz 130:770ce14d3d15 146 }
Wolfgang Betz 130:770ce14d3d15 147
Wolfgang Betz 130:770ce14d3d15 148 servUuidlength = buffSize+1; // +1 to include the Data Type Value
Wolfgang Betz 130:770ce14d3d15 149 servUuidData[0] = (uint8_t)(*loadPtr.getUnitAtIndex(index).getAdTypePtr()); //Data Type Value
Wolfgang Betz 130:770ce14d3d15 150
Wolfgang Betz 132:51056160fa4a 151 PRINTF("servUuidlength=%d servUuidData[0]=%d buffSize=%d\n\r", servUuidlength, servUuidData[0], buffSize);
Wolfgang Betz 130:770ce14d3d15 152 // Save the Service UUID list just after the Data Type Value field
Wolfgang Betz 130:770ce14d3d15 153 memcpy(servUuidData+1, loadPtr.getUnitAtIndex(index).getDataPtr(), buffSize);
Andrea Palmieri 189:30fa96fa8ec4 154 #ifdef DEBUG
Wolfgang Betz 130:770ce14d3d15 155 for(unsigned i=0; i<servUuidlength; i++) {
Wolfgang Betz 132:51056160fa4a 156 PRINTF("servUuidData[%d] = 0x%x\n\r", i, servUuidData[i]);
Wolfgang Betz 130:770ce14d3d15 157 }
Wolfgang Betz 130:770ce14d3d15 158
Wolfgang Betz 130:770ce14d3d15 159 for(unsigned i=0; i<buffSize; i++) {
Andrea Palmieri 236:2a73f3a97452 160 PRINTF("loadPtr.getUnitAtIndex(index).getDataPtr()[%d] = 0x%x\n\r",
Andrea Palmieri 236:2a73f3a97452 161 i, loadPtr.getUnitAtIndex(index).getDataPtr()[i]);
Wolfgang Betz 130:770ce14d3d15 162 }
Andrea Palmieri 189:30fa96fa8ec4 163 #endif /* DEBUG */
Wolfgang Betz 130:770ce14d3d15 164 break;
Wolfgang Betz 130:770ce14d3d15 165 }
Wolfgang Betz 130:770ce14d3d15 166 case GapAdvertisingData::INCOMPLETE_LIST_32BIT_SERVICE_IDS: /**< Incomplete list of 32-bit Service IDs (not relevant for Bluetooth 4.0) */
Wolfgang Betz 130:770ce14d3d15 167 {
Wolfgang Betz 132:51056160fa4a 168 PRINTF("Advertising type: INCOMPLETE_LIST_32BIT_SERVICE_IDS\n\r");
Wolfgang Betz 130:770ce14d3d15 169 return BLE_ERROR_NOT_IMPLEMENTED;
Wolfgang Betz 130:770ce14d3d15 170 }
Wolfgang Betz 130:770ce14d3d15 171 case GapAdvertisingData::COMPLETE_LIST_32BIT_SERVICE_IDS: /**< Complete list of 32-bit Service IDs (not relevant for Bluetooth 4.0) */
Wolfgang Betz 130:770ce14d3d15 172 {
Wolfgang Betz 132:51056160fa4a 173 PRINTF("Advertising type: COMPLETE_LIST_32BIT_SERVICE_IDS\n\r");
Wolfgang Betz 130:770ce14d3d15 174 return BLE_ERROR_NOT_IMPLEMENTED;
Wolfgang Betz 130:770ce14d3d15 175 }
Wolfgang Betz 130:770ce14d3d15 176 case GapAdvertisingData::SHORTENED_LOCAL_NAME: /**< Shortened Local Name */
Wolfgang Betz 130:770ce14d3d15 177 {
Wolfgang Betz 130:770ce14d3d15 178 break;
Wolfgang Betz 130:770ce14d3d15 179 }
Wolfgang Betz 130:770ce14d3d15 180 case GapAdvertisingData::COMPLETE_LOCAL_NAME: /**< Complete Local Name */
Wolfgang Betz 130:770ce14d3d15 181 {
Wolfgang Betz 132:51056160fa4a 182 PRINTF("Advertising type: COMPLETE_LOCAL_NAME\n\r");
Andrea Palmieri 222:37a7e289ee3d 183 loadPtr.getUnitAtIndex(index).printDataAsString();
Andrea Palmieri 222:37a7e289ee3d 184 local_name_length = *loadPtr.getUnitAtIndex(index).getLenPtr()-1;
Andrea Palmieri 229:9981f62cdb1a 185 // The total length should include the Data Type Value
Andrea Palmieri 229:9981f62cdb1a 186 if(local_name_length>ADV_DATA_MAX_SIZE-1) {
Andrea Palmieri 222:37a7e289ee3d 187 return BLE_ERROR_INVALID_PARAM;
Andrea Palmieri 222:37a7e289ee3d 188 }
Andrea Palmieri 222:37a7e289ee3d 189 local_name[0] = (uint8_t)(*loadPtr.getUnitAtIndex(index).getAdTypePtr()); //Data Type Value
Andrea Palmieri 222:37a7e289ee3d 190 memcpy(local_name+1, (uint8_t*)loadPtr.getUnitAtIndex(index).getDataPtr(), local_name_length-1);
Andrea Palmieri 222:37a7e289ee3d 191 PRINTF("Advertising type: COMPLETE_LOCAL_NAME local_name=%s local_name_length=%d\n\r", local_name, local_name_length);
Andrea Palmieri 222:37a7e289ee3d 192
Wolfgang Betz 130:770ce14d3d15 193 break;
Wolfgang Betz 130:770ce14d3d15 194 }
Wolfgang Betz 130:770ce14d3d15 195 case GapAdvertisingData::TX_POWER_LEVEL: /**< TX Power Level (in dBm) */
Wolfgang Betz 130:770ce14d3d15 196 {
Wolfgang Betz 132:51056160fa4a 197 PRINTF("Advertising type: TX_POWER_LEVEL\n\r");
Wolfgang Betz 130:770ce14d3d15 198 int8_t enHighPower = 0;
Wolfgang Betz 130:770ce14d3d15 199 int8_t paLevel = 0;
Wolfgang Betz 132:51056160fa4a 200 #ifdef DEBUG
Wolfgang Betz 130:770ce14d3d15 201 int8_t dbm = *loadPtr.getUnitAtIndex(index).getDataPtr();
Wolfgang Betz 130:770ce14d3d15 202 int8_t dbmActuallySet = getHighPowerAndPALevelValue(dbm, enHighPower, paLevel);
Wolfgang Betz 130:770ce14d3d15 203 #endif
Wolfgang Betz 132:51056160fa4a 204 PRINTF("dbm=%d, dbmActuallySet=%d\n\r", dbm, dbmActuallySet);
Wolfgang Betz 132:51056160fa4a 205 PRINTF("enHighPower=%d, paLevel=%d\n\r", enHighPower, paLevel);
Wolfgang Betz 130:770ce14d3d15 206 aci_hal_set_tx_power_level(enHighPower, paLevel);
Wolfgang Betz 130:770ce14d3d15 207 break;
Wolfgang Betz 130:770ce14d3d15 208 }
Wolfgang Betz 130:770ce14d3d15 209 case GapAdvertisingData::DEVICE_ID: /**< Device ID */
Wolfgang Betz 130:770ce14d3d15 210 {
Wolfgang Betz 130:770ce14d3d15 211 break;
Wolfgang Betz 130:770ce14d3d15 212 }
Wolfgang Betz 130:770ce14d3d15 213 case GapAdvertisingData::SLAVE_CONNECTION_INTERVAL_RANGE: /**< Slave :Connection Interval Range */
Wolfgang Betz 130:770ce14d3d15 214 {
Wolfgang Betz 130:770ce14d3d15 215 break;
Wolfgang Betz 130:770ce14d3d15 216 }
Wolfgang Betz 130:770ce14d3d15 217 case GapAdvertisingData::SERVICE_DATA: /**< Service Data */
Wolfgang Betz 130:770ce14d3d15 218 {
Wolfgang Betz 132:51056160fa4a 219 PRINTF("Advertising type: SERVICE_DATA\n\r");
Wolfgang Betz 130:770ce14d3d15 220 uint8_t buffSize = *loadPtr.getUnitAtIndex(index).getLenPtr()-1;
Wolfgang Betz 132:51056160fa4a 221 PRINTF("Advertising type: SERVICE_DATA (buffSize=%d)\n\r", buffSize);
Wolfgang Betz 130:770ce14d3d15 222 // the total ADV DATA LEN should include two more bytes: the buffer size byte; and the Service Data Type Value byte
Wolfgang Betz 130:770ce14d3d15 223 if(buffSize>ADV_DATA_MAX_SIZE-2) {
Wolfgang Betz 130:770ce14d3d15 224 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 225 }
Andrea Palmieri 229:9981f62cdb1a 226 #ifdef DEBUG
Wolfgang Betz 130:770ce14d3d15 227 for(int i=0; i<buffSize+1; i++) {
Andrea Palmieri 236:2a73f3a97452 228 PRINTF("Advertising type: SERVICE_DATA loadPtr.getUnitAtIndex(index).getDataPtr()[%d] = 0x%x\n\r",
Andrea Palmieri 236:2a73f3a97452 229 i, loadPtr.getUnitAtIndex(index).getDataPtr()[i]);
Wolfgang Betz 130:770ce14d3d15 230 }
Andrea Palmieri 229:9981f62cdb1a 231 #endif
Wolfgang Betz 130:770ce14d3d15 232 AdvLen = buffSize+2; // the total ADV DATA LEN should include two more bytes: the buffer size byte; and the Service Data Type Value byte
Wolfgang Betz 130:770ce14d3d15 233 AdvData[0] = buffSize+1; // the fisrt byte is the data buffer size (type+data)
Wolfgang Betz 130:770ce14d3d15 234 AdvData[1] = AD_TYPE_SERVICE_DATA;
Wolfgang Betz 130:770ce14d3d15 235 memcpy(AdvData+2, loadPtr.getUnitAtIndex(index).getDataPtr(), buffSize);
Wolfgang Betz 130:770ce14d3d15 236 break;
Wolfgang Betz 130:770ce14d3d15 237 }
Andrea Palmieri 228:25368f053411 238
Wolfgang Betz 130:770ce14d3d15 239 case GapAdvertisingData::ADVERTISING_INTERVAL: /**< Advertising Interval */
Wolfgang Betz 130:770ce14d3d15 240 {
Wolfgang Betz 132:51056160fa4a 241 PRINTF("Advertising type: ADVERTISING_INTERVAL\n\r");
Andrea Palmieri 232:aead10288880 242 //uint32_t advInt = (uint32_t)(*loadPtr.getUnitAtIndex(index).getDataPtr());
Wolfgang Betz 130:770ce14d3d15 243 break;
Wolfgang Betz 130:770ce14d3d15 244 }
Andrea Palmieri 182:e7cff2f17ef9 245 case GapAdvertisingData::MANUFACTURER_SPECIFIC_DATA: /**< Manufacturer Specific Data */
Wolfgang Betz 130:770ce14d3d15 246 {
Andrea Palmieri 182:e7cff2f17ef9 247 PRINTF("Advertising type: MANUFACTURER_SPECIFIC_DATA\n\r");
Andrea Palmieri 182:e7cff2f17ef9 248 uint8_t buffSize = *loadPtr.getUnitAtIndex(index).getLenPtr()-1;
Andrea Palmieri 182:e7cff2f17ef9 249 PRINTF("Advertising type: MANUFACTURER_SPECIFIC_DATA (buffSize=%d)\n\r", buffSize);
Andrea Palmieri 182:e7cff2f17ef9 250 // the total ADV DATA LEN should include two more bytes:
Andrea Palmieri 182:e7cff2f17ef9 251 // the buffer size byte;
Andrea Palmieri 182:e7cff2f17ef9 252 // and the Manufacturer Specific Data Type Value byte
Andrea Palmieri 182:e7cff2f17ef9 253 if(buffSize>ADV_DATA_MAX_SIZE-2) {
Andrea Palmieri 182:e7cff2f17ef9 254 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Andrea Palmieri 182:e7cff2f17ef9 255 }
Andrea Palmieri 229:9981f62cdb1a 256 #ifdef DBEUG
Andrea Palmieri 182:e7cff2f17ef9 257 for(int i=0; i<buffSize+1; i++) {
Andrea Palmieri 182:e7cff2f17ef9 258 PRINTF("Advertising type: MANUFACTURER_SPECIFIC_DATA loadPtr.getUnitAtIndex(index).getDataPtr()[%d] = 0x%x\n\r",
Andrea Palmieri 182:e7cff2f17ef9 259 i, loadPtr.getUnitAtIndex(index).getDataPtr()[i]);
Andrea Palmieri 182:e7cff2f17ef9 260 }
Andrea Palmieri 229:9981f62cdb1a 261 #endif
Andrea Palmieri 182:e7cff2f17ef9 262 AdvLen = buffSize+2; // the total ADV DATA LEN should include two more bytes: the buffer size byte; and the Manufacturer Specific Data Type Value byte
Andrea Palmieri 182:e7cff2f17ef9 263 AdvData[0] = buffSize+1; // the fisrt byte is the data buffer size (type+data)
Andrea Palmieri 182:e7cff2f17ef9 264 AdvData[1] = AD_TYPE_MANUFACTURER_SPECIFIC_DATA;
Andrea Palmieri 182:e7cff2f17ef9 265 memcpy(AdvData+2, loadPtr.getUnitAtIndex(index).getDataPtr(), buffSize);
Wolfgang Betz 130:770ce14d3d15 266 break;
Wolfgang Betz 130:770ce14d3d15 267 }
Andrea Palmieri 236:2a73f3a97452 268 } // end switch
Andrea Palmieri 236:2a73f3a97452 269
Andrea Palmieri 236:2a73f3a97452 270 } //end for
Andrea Palmieri 236:2a73f3a97452 271
Andrea Palmieri 236:2a73f3a97452 272 //Set the SCAN_RSP Payload
Andrea Palmieri 236:2a73f3a97452 273 if(scanResponse.getPayloadLen() > 0) {
Andrea Palmieri 236:2a73f3a97452 274 scan_response_payload = scanResponse.getPayload();
Andrea Palmieri 236:2a73f3a97452 275 scan_rsp_length = scanResponse.getPayloadLen();
Wolfgang Betz 130:770ce14d3d15 276 }
Andrea Palmieri 237:64c2ddbd9329 277
Andrea Palmieri 237:64c2ddbd9329 278 /* Align the GAP Service Appearance Char value coherently */
Andrea Palmieri 237:64c2ddbd9329 279 STORE_LE_16(deviceAppearance, advData.getAppearance());
Andrea Palmieri 237:64c2ddbd9329 280 setAppearance((GapAdvertisingData::Appearance)(deviceAppearance[1]<<8|deviceAppearance[0]));
Andrea Palmieri 237:64c2ddbd9329 281
Andrea Palmieri 213:781abfbf2d1c 282 // Update the ADV data if we are already in ADV mode
Andrea Palmieri 213:781abfbf2d1c 283 if(AdvLen > 0 && state.advertising == 1) {
Andrea Palmieri 213:781abfbf2d1c 284
Andrea Palmieri 213:781abfbf2d1c 285 tBleStatus ret = aci_gap_update_adv_data(AdvLen, AdvData);
Andrea Palmieri 213:781abfbf2d1c 286 if(BLE_STATUS_SUCCESS!=ret) {
Andrea Palmieri 213:781abfbf2d1c 287 PRINTF("error occurred while adding adv data (ret=0x%x)\n", ret);
Andrea Palmieri 213:781abfbf2d1c 288 switch (ret) {
Andrea Palmieri 213:781abfbf2d1c 289 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 213:781abfbf2d1c 290 return BLE_STACK_BUSY;
Andrea Palmieri 213:781abfbf2d1c 291 default:
Andrea Palmieri 213:781abfbf2d1c 292 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 213:781abfbf2d1c 293 }
Andrea Palmieri 213:781abfbf2d1c 294 }
Andrea Palmieri 213:781abfbf2d1c 295 }
Wolfgang Betz 130:770ce14d3d15 296 }
Wolfgang Betz 130:770ce14d3d15 297 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 298 }
Wolfgang Betz 130:770ce14d3d15 299
Wolfgang Betz 130:770ce14d3d15 300 /*
Wolfgang Betz 130:770ce14d3d15 301 * Utility to set ADV timeout flag
Wolfgang Betz 130:770ce14d3d15 302 */
Wolfgang Betz 130:770ce14d3d15 303 void BlueNRGGap::setAdvToFlag(void) {
Wolfgang Betz 130:770ce14d3d15 304 AdvToFlag = true;
Wolfgang Betz 130:770ce14d3d15 305 }
Wolfgang Betz 130:770ce14d3d15 306
Wolfgang Betz 130:770ce14d3d15 307 /*
Wolfgang Betz 130:770ce14d3d15 308 * ADV timeout callback
Andrea Palmieri 229:9981f62cdb1a 309 */
Wolfgang Betz 138:32e3c4ca7a45 310 #ifdef AST_FOR_MBED_OS
Wolfgang Betz 132:51056160fa4a 311 static void advTimeoutCB(void)
Wolfgang Betz 132:51056160fa4a 312 {
Wolfgang Betz 132:51056160fa4a 313 Gap::GapState_t state;
Wolfgang Betz 132:51056160fa4a 314
Wolfgang Betz 132:51056160fa4a 315 state = BlueNRGGap::getInstance().getState();
Wolfgang Betz 132:51056160fa4a 316 if (state.advertising == 1) {
Wolfgang Betz 132:51056160fa4a 317
Wolfgang Betz 132:51056160fa4a 318 BlueNRGGap::getInstance().stopAdvertising();
Wolfgang Betz 132:51056160fa4a 319
Wolfgang Betz 132:51056160fa4a 320 }
Wolfgang Betz 132:51056160fa4a 321 }
Wolfgang Betz 132:51056160fa4a 322 #else
Wolfgang Betz 130:770ce14d3d15 323 static void advTimeoutCB(void)
Wolfgang Betz 130:770ce14d3d15 324 {
Wolfgang Betz 130:770ce14d3d15 325 Gap::GapState_t state;
Wolfgang Betz 130:770ce14d3d15 326
Wolfgang Betz 130:770ce14d3d15 327 state = BlueNRGGap::getInstance().getState();
Wolfgang Betz 130:770ce14d3d15 328 if (state.advertising == 1) {
Wolfgang Betz 130:770ce14d3d15 329
Wolfgang Betz 130:770ce14d3d15 330 BlueNRGGap::getInstance().setAdvToFlag();
Wolfgang Betz 130:770ce14d3d15 331
Wolfgang Betz 130:770ce14d3d15 332 Timeout t = BlueNRGGap::getInstance().getAdvTimeout();
Wolfgang Betz 130:770ce14d3d15 333 t.detach(); /* disable the callback from the timeout */
Wolfgang Betz 130:770ce14d3d15 334
Wolfgang Betz 130:770ce14d3d15 335 }
Wolfgang Betz 130:770ce14d3d15 336 }
Wolfgang Betz 138:32e3c4ca7a45 337 #endif /* AST_FOR_MBED_OS */
Wolfgang Betz 130:770ce14d3d15 338
Wolfgang Betz 130:770ce14d3d15 339 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 340 /*!
Wolfgang Betz 130:770ce14d3d15 341 @brief Starts the BLE HW, initialising any services that were
Wolfgang Betz 130:770ce14d3d15 342 added before this function was called.
Wolfgang Betz 130:770ce14d3d15 343
Wolfgang Betz 130:770ce14d3d15 344 @param[in] params
Wolfgang Betz 130:770ce14d3d15 345 Basic advertising details, including the advertising
Wolfgang Betz 130:770ce14d3d15 346 delay, timeout and how the device should be advertised
Wolfgang Betz 130:770ce14d3d15 347
Wolfgang Betz 130:770ce14d3d15 348 @note All services must be added before calling this function!
Wolfgang Betz 130:770ce14d3d15 349
Wolfgang Betz 130:770ce14d3d15 350 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 351
Wolfgang Betz 130:770ce14d3d15 352 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 353 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 354
Wolfgang Betz 130:770ce14d3d15 355 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 356
Wolfgang Betz 130:770ce14d3d15 357 @code
Wolfgang Betz 130:770ce14d3d15 358
Wolfgang Betz 130:770ce14d3d15 359 @endcode
Wolfgang Betz 130:770ce14d3d15 360 */
Wolfgang Betz 130:770ce14d3d15 361 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 362
Wolfgang Betz 130:770ce14d3d15 363 ble_error_t BlueNRGGap::startAdvertising(const GapAdvertisingParams &params)
Andrea Palmieri 187:2e517d3ddd71 364 {
Andrea Palmieri 187:2e517d3ddd71 365 tBleStatus ret;
Andrea Palmieri 187:2e517d3ddd71 366
Wolfgang Betz 130:770ce14d3d15 367 /* Make sure we support the advertising type */
Wolfgang Betz 130:770ce14d3d15 368 if (params.getAdvertisingType() == GapAdvertisingParams::ADV_CONNECTABLE_DIRECTED) {
Andrea Palmieri 220:e02936f0d4c7 369 /* ToDo: This requires a proper security implementation, etc. */
Wolfgang Betz 130:770ce14d3d15 370 return BLE_ERROR_NOT_IMPLEMENTED;
Wolfgang Betz 130:770ce14d3d15 371 }
Wolfgang Betz 130:770ce14d3d15 372
Wolfgang Betz 130:770ce14d3d15 373 /* Check interval range */
Wolfgang Betz 130:770ce14d3d15 374 if (params.getAdvertisingType() == GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED) {
Wolfgang Betz 130:770ce14d3d15 375 /* Min delay is slightly longer for unconnectable devices */
Wolfgang Betz 130:770ce14d3d15 376 if ((params.getIntervalInADVUnits() < GapAdvertisingParams::GAP_ADV_PARAMS_INTERVAL_MIN_NONCON) ||
Wolfgang Betz 130:770ce14d3d15 377 (params.getIntervalInADVUnits() > GapAdvertisingParams::GAP_ADV_PARAMS_INTERVAL_MAX)) {
Wolfgang Betz 130:770ce14d3d15 378 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 379 }
Wolfgang Betz 130:770ce14d3d15 380 } else {
Wolfgang Betz 130:770ce14d3d15 381 if ((params.getIntervalInADVUnits() < GapAdvertisingParams::GAP_ADV_PARAMS_INTERVAL_MIN) ||
Wolfgang Betz 130:770ce14d3d15 382 (params.getIntervalInADVUnits() > GapAdvertisingParams::GAP_ADV_PARAMS_INTERVAL_MAX)) {
Wolfgang Betz 130:770ce14d3d15 383 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 384 }
Wolfgang Betz 130:770ce14d3d15 385 }
Wolfgang Betz 130:770ce14d3d15 386
Wolfgang Betz 130:770ce14d3d15 387 /* Check timeout is zero for Connectable Directed */
Wolfgang Betz 130:770ce14d3d15 388 if ((params.getAdvertisingType() == GapAdvertisingParams::ADV_CONNECTABLE_DIRECTED) && (params.getTimeout() != 0)) {
Wolfgang Betz 130:770ce14d3d15 389 /* Timeout must be 0 with this type, although we'll never get here */
Wolfgang Betz 130:770ce14d3d15 390 /* since this isn't implemented yet anyway */
Wolfgang Betz 130:770ce14d3d15 391 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 392 }
Wolfgang Betz 130:770ce14d3d15 393
Wolfgang Betz 130:770ce14d3d15 394 /* Check timeout for other advertising types */
Wolfgang Betz 130:770ce14d3d15 395 if ((params.getAdvertisingType() != GapAdvertisingParams::ADV_CONNECTABLE_DIRECTED) &&
Wolfgang Betz 130:770ce14d3d15 396 (params.getTimeout() > GapAdvertisingParams::GAP_ADV_PARAMS_TIMEOUT_MAX)) {
Wolfgang Betz 130:770ce14d3d15 397 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 398 }
Wolfgang Betz 130:770ce14d3d15 399
Andrea Palmieri 229:9981f62cdb1a 400 /*
Andrea Palmieri 229:9981f62cdb1a 401 * Advertising filter policy setting
Andrea Palmieri 229:9981f62cdb1a 402 * FIXME: the Security Manager should be implemented
Andrea Palmieri 229:9981f62cdb1a 403 */
Andrea Palmieri 229:9981f62cdb1a 404 AdvertisingPolicyMode_t mode = getAdvertisingPolicyMode();
Andrea Palmieri 229:9981f62cdb1a 405 if(mode != ADV_POLICY_IGNORE_WHITELIST) {
Andrea Palmieri 229:9981f62cdb1a 406 ret = aci_gap_configure_whitelist();
Andrea Palmieri 229:9981f62cdb1a 407 if(ret != BLE_STATUS_SUCCESS) {
Andrea Palmieri 229:9981f62cdb1a 408 PRINTF("aci_gap_configure_whitelist ret=0x%x\n\r", ret);
Andrea Palmieri 229:9981f62cdb1a 409 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 229:9981f62cdb1a 410 }
Andrea Palmieri 229:9981f62cdb1a 411 }
Andrea Palmieri 229:9981f62cdb1a 412
Andrea Palmieri 229:9981f62cdb1a 413 uint8_t advFilterPolicy = NO_WHITE_LIST_USE;
Andrea Palmieri 229:9981f62cdb1a 414 switch(mode) {
Andrea Palmieri 229:9981f62cdb1a 415 case ADV_POLICY_FILTER_SCAN_REQS:
Andrea Palmieri 229:9981f62cdb1a 416 advFilterPolicy = WHITE_LIST_FOR_ONLY_SCAN;
Andrea Palmieri 229:9981f62cdb1a 417 break;
Andrea Palmieri 229:9981f62cdb1a 418 case ADV_POLICY_FILTER_CONN_REQS:
Andrea Palmieri 229:9981f62cdb1a 419 advFilterPolicy = WHITE_LIST_FOR_ONLY_CONN;
Andrea Palmieri 229:9981f62cdb1a 420 break;
Andrea Palmieri 229:9981f62cdb1a 421 case ADV_POLICY_FILTER_ALL_REQS:
Andrea Palmieri 229:9981f62cdb1a 422 advFilterPolicy = WHITE_LIST_FOR_ALL;
Andrea Palmieri 229:9981f62cdb1a 423 break;
Andrea Palmieri 229:9981f62cdb1a 424 default:
Andrea Palmieri 229:9981f62cdb1a 425 advFilterPolicy = NO_WHITE_LIST_USE;
Andrea Palmieri 229:9981f62cdb1a 426 break;
Andrea Palmieri 229:9981f62cdb1a 427 }
Andrea Palmieri 229:9981f62cdb1a 428
Andrea Palmieri 228:25368f053411 429 /* Check the ADV type before setting scan response data */
Andrea Palmieri 228:25368f053411 430 if (params.getAdvertisingType() == GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED ||
Andrea Palmieri 228:25368f053411 431 params.getAdvertisingType() == GapAdvertisingParams::ADV_SCANNABLE_UNDIRECTED) {
Andrea Palmieri 228:25368f053411 432
Andrea Palmieri 228:25368f053411 433 /* set scan response data */
Andrea Palmieri 228:25368f053411 434 PRINTF(" setting scan response data (scan_rsp_length=%u)\n", scan_rsp_length);
Andrea Palmieri 228:25368f053411 435 ret = hci_le_set_scan_resp_data(scan_rsp_length, scan_response_payload);
Andrea Palmieri 228:25368f053411 436
Andrea Palmieri 228:25368f053411 437 if(BLE_STATUS_SUCCESS!=ret) {
Andrea Palmieri 228:25368f053411 438 PRINTF(" error while setting scan response data (ret=0x%x)\n", ret);
Andrea Palmieri 228:25368f053411 439 switch (ret) {
Andrea Palmieri 228:25368f053411 440 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 228:25368f053411 441 return BLE_STACK_BUSY;
Andrea Palmieri 228:25368f053411 442 default:
Andrea Palmieri 228:25368f053411 443 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 228:25368f053411 444 }
Andrea Palmieri 187:2e517d3ddd71 445 }
Andrea Palmieri 228:25368f053411 446 } else {
Andrea Palmieri 228:25368f053411 447 hci_le_set_scan_resp_data(0, NULL);
Andrea Palmieri 187:2e517d3ddd71 448 }
Wolfgang Betz 130:770ce14d3d15 449
Andrea Palmieri 232:aead10288880 450 //advInterval = params.getIntervalInADVUnits();
Andrea Palmieri 232:aead10288880 451 setAdvParameters();
Andrea Palmieri 232:aead10288880 452 PRINTF("advInterval=%d advType=%d\n\r", advInterval, params.getAdvertisingType());
Wolfgang Betz 130:770ce14d3d15 453
Andrea Palmieri 229:9981f62cdb1a 454 /* Setting discoverable mode */
Andrea Palmieri 220:e02936f0d4c7 455 ret = aci_gap_set_discoverable(params.getAdvertisingType(), // AdvType
Andrea Palmieri 232:aead10288880 456 advInterval, // AdvIntervMin
Andrea Palmieri 232:aead10288880 457 advInterval, // AdvIntervMax
Andrea Palmieri 228:25368f053411 458 addr_type, // OwnAddrType
Andrea Palmieri 229:9981f62cdb1a 459 advFilterPolicy, // AdvFilterPolicy
Andrea Palmieri 220:e02936f0d4c7 460 local_name_length, // LocalNameLen
Andrea Palmieri 220:e02936f0d4c7 461 (const char*)local_name, // LocalName
Andrea Palmieri 220:e02936f0d4c7 462 servUuidlength, // ServiceUUIDLen
Andrea Palmieri 220:e02936f0d4c7 463 servUuidData, // ServiceUUIDList
Andrea Palmieri 220:e02936f0d4c7 464 0, // SlaveConnIntervMin
Andrea Palmieri 220:e02936f0d4c7 465 0); // SlaveConnIntervMax
Wolfgang Betz 130:770ce14d3d15 466
Wolfgang Betz 130:770ce14d3d15 467
Andrea Palmieri 229:9981f62cdb1a 468 PRINTF("!!!setting discoverable (servUuidlength=0x%x)\n\r", servUuidlength);
Wolfgang Betz 130:770ce14d3d15 469 if(BLE_STATUS_SUCCESS!=ret) {
Andrea Palmieri 229:9981f62cdb1a 470 PRINTF("error occurred while setting discoverable (ret=0x%x)\n\r", ret);
Andrea Palmieri 187:2e517d3ddd71 471 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 472 case BLE_STATUS_INVALID_PARAMS:
Andrea Palmieri 187:2e517d3ddd71 473 return BLE_ERROR_INVALID_PARAM;
Andrea Palmieri 187:2e517d3ddd71 474 case ERR_COMMAND_DISALLOWED:
Andrea Palmieri 187:2e517d3ddd71 475 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 187:2e517d3ddd71 476 case ERR_UNSUPPORTED_FEATURE:
Andrea Palmieri 187:2e517d3ddd71 477 return BLE_ERROR_NOT_IMPLEMENTED;
Andrea Palmieri 187:2e517d3ddd71 478 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 479 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 480 default:
Andrea Palmieri 187:2e517d3ddd71 481 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 482 }
Wolfgang Betz 130:770ce14d3d15 483 }
Wolfgang Betz 130:770ce14d3d15 484
Wolfgang Betz 130:770ce14d3d15 485 // Before updating the ADV data, delete COMPLETE_LOCAL_NAME and TX_POWER_LEVEL fields (if present)
Andrea Palmieri 228:25368f053411 486 if(AdvLen > 0) {
Andrea Palmieri 228:25368f053411 487 if(local_name_length > 0) {
Wolfgang Betz 132:51056160fa4a 488 PRINTF("!!!calling aci_gap_delete_ad_type AD_TYPE_COMPLETE_LOCAL_NAME!!!\n");
Wolfgang Betz 130:770ce14d3d15 489 ret = aci_gap_delete_ad_type(AD_TYPE_COMPLETE_LOCAL_NAME);
Andrea Palmieri 187:2e517d3ddd71 490 if (BLE_STATUS_SUCCESS!=ret){
Wolfgang Betz 132:51056160fa4a 491 PRINTF("aci_gap_delete_ad_type failed return=%d\n", ret);
Andrea Palmieri 187:2e517d3ddd71 492 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 493 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 494 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 495 default:
Andrea Palmieri 187:2e517d3ddd71 496 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 497 }
Wolfgang Betz 130:770ce14d3d15 498 }
Wolfgang Betz 130:770ce14d3d15 499 }
Wolfgang Betz 130:770ce14d3d15 500
Andrea Palmieri 201:a9bc2e8b01d7 501 // If ADV Data Type is SERVICE DATA or MANUFACTURER SPECIFIC DATA,
Andrea Palmieri 201:a9bc2e8b01d7 502 // we need to delete it to make the needed room in ADV payload
Andrea Palmieri 201:a9bc2e8b01d7 503 if(AdvData[1]==AD_TYPE_SERVICE_DATA || AdvData[1]==AD_TYPE_MANUFACTURER_SPECIFIC_DATA) {
Wolfgang Betz 132:51056160fa4a 504 PRINTF("!!!calling aci_gap_delete_ad_type(AD_TYPE_TX_POWER_LEVEL)!!!\n");
Wolfgang Betz 130:770ce14d3d15 505 ret = aci_gap_delete_ad_type(AD_TYPE_TX_POWER_LEVEL);
Andrea Palmieri 187:2e517d3ddd71 506 if (BLE_STATUS_SUCCESS!=ret){
Wolfgang Betz 132:51056160fa4a 507 PRINTF("aci_gap_delete_ad_type failed return=%d\n", ret);
Andrea Palmieri 187:2e517d3ddd71 508 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 509 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 510 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 511 default:
Andrea Palmieri 187:2e517d3ddd71 512 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 513 }
Wolfgang Betz 130:770ce14d3d15 514 }
Wolfgang Betz 130:770ce14d3d15 515 }
Wolfgang Betz 130:770ce14d3d15 516
Wolfgang Betz 130:770ce14d3d15 517 ret = aci_gap_update_adv_data(AdvLen, AdvData);
Wolfgang Betz 130:770ce14d3d15 518 if(BLE_STATUS_SUCCESS!=ret) {
Wolfgang Betz 132:51056160fa4a 519 PRINTF("error occurred while adding adv data (ret=0x%x)\n", ret);
Andrea Palmieri 187:2e517d3ddd71 520 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 521 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 522 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 523 default:
Andrea Palmieri 187:2e517d3ddd71 524 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 525 }
Wolfgang Betz 130:770ce14d3d15 526 }
Andrea Palmieri 228:25368f053411 527
Andrea Palmieri 187:2e517d3ddd71 528 } // AdvLen>0
Wolfgang Betz 130:770ce14d3d15 529
Andrea Palmieri 228:25368f053411 530 if(deviceAppearance != 0) {
Andrea Palmieri 228:25368f053411 531 uint8_t appearance[] = {3, AD_TYPE_APPEARANCE, deviceAppearance[0], deviceAppearance[1]};
Andrea Palmieri 237:64c2ddbd9329 532 ret = aci_gap_update_adv_data(4, appearance);
Andrea Palmieri 237:64c2ddbd9329 533 if(BLE_STATUS_SUCCESS!=ret) {
Andrea Palmieri 237:64c2ddbd9329 534 switch (ret) {
Andrea Palmieri 237:64c2ddbd9329 535 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 237:64c2ddbd9329 536 return BLE_STACK_BUSY;
Andrea Palmieri 237:64c2ddbd9329 537 default:
Andrea Palmieri 237:64c2ddbd9329 538 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 237:64c2ddbd9329 539 }
Andrea Palmieri 237:64c2ddbd9329 540 }
Andrea Palmieri 228:25368f053411 541 }
Andrea Palmieri 228:25368f053411 542
Wolfgang Betz 130:770ce14d3d15 543 state.advertising = 1;
Wolfgang Betz 130:770ce14d3d15 544
Wolfgang Betz 130:770ce14d3d15 545 AdvToFlag = false;
Wolfgang Betz 130:770ce14d3d15 546 if(params.getTimeout() != 0) {
Wolfgang Betz 132:51056160fa4a 547 PRINTF("!!! attaching to!!!\n");
Wolfgang Betz 138:32e3c4ca7a45 548 #ifdef AST_FOR_MBED_OS
Andrea Palmieri 229:9981f62cdb1a 549 minar::Scheduler::postCallback(advTimeoutCB).delay(minar::milliseconds(params.getTimeout() * 1000));
Wolfgang Betz 132:51056160fa4a 550 #else
Andrea Palmieri 229:9981f62cdb1a 551 advTimeout.attach(advTimeoutCB, params.getTimeout() * 1000);
Wolfgang Betz 132:51056160fa4a 552 #endif
Wolfgang Betz 130:770ce14d3d15 553 }
Wolfgang Betz 130:770ce14d3d15 554
Wolfgang Betz 130:770ce14d3d15 555 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 556 }
Wolfgang Betz 130:770ce14d3d15 557
Wolfgang Betz 130:770ce14d3d15 558 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 559 /*!
Wolfgang Betz 130:770ce14d3d15 560 @brief Stops the BLE HW and disconnects from any devices
Wolfgang Betz 130:770ce14d3d15 561
Wolfgang Betz 130:770ce14d3d15 562 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 563
Wolfgang Betz 130:770ce14d3d15 564 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 565 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 566
Wolfgang Betz 130:770ce14d3d15 567 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 568
Wolfgang Betz 130:770ce14d3d15 569 @code
Wolfgang Betz 130:770ce14d3d15 570
Wolfgang Betz 130:770ce14d3d15 571 @endcode
Wolfgang Betz 130:770ce14d3d15 572 */
Wolfgang Betz 130:770ce14d3d15 573 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 574 ble_error_t BlueNRGGap::stopAdvertising(void)
Wolfgang Betz 130:770ce14d3d15 575 {
Wolfgang Betz 130:770ce14d3d15 576 tBleStatus ret;
Andrea Palmieri 229:9981f62cdb1a 577
Wolfgang Betz 130:770ce14d3d15 578 if(state.advertising == 1) {
Wolfgang Betz 130:770ce14d3d15 579 //Set non-discoverable to stop advertising
Wolfgang Betz 130:770ce14d3d15 580 ret = aci_gap_set_non_discoverable();
Wolfgang Betz 130:770ce14d3d15 581
Andrea Palmieri 187:2e517d3ddd71 582 if (BLE_STATUS_SUCCESS!=ret){
Wolfgang Betz 132:51056160fa4a 583 PRINTF("Error in stopping advertisement (ret=0x%x)!!\n\r", ret) ;
Andrea Palmieri 187:2e517d3ddd71 584 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 585 case ERR_COMMAND_DISALLOWED:
Andrea Palmieri 187:2e517d3ddd71 586 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 187:2e517d3ddd71 587 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 588 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 589 default:
Andrea Palmieri 187:2e517d3ddd71 590 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 591 }
Wolfgang Betz 130:770ce14d3d15 592 }
Wolfgang Betz 132:51056160fa4a 593 PRINTF("Advertisement stopped!!\n\r") ;
Wolfgang Betz 130:770ce14d3d15 594 //Set GapState_t::advertising state
Wolfgang Betz 130:770ce14d3d15 595 state.advertising = 0;
Wolfgang Betz 130:770ce14d3d15 596 }
Wolfgang Betz 130:770ce14d3d15 597
Wolfgang Betz 130:770ce14d3d15 598 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 599 }
Wolfgang Betz 130:770ce14d3d15 600
Wolfgang Betz 130:770ce14d3d15 601 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 602 /*!
Wolfgang Betz 130:770ce14d3d15 603 @brief Disconnects if we are connected to a central device
Wolfgang Betz 130:770ce14d3d15 604
Wolfgang Betz 130:770ce14d3d15 605 @param[in] reason
Wolfgang Betz 130:770ce14d3d15 606 Disconnection Reason
Wolfgang Betz 130:770ce14d3d15 607
Wolfgang Betz 130:770ce14d3d15 608 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 609
Wolfgang Betz 130:770ce14d3d15 610 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 611 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 612
Wolfgang Betz 130:770ce14d3d15 613 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 614
Wolfgang Betz 130:770ce14d3d15 615 @code
Wolfgang Betz 130:770ce14d3d15 616
Wolfgang Betz 130:770ce14d3d15 617 @endcode
Wolfgang Betz 130:770ce14d3d15 618 */
Wolfgang Betz 130:770ce14d3d15 619 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 620 ble_error_t BlueNRGGap::disconnect(Gap::DisconnectionReason_t reason)
Wolfgang Betz 130:770ce14d3d15 621 {
Andrea Palmieri 142:adf1567d3900 622 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 623 (void)reason;
Andrea Palmieri 142:adf1567d3900 624
Wolfgang Betz 130:770ce14d3d15 625 tBleStatus ret;
Wolfgang Betz 130:770ce14d3d15 626 //For Reason codes check BlueTooth HCI Spec
Wolfgang Betz 130:770ce14d3d15 627
Wolfgang Betz 130:770ce14d3d15 628 if(m_connectionHandle != BLE_CONN_HANDLE_INVALID) {
Wolfgang Betz 130:770ce14d3d15 629 ret = aci_gap_terminate(m_connectionHandle, 0x16);//0x16 Connection Terminated by Local Host.
Wolfgang Betz 130:770ce14d3d15 630
Andrea Palmieri 187:2e517d3ddd71 631 if (BLE_STATUS_SUCCESS != ret){
Andrea Palmieri 187:2e517d3ddd71 632 PRINTF("Error in GAP termination (ret=0x%x)!!\n\r", ret) ;
Andrea Palmieri 187:2e517d3ddd71 633 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 634 case ERR_COMMAND_DISALLOWED:
Andrea Palmieri 187:2e517d3ddd71 635 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 187:2e517d3ddd71 636 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 637 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 638 default:
Andrea Palmieri 187:2e517d3ddd71 639 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 640 }
Wolfgang Betz 130:770ce14d3d15 641 }
Wolfgang Betz 130:770ce14d3d15 642
Wolfgang Betz 132:51056160fa4a 643 //PRINTF("Disconnected from localhost!!\n\r") ;
Wolfgang Betz 130:770ce14d3d15 644 m_connectionHandle = BLE_CONN_HANDLE_INVALID;
Wolfgang Betz 130:770ce14d3d15 645 }
Wolfgang Betz 130:770ce14d3d15 646
Wolfgang Betz 130:770ce14d3d15 647 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 648 }
Wolfgang Betz 130:770ce14d3d15 649
Wolfgang Betz 130:770ce14d3d15 650 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 651 /*!
Wolfgang Betz 130:770ce14d3d15 652 @brief Disconnects if we are connected to a central device
Wolfgang Betz 130:770ce14d3d15 653
Wolfgang Betz 130:770ce14d3d15 654 @param[in] reason
Wolfgang Betz 130:770ce14d3d15 655 Disconnection Reason
Wolfgang Betz 130:770ce14d3d15 656
Wolfgang Betz 130:770ce14d3d15 657 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 658
Wolfgang Betz 130:770ce14d3d15 659 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 660 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 661
Wolfgang Betz 130:770ce14d3d15 662 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 663
Wolfgang Betz 130:770ce14d3d15 664 @code
Wolfgang Betz 130:770ce14d3d15 665
Wolfgang Betz 130:770ce14d3d15 666 @endcode
Wolfgang Betz 130:770ce14d3d15 667 */
Wolfgang Betz 130:770ce14d3d15 668 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 669 ble_error_t BlueNRGGap::disconnect(Handle_t connectionHandle, Gap::DisconnectionReason_t reason)
Wolfgang Betz 130:770ce14d3d15 670 {
Andrea Palmieri 142:adf1567d3900 671 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 672 (void)reason;
Andrea Palmieri 142:adf1567d3900 673
Wolfgang Betz 130:770ce14d3d15 674 tBleStatus ret;
Wolfgang Betz 130:770ce14d3d15 675 //For Reason codes check BlueTooth HCI Spec
Wolfgang Betz 130:770ce14d3d15 676
Wolfgang Betz 130:770ce14d3d15 677 if(connectionHandle != BLE_CONN_HANDLE_INVALID) {
Wolfgang Betz 130:770ce14d3d15 678 ret = aci_gap_terminate(connectionHandle, 0x16);//0x16 Connection Terminated by Local Host.
Wolfgang Betz 130:770ce14d3d15 679
Andrea Palmieri 187:2e517d3ddd71 680 if (BLE_STATUS_SUCCESS != ret){
Andrea Palmieri 187:2e517d3ddd71 681 PRINTF("Error in GAP termination (ret=0x%x)!!\n\r", ret) ;
Andrea Palmieri 187:2e517d3ddd71 682 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 683 case ERR_COMMAND_DISALLOWED:
Andrea Palmieri 187:2e517d3ddd71 684 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 187:2e517d3ddd71 685 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 686 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 687 default:
Andrea Palmieri 187:2e517d3ddd71 688 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 689 }
Wolfgang Betz 130:770ce14d3d15 690 }
Wolfgang Betz 130:770ce14d3d15 691
Wolfgang Betz 132:51056160fa4a 692 //PRINTF("Disconnected from localhost!!\n\r") ;
Wolfgang Betz 130:770ce14d3d15 693 m_connectionHandle = BLE_CONN_HANDLE_INVALID;
Wolfgang Betz 130:770ce14d3d15 694 }
Wolfgang Betz 130:770ce14d3d15 695
Wolfgang Betz 130:770ce14d3d15 696 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 697 }
Wolfgang Betz 130:770ce14d3d15 698
Wolfgang Betz 130:770ce14d3d15 699 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 700 /*!
Wolfgang Betz 130:770ce14d3d15 701 @brief Sets the 16-bit connection handle
Wolfgang Betz 130:770ce14d3d15 702
Wolfgang Betz 130:770ce14d3d15 703 @param[in] con_handle
Wolfgang Betz 130:770ce14d3d15 704 Connection Handle which is set in the Gap Instance
Wolfgang Betz 130:770ce14d3d15 705
Wolfgang Betz 130:770ce14d3d15 706 @returns void
Wolfgang Betz 130:770ce14d3d15 707 */
Wolfgang Betz 130:770ce14d3d15 708 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 709 void BlueNRGGap::setConnectionHandle(uint16_t con_handle)
Wolfgang Betz 130:770ce14d3d15 710 {
Wolfgang Betz 130:770ce14d3d15 711 m_connectionHandle = con_handle;
Wolfgang Betz 130:770ce14d3d15 712 }
Wolfgang Betz 130:770ce14d3d15 713
Wolfgang Betz 130:770ce14d3d15 714 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 715 /*!
Wolfgang Betz 130:770ce14d3d15 716 @brief Gets the 16-bit connection handle
Wolfgang Betz 130:770ce14d3d15 717
Wolfgang Betz 130:770ce14d3d15 718 @param[in] void
Wolfgang Betz 130:770ce14d3d15 719
Wolfgang Betz 130:770ce14d3d15 720 @returns uint16_t
Wolfgang Betz 130:770ce14d3d15 721 Connection Handle of the Gap Instance
Wolfgang Betz 130:770ce14d3d15 722 */
Wolfgang Betz 130:770ce14d3d15 723 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 724 uint16_t BlueNRGGap::getConnectionHandle(void)
Wolfgang Betz 130:770ce14d3d15 725 {
Wolfgang Betz 130:770ce14d3d15 726 return m_connectionHandle;
Wolfgang Betz 130:770ce14d3d15 727 }
Wolfgang Betz 130:770ce14d3d15 728
Wolfgang Betz 130:770ce14d3d15 729 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 730 /*!
Wolfgang Betz 130:770ce14d3d15 731 @brief Sets the BLE device address. SetAddress will reset the BLE
Wolfgang Betz 130:770ce14d3d15 732 device and re-initialize BTLE. Will not start advertising.
Wolfgang Betz 130:770ce14d3d15 733
Wolfgang Betz 130:770ce14d3d15 734 @param[in] type
Wolfgang Betz 130:770ce14d3d15 735 Type of Address
Wolfgang Betz 130:770ce14d3d15 736
Wolfgang Betz 130:770ce14d3d15 737 @param[in] address[6]
Wolfgang Betz 130:770ce14d3d15 738 Value of the Address to be set
Wolfgang Betz 130:770ce14d3d15 739
Wolfgang Betz 130:770ce14d3d15 740 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 741
Wolfgang Betz 130:770ce14d3d15 742 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 743
Wolfgang Betz 130:770ce14d3d15 744 @code
Wolfgang Betz 130:770ce14d3d15 745
Wolfgang Betz 130:770ce14d3d15 746 @endcode
Wolfgang Betz 130:770ce14d3d15 747 */
Wolfgang Betz 130:770ce14d3d15 748 /**************************************************************************/
Wolfgang Betz 132:51056160fa4a 749 ble_error_t BlueNRGGap::setAddress(AddressType_t type, const Address_t address)
Wolfgang Betz 130:770ce14d3d15 750 {
Andrea Palmieri 228:25368f053411 751 tBleStatus ret;
Andrea Palmieri 228:25368f053411 752
Andrea Palmieri 210:08c4c85ca679 753 if (type > BLEProtocol::AddressType::RANDOM_PRIVATE_NON_RESOLVABLE) {
Wolfgang Betz 130:770ce14d3d15 754 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 755 }
Wolfgang Betz 130:770ce14d3d15 756
Wolfgang Betz 132:51056160fa4a 757 addr_type = type;
Andrea Palmieri 228:25368f053411 758
Andrea Palmieri 228:25368f053411 759 // If Address Type is other than PUBLIC, the given Address is ignored
Andrea Palmieri 228:25368f053411 760 if(addr_type == BLEProtocol::AddressType::PUBLIC){
Andrea Palmieri 228:25368f053411 761 ret = aci_hal_write_config_data(CONFIG_DATA_PUBADDR_OFFSET,
Andrea Palmieri 228:25368f053411 762 CONFIG_DATA_PUBADDR_LEN,
Andrea Palmieri 228:25368f053411 763 address);
Andrea Palmieri 229:9981f62cdb1a 764 if(ret != BLE_STATUS_SUCCESS) {
Andrea Palmieri 229:9981f62cdb1a 765 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 229:9981f62cdb1a 766 }
Wolfgang Betz 130:770ce14d3d15 767 }
Wolfgang Betz 130:770ce14d3d15 768
Wolfgang Betz 130:770ce14d3d15 769 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 770 }
Andrea Palmieri 229:9981f62cdb1a 771
Wolfgang Betz 130:770ce14d3d15 772 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 773 /*!
Wolfgang Betz 130:770ce14d3d15 774 @brief Returns boolean if the address of the device has been set
Wolfgang Betz 130:770ce14d3d15 775 or not
Wolfgang Betz 130:770ce14d3d15 776
Wolfgang Betz 130:770ce14d3d15 777 @returns bool
Wolfgang Betz 130:770ce14d3d15 778
Wolfgang Betz 130:770ce14d3d15 779 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 780
Wolfgang Betz 130:770ce14d3d15 781 @code
Wolfgang Betz 130:770ce14d3d15 782
Wolfgang Betz 130:770ce14d3d15 783 @endcode
Wolfgang Betz 130:770ce14d3d15 784 */
Wolfgang Betz 130:770ce14d3d15 785 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 786 bool BlueNRGGap::getIsSetAddress()
Wolfgang Betz 130:770ce14d3d15 787 {
Wolfgang Betz 130:770ce14d3d15 788 return isSetAddress;
Wolfgang Betz 130:770ce14d3d15 789 }
Wolfgang Betz 130:770ce14d3d15 790
Wolfgang Betz 130:770ce14d3d15 791 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 792 /*!
Wolfgang Betz 130:770ce14d3d15 793 @brief Returns the address of the device if set
Wolfgang Betz 130:770ce14d3d15 794
Wolfgang Betz 130:770ce14d3d15 795 @returns Pointer to the address if Address is set else NULL
Wolfgang Betz 130:770ce14d3d15 796
Wolfgang Betz 130:770ce14d3d15 797 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 798
Wolfgang Betz 130:770ce14d3d15 799 @code
Wolfgang Betz 130:770ce14d3d15 800
Wolfgang Betz 130:770ce14d3d15 801 @endcode
Wolfgang Betz 130:770ce14d3d15 802 */
Wolfgang Betz 130:770ce14d3d15 803 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 804 ble_error_t BlueNRGGap::getAddress(AddressType_t *typeP, Address_t address)
Wolfgang Betz 130:770ce14d3d15 805 {
Andrea Palmieri 229:9981f62cdb1a 806 uint8_t bdaddr[BDADDR_SIZE];
Andrea Palmieri 229:9981f62cdb1a 807 uint8_t data_len_out;
Andrea Palmieri 229:9981f62cdb1a 808
Andrea Palmieri 228:25368f053411 809 if(typeP != NULL) {
Andrea Palmieri 228:25368f053411 810 *typeP = addr_type;
Andrea Palmieri 228:25368f053411 811 }
Andrea Palmieri 228:25368f053411 812
Andrea Palmieri 229:9981f62cdb1a 813 tBleStatus ret = aci_hal_read_config_data(CONFIG_DATA_RANDOM_ADDRESS_IDB05A1, BDADDR_SIZE, &data_len_out, bdaddr);
Andrea Palmieri 229:9981f62cdb1a 814 if(ret != BLE_STATUS_SUCCESS) {
Andrea Palmieri 229:9981f62cdb1a 815 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 229:9981f62cdb1a 816 }
Andrea Palmieri 229:9981f62cdb1a 817
Andrea Palmieri 228:25368f053411 818 if(address != NULL) {
Andrea Palmieri 228:25368f053411 819 memcpy(address, bdaddr, BDADDR_SIZE);
Wolfgang Betz 130:770ce14d3d15 820 }
Wolfgang Betz 130:770ce14d3d15 821
Wolfgang Betz 130:770ce14d3d15 822 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 823 }
Wolfgang Betz 130:770ce14d3d15 824
Wolfgang Betz 130:770ce14d3d15 825 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 826 /*!
Wolfgang Betz 130:770ce14d3d15 827 @brief obtains preferred connection params
Wolfgang Betz 130:770ce14d3d15 828
Wolfgang Betz 130:770ce14d3d15 829 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 830
Wolfgang Betz 130:770ce14d3d15 831 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 832
Wolfgang Betz 130:770ce14d3d15 833 @code
Wolfgang Betz 130:770ce14d3d15 834
Wolfgang Betz 130:770ce14d3d15 835 @endcode
Wolfgang Betz 130:770ce14d3d15 836 */
Wolfgang Betz 130:770ce14d3d15 837 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 838 ble_error_t BlueNRGGap::getPreferredConnectionParams(ConnectionParams_t *params)
Wolfgang Betz 130:770ce14d3d15 839 {
Andrea Palmieri 142:adf1567d3900 840 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 841 (void)params;
Andrea Palmieri 142:adf1567d3900 842
Wolfgang Betz 130:770ce14d3d15 843 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 844 }
Wolfgang Betz 130:770ce14d3d15 845
Wolfgang Betz 130:770ce14d3d15 846
Wolfgang Betz 130:770ce14d3d15 847 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 848 /*!
Wolfgang Betz 130:770ce14d3d15 849 @brief sets preferred connection params
Wolfgang Betz 130:770ce14d3d15 850
Wolfgang Betz 130:770ce14d3d15 851 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 852
Wolfgang Betz 130:770ce14d3d15 853 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 854
Wolfgang Betz 130:770ce14d3d15 855 @code
Wolfgang Betz 130:770ce14d3d15 856
Wolfgang Betz 130:770ce14d3d15 857 @endcode
Wolfgang Betz 130:770ce14d3d15 858 */
Wolfgang Betz 130:770ce14d3d15 859 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 860 ble_error_t BlueNRGGap::setPreferredConnectionParams(const ConnectionParams_t *params)
Wolfgang Betz 130:770ce14d3d15 861 {
Andrea Palmieri 142:adf1567d3900 862 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 863 (void)params;
Andrea Palmieri 142:adf1567d3900 864
Wolfgang Betz 130:770ce14d3d15 865 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 866 }
Wolfgang Betz 130:770ce14d3d15 867
Wolfgang Betz 130:770ce14d3d15 868 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 869 /*!
Wolfgang Betz 130:770ce14d3d15 870 @brief updates preferred connection params
Wolfgang Betz 130:770ce14d3d15 871
Wolfgang Betz 130:770ce14d3d15 872 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 873
Wolfgang Betz 130:770ce14d3d15 874 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 875
Wolfgang Betz 130:770ce14d3d15 876 @code
Wolfgang Betz 130:770ce14d3d15 877
Wolfgang Betz 130:770ce14d3d15 878 @endcode
Wolfgang Betz 130:770ce14d3d15 879 */
Wolfgang Betz 130:770ce14d3d15 880 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 881 ble_error_t BlueNRGGap::updateConnectionParams(Handle_t handle, const ConnectionParams_t *params)
Wolfgang Betz 130:770ce14d3d15 882 {
Andrea Palmieri 142:adf1567d3900 883 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 884 (void) handle;
Andrea Palmieri 142:adf1567d3900 885 (void)params;
Andrea Palmieri 142:adf1567d3900 886
Wolfgang Betz 130:770ce14d3d15 887 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 888 }
Wolfgang Betz 130:770ce14d3d15 889
Wolfgang Betz 130:770ce14d3d15 890 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 891 /*!
Wolfgang Betz 130:770ce14d3d15 892 @brief Sets the Device Name Characteristic
Wolfgang Betz 130:770ce14d3d15 893
Wolfgang Betz 130:770ce14d3d15 894 @param[in] deviceName
Wolfgang Betz 130:770ce14d3d15 895 pointer to device name to be set
Wolfgang Betz 130:770ce14d3d15 896
Wolfgang Betz 130:770ce14d3d15 897 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 898
Wolfgang Betz 130:770ce14d3d15 899 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 900 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 901
Wolfgang Betz 130:770ce14d3d15 902 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 903
Wolfgang Betz 130:770ce14d3d15 904 @code
Wolfgang Betz 130:770ce14d3d15 905
Wolfgang Betz 130:770ce14d3d15 906 @endcode
Wolfgang Betz 130:770ce14d3d15 907 */
Wolfgang Betz 130:770ce14d3d15 908 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 909 ble_error_t BlueNRGGap::setDeviceName(const uint8_t *deviceName)
Wolfgang Betz 130:770ce14d3d15 910 {
Andrea Palmieri 187:2e517d3ddd71 911 tBleStatus ret;
Wolfgang Betz 130:770ce14d3d15 912 uint8_t nameLen = 0;
Wolfgang Betz 130:770ce14d3d15 913
Andrea Palmieri 228:25368f053411 914 nameLen = strlen((const char*)deviceName);
Andrea Palmieri 228:25368f053411 915 PRINTF("DeviceName Size=%d\n\r", nameLen);
Andrea Palmieri 228:25368f053411 916
Andrea Palmieri 222:37a7e289ee3d 917 ret = aci_gatt_update_char_value(g_gap_service_handle,
Andrea Palmieri 222:37a7e289ee3d 918 g_device_name_char_handle,
Andrea Palmieri 222:37a7e289ee3d 919 0,
Andrea Palmieri 222:37a7e289ee3d 920 nameLen,
Andrea Palmieri 228:25368f053411 921 deviceName);
Andrea Palmieri 187:2e517d3ddd71 922
Andrea Palmieri 187:2e517d3ddd71 923 if (BLE_STATUS_SUCCESS != ret){
Andrea Palmieri 187:2e517d3ddd71 924 PRINTF("device set name failed (ret=0x%x)!!\n\r", ret) ;
Andrea Palmieri 187:2e517d3ddd71 925 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 926 case BLE_STATUS_INVALID_HANDLE:
Andrea Palmieri 187:2e517d3ddd71 927 case BLE_STATUS_INVALID_PARAMETER:
Andrea Palmieri 187:2e517d3ddd71 928 return BLE_ERROR_INVALID_PARAM;
Andrea Palmieri 187:2e517d3ddd71 929 case BLE_STATUS_INSUFFICIENT_RESOURCES:
Andrea Palmieri 187:2e517d3ddd71 930 return BLE_ERROR_NO_MEM;
Andrea Palmieri 187:2e517d3ddd71 931 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 932 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 933 default:
Andrea Palmieri 187:2e517d3ddd71 934 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 935 }
Wolfgang Betz 130:770ce14d3d15 936 }
Wolfgang Betz 130:770ce14d3d15 937
Wolfgang Betz 130:770ce14d3d15 938 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 939 }
Wolfgang Betz 130:770ce14d3d15 940
Wolfgang Betz 130:770ce14d3d15 941 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 942 /*!
Wolfgang Betz 130:770ce14d3d15 943 @brief Gets the Device Name Characteristic
Wolfgang Betz 130:770ce14d3d15 944
Wolfgang Betz 130:770ce14d3d15 945 @param[in] deviceName
Wolfgang Betz 130:770ce14d3d15 946 pointer to device name
Wolfgang Betz 130:770ce14d3d15 947
Wolfgang Betz 130:770ce14d3d15 948 @param[in] lengthP
Wolfgang Betz 130:770ce14d3d15 949 pointer to device name length
Wolfgang Betz 130:770ce14d3d15 950
Wolfgang Betz 130:770ce14d3d15 951 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 952
Wolfgang Betz 130:770ce14d3d15 953 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 954 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 955
Wolfgang Betz 130:770ce14d3d15 956 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 957
Wolfgang Betz 130:770ce14d3d15 958 @code
Wolfgang Betz 130:770ce14d3d15 959
Wolfgang Betz 130:770ce14d3d15 960 @endcode
Wolfgang Betz 130:770ce14d3d15 961 */
Wolfgang Betz 130:770ce14d3d15 962 /**************************************************************************/
Andrea Palmieri 228:25368f053411 963 ble_error_t BlueNRGGap::getDeviceName(uint8_t *deviceName, unsigned *lengthP)
Andrea Palmieri 228:25368f053411 964 {
Andrea Palmieri 228:25368f053411 965 tBleStatus ret;
Andrea Palmieri 228:25368f053411 966
Andrea Palmieri 229:9981f62cdb1a 967 ret = aci_gatt_read_handle_value(g_device_name_char_handle+BlueNRGGattServer::CHAR_VALUE_HANDLE,
Andrea Palmieri 228:25368f053411 968 *lengthP,
Andrea Palmieri 228:25368f053411 969 (uint16_t *)lengthP,
Andrea Palmieri 228:25368f053411 970 deviceName);
Andrea Palmieri 228:25368f053411 971 PRINTF("getDeviceName ret=0x%02x (lengthP=%d)\n\r", ret, *lengthP);
Andrea Palmieri 228:25368f053411 972 if (ret == BLE_STATUS_SUCCESS) {
Andrea Palmieri 228:25368f053411 973 return BLE_ERROR_NONE;
Andrea Palmieri 228:25368f053411 974 } else {
Andrea Palmieri 228:25368f053411 975 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Andrea Palmieri 228:25368f053411 976 }
Wolfgang Betz 130:770ce14d3d15 977 }
Wolfgang Betz 130:770ce14d3d15 978
Wolfgang Betz 130:770ce14d3d15 979 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 980 /*!
Wolfgang Betz 130:770ce14d3d15 981 @brief Sets the Device Appearance Characteristic
Wolfgang Betz 130:770ce14d3d15 982
Wolfgang Betz 130:770ce14d3d15 983 @param[in] appearance
Wolfgang Betz 130:770ce14d3d15 984 device appearance
Wolfgang Betz 130:770ce14d3d15 985
Wolfgang Betz 130:770ce14d3d15 986 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 987
Wolfgang Betz 130:770ce14d3d15 988 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 989 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 990
Wolfgang Betz 130:770ce14d3d15 991 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 992
Wolfgang Betz 130:770ce14d3d15 993 @code
Wolfgang Betz 130:770ce14d3d15 994
Wolfgang Betz 130:770ce14d3d15 995 @endcode
Wolfgang Betz 130:770ce14d3d15 996 */
Wolfgang Betz 130:770ce14d3d15 997 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 998 ble_error_t BlueNRGGap::setAppearance(GapAdvertisingData::Appearance appearance)
Wolfgang Betz 130:770ce14d3d15 999 {
Andrea Palmieri 187:2e517d3ddd71 1000 tBleStatus ret;
Andrea Palmieri 228:25368f053411 1001 uint8_t deviceAppearance[2];
Andrea Palmieri 187:2e517d3ddd71 1002
Wolfgang Betz 130:770ce14d3d15 1003 STORE_LE_16(deviceAppearance, appearance);
Wolfgang Betz 132:51056160fa4a 1004 PRINTF("input: incoming = %d deviceAppearance= 0x%x 0x%x\n\r", appearance, deviceAppearance[1], deviceAppearance[0]);
Wolfgang Betz 130:770ce14d3d15 1005
Andrea Palmieri 228:25368f053411 1006 ret = aci_gatt_update_char_value(g_gap_service_handle,
Andrea Palmieri 228:25368f053411 1007 g_appearance_char_handle,
Andrea Palmieri 228:25368f053411 1008 0, 2, (uint8_t *)deviceAppearance);
Andrea Palmieri 187:2e517d3ddd71 1009 if (BLE_STATUS_SUCCESS == ret){
Andrea Palmieri 187:2e517d3ddd71 1010 return BLE_ERROR_NONE;
Andrea Palmieri 187:2e517d3ddd71 1011 }
Andrea Palmieri 187:2e517d3ddd71 1012
Andrea Palmieri 217:23870c55b07e 1013 PRINTF("setAppearance failed (ret=0x%x)!!\n\r", ret);
Andrea Palmieri 187:2e517d3ddd71 1014 switch (ret) {
Andrea Palmieri 187:2e517d3ddd71 1015 case BLE_STATUS_INVALID_HANDLE:
Andrea Palmieri 187:2e517d3ddd71 1016 case BLE_STATUS_INVALID_PARAMETER:
Andrea Palmieri 187:2e517d3ddd71 1017 return BLE_ERROR_INVALID_PARAM;
Andrea Palmieri 187:2e517d3ddd71 1018 case BLE_STATUS_INSUFFICIENT_RESOURCES:
Andrea Palmieri 187:2e517d3ddd71 1019 return BLE_ERROR_NO_MEM;
Andrea Palmieri 187:2e517d3ddd71 1020 case BLE_STATUS_TIMEOUT:
Andrea Palmieri 187:2e517d3ddd71 1021 return BLE_STACK_BUSY;
Andrea Palmieri 187:2e517d3ddd71 1022 default:
Andrea Palmieri 187:2e517d3ddd71 1023 return BLE_ERROR_UNSPECIFIED;
Andrea Palmieri 187:2e517d3ddd71 1024 }
Wolfgang Betz 130:770ce14d3d15 1025 }
Wolfgang Betz 130:770ce14d3d15 1026
Wolfgang Betz 130:770ce14d3d15 1027 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1028 /*!
Wolfgang Betz 130:770ce14d3d15 1029 @brief Gets the Device Appearance Characteristic
Wolfgang Betz 130:770ce14d3d15 1030
Wolfgang Betz 130:770ce14d3d15 1031 @param[in] appearance
Wolfgang Betz 130:770ce14d3d15 1032 pointer to device appearance value
Wolfgang Betz 130:770ce14d3d15 1033
Wolfgang Betz 130:770ce14d3d15 1034 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 1035
Wolfgang Betz 130:770ce14d3d15 1036 @retval BLE_ERROR_NONE
Wolfgang Betz 130:770ce14d3d15 1037 Everything executed properly
Wolfgang Betz 130:770ce14d3d15 1038
Wolfgang Betz 130:770ce14d3d15 1039 @section EXAMPLE
Wolfgang Betz 130:770ce14d3d15 1040
Wolfgang Betz 130:770ce14d3d15 1041 @code
Wolfgang Betz 130:770ce14d3d15 1042
Wolfgang Betz 130:770ce14d3d15 1043 @endcode
Wolfgang Betz 130:770ce14d3d15 1044 */
Wolfgang Betz 130:770ce14d3d15 1045 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1046 ble_error_t BlueNRGGap::getAppearance(GapAdvertisingData::Appearance *appearanceP)
Wolfgang Betz 130:770ce14d3d15 1047 {
Andrea Palmieri 228:25368f053411 1048 tBleStatus ret;
Andrea Palmieri 228:25368f053411 1049 uint16_t lengthP = 2;
Andrea Palmieri 228:25368f053411 1050
Andrea Palmieri 229:9981f62cdb1a 1051 ret = aci_gatt_read_handle_value(g_appearance_char_handle+BlueNRGGattServer::CHAR_VALUE_HANDLE,
Andrea Palmieri 228:25368f053411 1052 lengthP,
Andrea Palmieri 228:25368f053411 1053 &lengthP,
Andrea Palmieri 228:25368f053411 1054 (uint8_t*)appearanceP);
Andrea Palmieri 228:25368f053411 1055 PRINTF("getAppearance ret=0x%02x (lengthP=%d)\n\r", ret, lengthP);
Andrea Palmieri 228:25368f053411 1056 if (ret == BLE_STATUS_SUCCESS) {
Andrea Palmieri 228:25368f053411 1057 return BLE_ERROR_NONE;
Andrea Palmieri 228:25368f053411 1058 } else {
Andrea Palmieri 228:25368f053411 1059 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Andrea Palmieri 228:25368f053411 1060 }
Andrea Palmieri 228:25368f053411 1061
Wolfgang Betz 130:770ce14d3d15 1062 }
Wolfgang Betz 130:770ce14d3d15 1063
Andrea Palmieri 160:174387d53809 1064 GapScanningParams* BlueNRGGap::getScanningParams(void)
Andrea Palmieri 160:174387d53809 1065 {
Andrea Palmieri 160:174387d53809 1066 return &_scanningParams;
Andrea Palmieri 160:174387d53809 1067 }
Andrea Palmieri 160:174387d53809 1068
Wolfgang Betz 165:3576598c0889 1069 static void makeConnection(void)
Wolfgang Betz 162:667f97a4db7f 1070 {
Wolfgang Betz 165:3576598c0889 1071 BlueNRGGap::getInstance().createConnection();
Wolfgang Betz 162:667f97a4db7f 1072 }
Wolfgang Betz 162:667f97a4db7f 1073
Wolfgang Betz 132:51056160fa4a 1074 void BlueNRGGap::Discovery_CB(Reason_t reason,
Wolfgang Betz 132:51056160fa4a 1075 uint8_t adv_type,
Andrea Palmieri 229:9981f62cdb1a 1076 uint8_t addr_type,
Wolfgang Betz 132:51056160fa4a 1077 uint8_t *addr,
Wolfgang Betz 132:51056160fa4a 1078 uint8_t *data_length,
Wolfgang Betz 132:51056160fa4a 1079 uint8_t *data,
Wolfgang Betz 132:51056160fa4a 1080 uint8_t *RSSI)
Wolfgang Betz 132:51056160fa4a 1081 {
Wolfgang Betz 132:51056160fa4a 1082 switch (reason) {
Wolfgang Betz 132:51056160fa4a 1083 case DEVICE_FOUND:
Wolfgang Betz 132:51056160fa4a 1084 {
Wolfgang Betz 132:51056160fa4a 1085 GapAdvertisingParams::AdvertisingType_t type;
Wolfgang Betz 132:51056160fa4a 1086 bool isScanResponse = false;
Andrea Palmieri 229:9981f62cdb1a 1087
Andrea Palmieri 229:9981f62cdb1a 1088 /*
Andrea Palmieri 229:9981f62cdb1a 1089 * Whitelisting (scan policy):
Andrea Palmieri 229:9981f62cdb1a 1090 * SCAN_POLICY_FILTER_ALL_ADV (ADV packets only from devs in the White List) &&
Andrea Palmieri 229:9981f62cdb1a 1091 * Private Random Address
Andrea Palmieri 229:9981f62cdb1a 1092 * => scan_results = FALSE
Andrea Palmieri 229:9981f62cdb1a 1093 * FIXME: the Security Manager should be implemented
Andrea Palmieri 229:9981f62cdb1a 1094 */
Andrea Palmieri 229:9981f62cdb1a 1095 ScanningPolicyMode_t mode = getScanningPolicyMode();
Andrea Palmieri 229:9981f62cdb1a 1096 PRINTF("mode=%u addr_type=%u\n\r", mode, addr_type);
Andrea Palmieri 229:9981f62cdb1a 1097 if(mode == Gap::SCAN_POLICY_FILTER_ALL_ADV ||
Andrea Palmieri 229:9981f62cdb1a 1098 (addr_type == RESOLVABLE_PRIVATE_ADDR ||
Andrea Palmieri 229:9981f62cdb1a 1099 addr_type == NON_RESOLVABLE_PRIVATE_ADDR)) {
Andrea Palmieri 229:9981f62cdb1a 1100 return;
Andrea Palmieri 229:9981f62cdb1a 1101 }
Andrea Palmieri 229:9981f62cdb1a 1102
Wolfgang Betz 132:51056160fa4a 1103 switch(adv_type) {
Wolfgang Betz 132:51056160fa4a 1104 case ADV_IND:
Wolfgang Betz 132:51056160fa4a 1105 type = GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED;
Wolfgang Betz 132:51056160fa4a 1106 break;
Wolfgang Betz 132:51056160fa4a 1107 case ADV_DIRECT_IND:
Wolfgang Betz 132:51056160fa4a 1108 type = GapAdvertisingParams::ADV_CONNECTABLE_DIRECTED;
Wolfgang Betz 132:51056160fa4a 1109 break;
Wolfgang Betz 132:51056160fa4a 1110 case ADV_SCAN_IND:
Wolfgang Betz 132:51056160fa4a 1111 case SCAN_RSP:
Wolfgang Betz 132:51056160fa4a 1112 type = GapAdvertisingParams::ADV_SCANNABLE_UNDIRECTED;
Wolfgang Betz 132:51056160fa4a 1113 isScanResponse = true;
Wolfgang Betz 132:51056160fa4a 1114 break;
Wolfgang Betz 132:51056160fa4a 1115 case ADV_NONCONN_IND:
Wolfgang Betz 132:51056160fa4a 1116 type = GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED;
Andrea Palmieri 142:adf1567d3900 1117 break;
Andrea Palmieri 142:adf1567d3900 1118 default:
Andrea Palmieri 142:adf1567d3900 1119 type = GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED;
Wolfgang Betz 132:51056160fa4a 1120 }
Wolfgang Betz 132:51056160fa4a 1121
Andrea Palmieri 217:23870c55b07e 1122 PRINTF("data_length=%d adv peerAddr[%02x %02x %02x %02x %02x %02x] \r\n",
Andrea Palmieri 217:23870c55b07e 1123 *data_length, addr[5], addr[4], addr[3], addr[2], addr[1], addr[0]);
Wolfgang Betz 132:51056160fa4a 1124 processAdvertisementReport(addr, *RSSI, isScanResponse, type, *data_length, data);
Andrea Palmieri 160:174387d53809 1125 PRINTF("!!!After processAdvertisementReport\n\r");
Wolfgang Betz 132:51056160fa4a 1126 }
Wolfgang Betz 132:51056160fa4a 1127 break;
Wolfgang Betz 132:51056160fa4a 1128
Wolfgang Betz 132:51056160fa4a 1129 case DISCOVERY_COMPLETE:
Wolfgang Betz 132:51056160fa4a 1130 // The discovery is complete. If this is due to a stop scanning (i.e., the device
Wolfgang Betz 132:51056160fa4a 1131 // we are interested in has been found) and a connection has been requested
Andrea Palmieri 229:9981f62cdb1a 1132 // then we start the device connection.
Andrea Palmieri 145:024a552e4715 1133 PRINTF("DISCOVERY_COMPLETE\n\r");
Wolfgang Betz 132:51056160fa4a 1134 _scanning = false;
Wolfgang Betz 132:51056160fa4a 1135
Wolfgang Betz 165:3576598c0889 1136 // Since the DISCOVERY_COMPLETE event can be received during the scanning interval,
Andrea Palmieri 229:9981f62cdb1a 1137 // we need to delay the starting of connection
Wolfgang Betz 165:3576598c0889 1138 uint16_t delay = 2*(_scanningParams.getInterval());
Wolfgang Betz 165:3576598c0889 1139
Andrea Palmieri 217:23870c55b07e 1140 #ifdef AST_FOR_MBED_OS
Wolfgang Betz 162:667f97a4db7f 1141 if(_connecting) {
Wolfgang Betz 165:3576598c0889 1142 minar::Scheduler::postCallback(makeConnection).delay(minar::milliseconds(delay));
Wolfgang Betz 132:51056160fa4a 1143 }
Andrea Palmieri 217:23870c55b07e 1144 #else
Andrea Palmieri 217:23870c55b07e 1145 Clock_Wait(delay);
Andrea Palmieri 217:23870c55b07e 1146 if(_connecting) {
Andrea Palmieri 217:23870c55b07e 1147 makeConnection();
Andrea Palmieri 217:23870c55b07e 1148 }
Andrea Palmieri 217:23870c55b07e 1149 #endif /* AST_FOR_MBED_OS */
Wolfgang Betz 132:51056160fa4a 1150
Wolfgang Betz 132:51056160fa4a 1151 break;
Wolfgang Betz 132:51056160fa4a 1152 }
Wolfgang Betz 132:51056160fa4a 1153 }
Wolfgang Betz 132:51056160fa4a 1154
Wolfgang Betz 132:51056160fa4a 1155 ble_error_t BlueNRGGap::startRadioScan(const GapScanningParams &scanningParams)
Wolfgang Betz 132:51056160fa4a 1156 {
Wolfgang Betz 132:51056160fa4a 1157
Wolfgang Betz 165:3576598c0889 1158 tBleStatus ret = BLE_STATUS_SUCCESS;
Andrea Palmieri 222:37a7e289ee3d 1159
Andrea Palmieri 222:37a7e289ee3d 1160 // Stop ADV before scanning
Andrea Palmieri 223:36df860f7ffc 1161 /*
Andrea Palmieri 222:37a7e289ee3d 1162 if (state.advertising == 1) {
Andrea Palmieri 222:37a7e289ee3d 1163 stopAdvertising();
Andrea Palmieri 222:37a7e289ee3d 1164 }
Andrea Palmieri 223:36df860f7ffc 1165 */
Andrea Palmieri 222:37a7e289ee3d 1166
Andrea Palmieri 229:9981f62cdb1a 1167 /*
Andrea Palmieri 229:9981f62cdb1a 1168 * Whitelisting (scan policy):
Andrea Palmieri 229:9981f62cdb1a 1169 * SCAN_POLICY_FILTER_ALL_ADV (ADV packets only from devs in the White List) &&
Andrea Palmieri 229:9981f62cdb1a 1170 * White List is empty
Andrea Palmieri 229:9981f62cdb1a 1171 * => scan operation = FAILURE
Andrea Palmieri 229:9981f62cdb1a 1172 * FIXME: the Security Manager should be implemented
Andrea Palmieri 229:9981f62cdb1a 1173 */
Andrea Palmieri 229:9981f62cdb1a 1174 ScanningPolicyMode_t mode = getScanningPolicyMode();
Andrea Palmieri 229:9981f62cdb1a 1175 uint8_t whiteListSize = whitelistAddresses.size;
Andrea Palmieri 229:9981f62cdb1a 1176 if(whiteListSize == 0 && mode == Gap::SCAN_POLICY_FILTER_ALL_ADV) {
Andrea Palmieri 229:9981f62cdb1a 1177 return BLE_ERROR_OPERATION_NOT_PERMITTED;
Andrea Palmieri 229:9981f62cdb1a 1178 }
Andrea Palmieri 229:9981f62cdb1a 1179
Andrea Palmieri 217:23870c55b07e 1180 ret = btleStartRadioScan(scanningParams.getActiveScanning(),
Andrea Palmieri 217:23870c55b07e 1181 scanningParams.getInterval(),
Andrea Palmieri 217:23870c55b07e 1182 scanningParams.getWindow(),
Andrea Palmieri 217:23870c55b07e 1183 addr_type);
Andrea Palmieri 217:23870c55b07e 1184
Andrea Palmieri 229:9981f62cdb1a 1185 PRINTF("Scanning...\n\r");
Andrea Palmieri 229:9981f62cdb1a 1186 PRINTF("scanningParams.getInterval()=%u[msec]\r\n",(scanningParams.getInterval()*625)/1000);
Andrea Palmieri 229:9981f62cdb1a 1187 PRINTF("scanningParams.getWindow()=%u[msec]\r\n",(scanningParams.getWindow()*625)/1000);
Andrea Palmieri 229:9981f62cdb1a 1188 //PRINTF("_advParams.getInterval()=%u\r\n",_advParams.getInterval());
Andrea Palmieri 229:9981f62cdb1a 1189 //PRINTF("CONN_P1=%u\r\n",(unsigned)CONN_P1);
Andrea Palmieri 229:9981f62cdb1a 1190 //PRINTF("CONN_P2=%u\r\n",(unsigned)CONN_P2);
Andrea Palmieri 217:23870c55b07e 1191 if (BLE_STATUS_SUCCESS == ret){
Andrea Palmieri 217:23870c55b07e 1192 PRINTF("Observation Procedure Started\n");
Andrea Palmieri 217:23870c55b07e 1193 _scanning = true;
Andrea Palmieri 217:23870c55b07e 1194 return BLE_ERROR_NONE;
Andrea Palmieri 145:024a552e4715 1195 }
Andrea Palmieri 217:23870c55b07e 1196
Andrea Palmieri 217:23870c55b07e 1197 // Observer role is not supported by X-NUCLEO-IDB04A1, return BLE_ERROR_NOT_IMPLEMENTED
Andrea Palmieri 217:23870c55b07e 1198 switch (ret) {
Andrea Palmieri 217:23870c55b07e 1199 case BLE_STATUS_INVALID_CID:
Andrea Palmieri 229:9981f62cdb1a 1200 PRINTF("Observation Procedure not implemented!!!\n\r");
Andrea Palmieri 217:23870c55b07e 1201 return BLE_ERROR_NOT_IMPLEMENTED;
Andrea Palmieri 217:23870c55b07e 1202 default:
Andrea Palmieri 229:9981f62cdb1a 1203 PRINTF("Observation Procedure failed (0x%02X)\n\r", ret);
Andrea Palmieri 217:23870c55b07e 1204 return BLE_ERROR_UNSPECIFIED;
Wolfgang Betz 132:51056160fa4a 1205 }
Andrea Palmieri 217:23870c55b07e 1206
Wolfgang Betz 130:770ce14d3d15 1207 }
Wolfgang Betz 130:770ce14d3d15 1208
Wolfgang Betz 130:770ce14d3d15 1209 ble_error_t BlueNRGGap::stopScan() {
Wolfgang Betz 165:3576598c0889 1210 tBleStatus ret = BLE_STATUS_SUCCESS;
Andrea Palmieri 229:9981f62cdb1a 1211
Andrea Palmieri 229:9981f62cdb1a 1212 PRINTF("stopScan\n\r");
Andrea Palmieri 217:23870c55b07e 1213 ret = aci_gap_terminate_gap_procedure(GAP_OBSERVATION_PROC);
Wolfgang Betz 132:51056160fa4a 1214
Wolfgang Betz 132:51056160fa4a 1215 if (ret != BLE_STATUS_SUCCESS) {
Andrea Palmieri 229:9981f62cdb1a 1216 PRINTF("GAP Terminate Gap Procedure failed\n");
Wolfgang Betz 132:51056160fa4a 1217 return BLE_ERROR_UNSPECIFIED;
Wolfgang Betz 132:51056160fa4a 1218 } else {
Wolfgang Betz 132:51056160fa4a 1219 PRINTF("Discovery Procedure Terminated\n");
Wolfgang Betz 130:770ce14d3d15 1220 return BLE_ERROR_NONE;
Wolfgang Betz 132:51056160fa4a 1221 }
Wolfgang Betz 130:770ce14d3d15 1222 }
Wolfgang Betz 130:770ce14d3d15 1223
Wolfgang Betz 130:770ce14d3d15 1224 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1225 /*!
Wolfgang Betz 130:770ce14d3d15 1226 @brief set Tx power level
Wolfgang Betz 130:770ce14d3d15 1227 @param[in] txPower Transmission Power level
Wolfgang Betz 130:770ce14d3d15 1228 @returns ble_error_t
Wolfgang Betz 130:770ce14d3d15 1229 */
Wolfgang Betz 130:770ce14d3d15 1230 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1231 ble_error_t BlueNRGGap::setTxPower(int8_t txPower)
Wolfgang Betz 130:770ce14d3d15 1232 {
Wolfgang Betz 130:770ce14d3d15 1233 tBleStatus ret;
Wolfgang Betz 130:770ce14d3d15 1234
Wolfgang Betz 130:770ce14d3d15 1235 int8_t enHighPower = 0;
Andrea Palmieri 201:a9bc2e8b01d7 1236 int8_t paLevel = 0;
Andrea Palmieri 201:a9bc2e8b01d7 1237
Andrea Palmieri 228:25368f053411 1238 ret = getHighPowerAndPALevelValue(txPower, enHighPower, paLevel);
Andrea Palmieri 228:25368f053411 1239 if(ret!=BLE_STATUS_SUCCESS) {
Andrea Palmieri 228:25368f053411 1240 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Andrea Palmieri 228:25368f053411 1241 }
Andrea Palmieri 201:a9bc2e8b01d7 1242
Wolfgang Betz 132:51056160fa4a 1243 PRINTF("enHighPower=%d, paLevel=%d\n\r", enHighPower, paLevel);
Wolfgang Betz 130:770ce14d3d15 1244 ret = aci_hal_set_tx_power_level(enHighPower, paLevel);
Wolfgang Betz 130:770ce14d3d15 1245 if(ret!=BLE_STATUS_SUCCESS) {
Andrea Palmieri 228:25368f053411 1246 return BLE_ERROR_PARAM_OUT_OF_RANGE;
Wolfgang Betz 130:770ce14d3d15 1247 }
Andrea Palmieri 201:a9bc2e8b01d7 1248
Wolfgang Betz 130:770ce14d3d15 1249 return BLE_ERROR_NONE;
Wolfgang Betz 130:770ce14d3d15 1250 }
Wolfgang Betz 130:770ce14d3d15 1251
Wolfgang Betz 130:770ce14d3d15 1252 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1253 /*!
Wolfgang Betz 130:770ce14d3d15 1254 @brief get permitted Tx power values
Wolfgang Betz 130:770ce14d3d15 1255 @param[in] values pointer to pointer to permitted power values
Wolfgang Betz 130:770ce14d3d15 1256 @param[in] num number of values
Wolfgang Betz 130:770ce14d3d15 1257 */
Wolfgang Betz 130:770ce14d3d15 1258 /**************************************************************************/
Wolfgang Betz 130:770ce14d3d15 1259 void BlueNRGGap::getPermittedTxPowerValues(const int8_t **valueArrayPP, size_t *countP) {
Wolfgang Betz 130:770ce14d3d15 1260 static const int8_t permittedTxValues[] = {
Andrea Palmieri 229:9981f62cdb1a 1261 -18, -15, -14, -12, -11, -9, -8, -6, -5, -2, 0, 2, 4, 5, 8
Wolfgang Betz 130:770ce14d3d15 1262 };
Wolfgang Betz 130:770ce14d3d15 1263
Wolfgang Betz 130:770ce14d3d15 1264 *valueArrayPP = permittedTxValues;
Wolfgang Betz 130:770ce14d3d15 1265 *countP = sizeof(permittedTxValues) / sizeof(int8_t);
Wolfgang Betz 130:770ce14d3d15 1266 }
Wolfgang Betz 132:51056160fa4a 1267
Andrea Palmieri 229:9981f62cdb1a 1268 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1269 /*!
Andrea Palmieri 232:aead10288880 1270 @brief Set advertising parameters according to the current state
Andrea Palmieri 232:aead10288880 1271 Parameters value is set taking into account guidelines of the BlueNRG
Andrea Palmieri 232:aead10288880 1272 time slots allocation
Andrea Palmieri 232:aead10288880 1273 */
Andrea Palmieri 232:aead10288880 1274 /**************************************************************************/
Andrea Palmieri 232:aead10288880 1275 void BlueNRGGap::setAdvParameters(void)
Andrea Palmieri 232:aead10288880 1276 {
Andrea Palmieri 232:aead10288880 1277 uint32_t advIntMS;
Andrea Palmieri 232:aead10288880 1278
Andrea Palmieri 232:aead10288880 1279 if(state.connected == 1) {
Andrea Palmieri 232:aead10288880 1280 advIntMS = (conn_min_interval*1.25)-GUARD_INT;
Andrea Palmieri 232:aead10288880 1281 advInterval = _advParams.MSEC_TO_ADVERTISEMENT_DURATION_UNITS(advIntMS);
Andrea Palmieri 232:aead10288880 1282 } else {
Andrea Palmieri 232:aead10288880 1283 advInterval = _advParams.getIntervalInADVUnits();
Andrea Palmieri 232:aead10288880 1284 }
Andrea Palmieri 232:aead10288880 1285 }
Andrea Palmieri 232:aead10288880 1286
Andrea Palmieri 232:aead10288880 1287 /**************************************************************************/
Andrea Palmieri 232:aead10288880 1288 /*!
Andrea Palmieri 229:9981f62cdb1a 1289 @brief Set connection parameters according to the current state (ADV and/or SCAN)
Andrea Palmieri 229:9981f62cdb1a 1290 Parameters value is set taking into account guidelines of the BlueNRG
Andrea Palmieri 229:9981f62cdb1a 1291 time slots allocation
Andrea Palmieri 229:9981f62cdb1a 1292 */
Andrea Palmieri 229:9981f62cdb1a 1293 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1294 void BlueNRGGap::setConnectionParameters(void)
Andrea Palmieri 229:9981f62cdb1a 1295 {
Andrea Palmieri 229:9981f62cdb1a 1296 if (state.advertising == 1) {
Andrea Palmieri 229:9981f62cdb1a 1297
Andrea Palmieri 232:aead10288880 1298 if (_scanningParams.getInterval() < advInterval) {
Andrea Palmieri 232:aead10288880 1299 PRINTF("state.adv=1 scanInterval<advInterval\r\n");
Andrea Palmieri 232:aead10288880 1300 scanInterval = advInterval;
Andrea Palmieri 232:aead10288880 1301 scanWindow = advInterval;
Andrea Palmieri 229:9981f62cdb1a 1302 } else {
Andrea Palmieri 232:aead10288880 1303 PRINTF("state.adv=1 scanInterval>=advInterval\r\n");
Andrea Palmieri 229:9981f62cdb1a 1304 scanInterval = _scanningParams.getInterval();
Andrea Palmieri 229:9981f62cdb1a 1305 scanWindow = _scanningParams.getWindow();
Andrea Palmieri 229:9981f62cdb1a 1306 }
Andrea Palmieri 234:3f6bba52b307 1307
Andrea Palmieri 234:3f6bba52b307 1308 if(advInterval>(MAX_INT_CONN-(GUARD_INT/1.25))) { //(4000-GUARD_INT)ms
Andrea Palmieri 234:3f6bba52b307 1309 conn_min_interval = MAX_INT_CONN;
Andrea Palmieri 234:3f6bba52b307 1310 conn_max_interval = MAX_INT_CONN;
Andrea Palmieri 234:3f6bba52b307 1311 } else {
Andrea Palmieri 234:3f6bba52b307 1312 conn_min_interval = (_advParams.ADVERTISEMENT_DURATION_UNITS_TO_MS(advInterval)+GUARD_INT)/1.25;
Andrea Palmieri 234:3f6bba52b307 1313 conn_max_interval = (_advParams.ADVERTISEMENT_DURATION_UNITS_TO_MS(advInterval)+GUARD_INT)/1.25;
Andrea Palmieri 234:3f6bba52b307 1314 }
Andrea Palmieri 229:9981f62cdb1a 1315
Andrea Palmieri 229:9981f62cdb1a 1316 } else {
Andrea Palmieri 229:9981f62cdb1a 1317
Andrea Palmieri 232:aead10288880 1318 PRINTF("state.adv = 0\r\n");
Andrea Palmieri 232:aead10288880 1319
Andrea Palmieri 229:9981f62cdb1a 1320 scanInterval = _scanningParams.getInterval();
Andrea Palmieri 229:9981f62cdb1a 1321 scanWindow = _scanningParams.getWindow();
Andrea Palmieri 234:3f6bba52b307 1322 if(SCAN_DURATION_UNITS_TO_MSEC(scanInterval)>(MAX_INT_CONN*1.25) ||
Andrea Palmieri 234:3f6bba52b307 1323 SCAN_DURATION_UNITS_TO_MSEC(scanInterval)<(MIN_INT_CONN*1.25)) { //(4000)ms || (7.5)ms
Andrea Palmieri 234:3f6bba52b307 1324 conn_min_interval = DEF_INT_CONN;
Andrea Palmieri 234:3f6bba52b307 1325 conn_max_interval = DEF_INT_CONN;
Andrea Palmieri 234:3f6bba52b307 1326 } else {
Andrea Palmieri 234:3f6bba52b307 1327 conn_min_interval = SCAN_DURATION_UNITS_TO_MSEC(scanInterval)/1.25;
Andrea Palmieri 234:3f6bba52b307 1328 conn_max_interval = SCAN_DURATION_UNITS_TO_MSEC(scanInterval)/1.25;
Andrea Palmieri 234:3f6bba52b307 1329 }
Andrea Palmieri 229:9981f62cdb1a 1330 }
Andrea Palmieri 229:9981f62cdb1a 1331 PRINTF("scanInterval=%u[msec]\r\n",SCAN_DURATION_UNITS_TO_MSEC(scanInterval));
Andrea Palmieri 229:9981f62cdb1a 1332 PRINTF("scanWindow()=%u[msec]\r\n",SCAN_DURATION_UNITS_TO_MSEC(scanWindow));
Andrea Palmieri 234:3f6bba52b307 1333 PRINTF("conn_min_interval=%u[msec]\r\n",(unsigned)(conn_min_interval*1.25));
Andrea Palmieri 234:3f6bba52b307 1334 PRINTF("conn_max_interval=%u[msec]\r\n",(unsigned)(conn_max_interval*1.25));
Andrea Palmieri 229:9981f62cdb1a 1335
Andrea Palmieri 229:9981f62cdb1a 1336 }
Andrea Palmieri 229:9981f62cdb1a 1337
Andrea Palmieri 181:749071129d2e 1338 ble_error_t BlueNRGGap::createConnection ()
Wolfgang Betz 132:51056160fa4a 1339 {
Wolfgang Betz 132:51056160fa4a 1340 tBleStatus ret;
Andrea Palmieri 229:9981f62cdb1a 1341
Andrea Palmieri 229:9981f62cdb1a 1342 /*
Andrea Palmieri 229:9981f62cdb1a 1343 Before creating connection, set parameters according
Andrea Palmieri 229:9981f62cdb1a 1344 to previous or current procedure (ADV and/or SCAN)
Andrea Palmieri 229:9981f62cdb1a 1345 */
Andrea Palmieri 229:9981f62cdb1a 1346 setConnectionParameters();
Andrea Palmieri 229:9981f62cdb1a 1347
Wolfgang Betz 132:51056160fa4a 1348 /*
Wolfgang Betz 163:4c008b1089e9 1349 Scan_Interval, Scan_Window, Peer_Address_Type, Peer_Address, Own_Address_Type, Conn_Interval_Min,
Wolfgang Betz 163:4c008b1089e9 1350 Conn_Interval_Max, Conn_Latency, Supervision_Timeout, Conn_Len_Min, Conn_Len_Max
Wolfgang Betz 132:51056160fa4a 1351 */
Andrea Palmieri 229:9981f62cdb1a 1352 ret = aci_gap_create_connection(scanInterval,
Andrea Palmieri 229:9981f62cdb1a 1353 scanWindow,
Andrea Palmieri 229:9981f62cdb1a 1354 _peerAddrType,
Wolfgang Betz 163:4c008b1089e9 1355 (unsigned char*)_peerAddr,
Andrea Palmieri 229:9981f62cdb1a 1356 addr_type,
Andrea Palmieri 229:9981f62cdb1a 1357 conn_min_interval, conn_max_interval, 0,
Andrea Palmieri 220:e02936f0d4c7 1358 SUPERV_TIMEOUT, CONN_L1 , CONN_L1);
Wolfgang Betz 165:3576598c0889 1359
Wolfgang Betz 165:3576598c0889 1360 _connecting = false;
Wolfgang Betz 163:4c008b1089e9 1361
Wolfgang Betz 163:4c008b1089e9 1362 if (ret != BLE_STATUS_SUCCESS) {
Andrea Palmieri 229:9981f62cdb1a 1363 PRINTF("Error while starting connection (ret=0x%02X).\n\r", ret);
Wolfgang Betz 132:51056160fa4a 1364 return BLE_ERROR_UNSPECIFIED;
Wolfgang Betz 132:51056160fa4a 1365 } else {
Wolfgang Betz 132:51056160fa4a 1366 PRINTF("Connection started.\n");
Wolfgang Betz 132:51056160fa4a 1367 return BLE_ERROR_NONE;
Wolfgang Betz 132:51056160fa4a 1368 }
Wolfgang Betz 132:51056160fa4a 1369 }
Wolfgang Betz 132:51056160fa4a 1370
Wolfgang Betz 132:51056160fa4a 1371 ble_error_t BlueNRGGap::connect (const Gap::Address_t peerAddr,
Wolfgang Betz 132:51056160fa4a 1372 Gap::AddressType_t peerAddrType,
Wolfgang Betz 132:51056160fa4a 1373 const ConnectionParams_t *connectionParams,
Wolfgang Betz 132:51056160fa4a 1374 const GapScanningParams *scanParams)
Wolfgang Betz 132:51056160fa4a 1375 {
Andrea Palmieri 142:adf1567d3900 1376 /* avoid compiler warnings about unused variables */
Andrea Palmieri 142:adf1567d3900 1377 (void)connectionParams;
Andrea Palmieri 142:adf1567d3900 1378 (void)scanParams;
Andrea Palmieri 142:adf1567d3900 1379
Andrea Palmieri 217:23870c55b07e 1380 // Save the peer address
Wolfgang Betz 132:51056160fa4a 1381 for(int i=0; i<BDADDR_SIZE; i++) {
Wolfgang Betz 132:51056160fa4a 1382 _peerAddr[i] = peerAddr[i];
Wolfgang Betz 132:51056160fa4a 1383 }
Andrea Palmieri 229:9981f62cdb1a 1384 _peerAddrType = peerAddrType;
Wolfgang Betz 132:51056160fa4a 1385
Andrea Palmieri 181:749071129d2e 1386 _connecting = true;
Wolfgang Betz 132:51056160fa4a 1387
Wolfgang Betz 132:51056160fa4a 1388 if(_scanning) {
Wolfgang Betz 132:51056160fa4a 1389 stopScan();
Wolfgang Betz 132:51056160fa4a 1390 } else {
Wolfgang Betz 165:3576598c0889 1391 PRINTF("Calling createConnection from connect()\n\r");
Wolfgang Betz 165:3576598c0889 1392 return createConnection();
Wolfgang Betz 132:51056160fa4a 1393 }
Wolfgang Betz 132:51056160fa4a 1394
Wolfgang Betz 132:51056160fa4a 1395 return BLE_ERROR_NONE;
Wolfgang Betz 132:51056160fa4a 1396 }
Andrea Palmieri 229:9981f62cdb1a 1397
Andrea Palmieri 229:9981f62cdb1a 1398 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1399 /*!
Andrea Palmieri 229:9981f62cdb1a 1400 @brief Set the advertising policy filter mode that will be used in
Andrea Palmieri 229:9981f62cdb1a 1401 the next call to startAdvertising().
Andrea Palmieri 229:9981f62cdb1a 1402
Andrea Palmieri 229:9981f62cdb1a 1403 @returns \ref ble_errror_t
Andrea Palmieri 229:9981f62cdb1a 1404
Andrea Palmieri 229:9981f62cdb1a 1405 @retval BLE_ERROR_NONE
Andrea Palmieri 229:9981f62cdb1a 1406 Everything executed properly.
Andrea Palmieri 229:9981f62cdb1a 1407
Andrea Palmieri 229:9981f62cdb1a 1408 BLE_ERROR_NOT_IMPLEMENTED
Andrea Palmieri 229:9981f62cdb1a 1409 This feature is currently note implemented.
Andrea Palmieri 229:9981f62cdb1a 1410 */
Andrea Palmieri 229:9981f62cdb1a 1411 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1412 ble_error_t BlueNRGGap::setAdvertisingPolicyMode(Gap::AdvertisingPolicyMode_t mode)
Andrea Palmieri 229:9981f62cdb1a 1413 {
Andrea Palmieri 229:9981f62cdb1a 1414 advertisingPolicyMode = mode;
Andrea Palmieri 229:9981f62cdb1a 1415
Andrea Palmieri 229:9981f62cdb1a 1416 return BLE_ERROR_NONE;
Andrea Palmieri 229:9981f62cdb1a 1417 }
Andrea Palmieri 229:9981f62cdb1a 1418
Andrea Palmieri 229:9981f62cdb1a 1419 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1420 /*!
Andrea Palmieri 229:9981f62cdb1a 1421 @brief Set the scanning policy filter mode that will be used in
Andrea Palmieri 229:9981f62cdb1a 1422 the next call to startAdvertising().
Andrea Palmieri 229:9981f62cdb1a 1423
Andrea Palmieri 229:9981f62cdb1a 1424 @returns \ref ble_errror_t
Andrea Palmieri 229:9981f62cdb1a 1425
Andrea Palmieri 229:9981f62cdb1a 1426 @retval BLE_ERROR_NONE
Andrea Palmieri 229:9981f62cdb1a 1427 Everything executed properly.
Andrea Palmieri 229:9981f62cdb1a 1428
Andrea Palmieri 229:9981f62cdb1a 1429 BLE_ERROR_NOT_IMPLEMENTED
Andrea Palmieri 229:9981f62cdb1a 1430 This feature is currently note implemented.
Andrea Palmieri 229:9981f62cdb1a 1431 */
Andrea Palmieri 229:9981f62cdb1a 1432 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1433 ble_error_t BlueNRGGap::setScanningPolicyMode(Gap::ScanningPolicyMode_t mode)
Andrea Palmieri 229:9981f62cdb1a 1434 {
Andrea Palmieri 229:9981f62cdb1a 1435 scanningPolicyMode = mode;
Andrea Palmieri 229:9981f62cdb1a 1436
Andrea Palmieri 229:9981f62cdb1a 1437 return BLE_ERROR_NONE;
Andrea Palmieri 229:9981f62cdb1a 1438 }
Andrea Palmieri 229:9981f62cdb1a 1439
Andrea Palmieri 229:9981f62cdb1a 1440 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1441 /*!
Andrea Palmieri 229:9981f62cdb1a 1442 @brief Get the current advertising policy filter mode.
Andrea Palmieri 229:9981f62cdb1a 1443
Andrea Palmieri 229:9981f62cdb1a 1444 @returns The advertising policy filter mode.
Andrea Palmieri 229:9981f62cdb1a 1445 */
Andrea Palmieri 229:9981f62cdb1a 1446 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1447 Gap::AdvertisingPolicyMode_t BlueNRGGap::getAdvertisingPolicyMode(void) const
Andrea Palmieri 229:9981f62cdb1a 1448 {
Andrea Palmieri 229:9981f62cdb1a 1449 return advertisingPolicyMode;
Andrea Palmieri 229:9981f62cdb1a 1450 }
Andrea Palmieri 229:9981f62cdb1a 1451
Andrea Palmieri 229:9981f62cdb1a 1452 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1453 /*!
Andrea Palmieri 229:9981f62cdb1a 1454 @brief Get the current scanning policy filter mode.
Andrea Palmieri 229:9981f62cdb1a 1455
Andrea Palmieri 229:9981f62cdb1a 1456 @returns The scanning policy filter mode.
Andrea Palmieri 229:9981f62cdb1a 1457
Andrea Palmieri 229:9981f62cdb1a 1458 */
Andrea Palmieri 229:9981f62cdb1a 1459 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1460 Gap::ScanningPolicyMode_t BlueNRGGap::getScanningPolicyMode(void) const
Andrea Palmieri 229:9981f62cdb1a 1461 {
Andrea Palmieri 229:9981f62cdb1a 1462 return scanningPolicyMode;
Andrea Palmieri 229:9981f62cdb1a 1463 }
Andrea Palmieri 229:9981f62cdb1a 1464
Andrea Palmieri 229:9981f62cdb1a 1465 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1466 /*!
Andrea Palmieri 229:9981f62cdb1a 1467 @brief Clear BlueNRGGap's state.
Andrea Palmieri 229:9981f62cdb1a 1468
Andrea Palmieri 229:9981f62cdb1a 1469 @returns ble_error_t
Andrea Palmieri 229:9981f62cdb1a 1470
Andrea Palmieri 229:9981f62cdb1a 1471 @retval BLE_ERROR_NONE
Andrea Palmieri 229:9981f62cdb1a 1472 Everything executed properly
Andrea Palmieri 229:9981f62cdb1a 1473 */
Andrea Palmieri 229:9981f62cdb1a 1474 /**************************************************************************/
Andrea Palmieri 229:9981f62cdb1a 1475 ble_error_t BlueNRGGap::reset(void)
Andrea Palmieri 229:9981f62cdb1a 1476 {
Andrea Palmieri 229:9981f62cdb1a 1477 /* Clear all state that is from the parent, including private members */
Andrea Palmieri 229:9981f62cdb1a 1478 if (Gap::reset() != BLE_ERROR_NONE) {
Andrea Palmieri 229:9981f62cdb1a 1479 return BLE_ERROR_INVALID_STATE;
Andrea Palmieri 229:9981f62cdb1a 1480 }
Andrea Palmieri 229:9981f62cdb1a 1481
Andrea Palmieri 229:9981f62cdb1a 1482 /* Clear derived class members */
Andrea Palmieri 229:9981f62cdb1a 1483 m_connectionHandle = BLE_CONN_HANDLE_INVALID;
Andrea Palmieri 229:9981f62cdb1a 1484
Andrea Palmieri 229:9981f62cdb1a 1485 memset(deviceAppearance, 0, sizeof(deviceAppearance));
Andrea Palmieri 229:9981f62cdb1a 1486 memset(local_name, 0, LOCAL_NAME_MAX_SIZE);
Andrea Palmieri 229:9981f62cdb1a 1487 memset(local_name, 0, UUID_BUFFER_SIZE);
Andrea Palmieri 229:9981f62cdb1a 1488 memset(AdvData, 0, ADV_DATA_MAX_SIZE);
Andrea Palmieri 229:9981f62cdb1a 1489
Andrea Palmieri 229:9981f62cdb1a 1490 /* Set the whitelist policy filter modes to IGNORE_WHITELIST */
Andrea Palmieri 229:9981f62cdb1a 1491 advertisingPolicyMode = Gap::ADV_POLICY_IGNORE_WHITELIST;
Andrea Palmieri 229:9981f62cdb1a 1492 scanningPolicyMode = Gap::SCAN_POLICY_IGNORE_WHITELIST;
Andrea Palmieri 229:9981f62cdb1a 1493
Andrea Palmieri 229:9981f62cdb1a 1494 return BLE_ERROR_NONE;
Andrea Palmieri 229:9981f62cdb1a 1495 }
Andrea Palmieri 229:9981f62cdb1a 1496