My fork of X_NUCLEO_IDB0XA1

Fork of X_NUCLEO_IDB0XA1 by ST

Committer:
Andrea Palmieri
Date:
Mon May 16 17:22:03 2016 +0200
Revision:
229:9981f62cdb1a
Parent:
228:25368f053411
Child:
232:aead10288880
Fix issues and add features

- Fix handles management
- Fix UUIDs management
- Implement API to read random address
- Fix clearing/setting of ADV payload
- Fix scanning behaviour
- Fix scanning while a connection is ongoing
- Implement Char Descriptor discovery
- Implement scanning/advertising filter policy (White List partial management)
- Update underlying BlueNRG stack
- Cosmetics

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