BLE

Fork of BLE_API by Bluetooth Low Energy

Committer:
vcoubard
Date:
Mon Jan 11 08:51:52 2016 +0000
Revision:
1097:c3a43f09f1c5
Parent:
1092:58b2dac13261
Child:
1099:5f6b5ea5d5f2
Synchronized with git rev 39e3e8d1
Author: Andres Amaya Garcia
Modify functions that manipulate adv payload

Modify the functions addData() and updateData() to correctly update the payload
information for a specified AD type if that type was already present in the
payload. For addData() if the AD type is not found, it is added to the payload.
In contrast, in updateData() if the AD type is not found an error is returned.

Documentation was updated accordingly.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
rgrover1 711:b2e1a2660ec2 1 /* mbed Microcontroller Library
rgrover1 711:b2e1a2660ec2 2 * Copyright (c) 2006-2013 ARM Limited
rgrover1 711:b2e1a2660ec2 3 *
rgrover1 711:b2e1a2660ec2 4 * Licensed under the Apache License, Version 2.0 (the "License");
rgrover1 711:b2e1a2660ec2 5 * you may not use this file except in compliance with the License.
rgrover1 711:b2e1a2660ec2 6 * You may obtain a copy of the License at
rgrover1 711:b2e1a2660ec2 7 *
rgrover1 711:b2e1a2660ec2 8 * http://www.apache.org/licenses/LICENSE-2.0
rgrover1 711:b2e1a2660ec2 9 *
rgrover1 711:b2e1a2660ec2 10 * Unless required by applicable law or agreed to in writing, software
rgrover1 711:b2e1a2660ec2 11 * distributed under the License is distributed on an "AS IS" BASIS,
rgrover1 711:b2e1a2660ec2 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
rgrover1 711:b2e1a2660ec2 13 * See the License for the specific language governing permissions and
rgrover1 711:b2e1a2660ec2 14 * limitations under the License.
rgrover1 711:b2e1a2660ec2 15 */
rgrover1 711:b2e1a2660ec2 16
rgrover1 711:b2e1a2660ec2 17 #ifndef __GAP_H__
rgrover1 711:b2e1a2660ec2 18 #define __GAP_H__
rgrover1 711:b2e1a2660ec2 19
vcoubard 1079:79c089630b38 20 #include "ble/BLEProtocol.h"
rgrover1 711:b2e1a2660ec2 21 #include "GapAdvertisingData.h"
rgrover1 711:b2e1a2660ec2 22 #include "GapAdvertisingParams.h"
rgrover1 711:b2e1a2660ec2 23 #include "GapScanningParams.h"
rgrover1 711:b2e1a2660ec2 24 #include "GapEvents.h"
rgrover1 830:9072de50087b 25 #include "CallChainOfFunctionPointersWithContext.h"
rgrover1 711:b2e1a2660ec2 26 #include "FunctionPointerWithContext.h"
rgrover1 711:b2e1a2660ec2 27
vcoubard 1049:efb29faf12fc 28 /* Forward declarations for classes that will only be used for pointers or references in the following. */
rgrover1 711:b2e1a2660ec2 29 class GapAdvertisingParams;
rgrover1 711:b2e1a2660ec2 30 class GapScanningParams;
rgrover1 711:b2e1a2660ec2 31 class GapAdvertisingData;
rgrover1 711:b2e1a2660ec2 32
rgrover1 711:b2e1a2660ec2 33 class Gap {
vcoubard 1079:79c089630b38 34 /*
vcoubard 1079:79c089630b38 35 * DEPRECATION ALERT: all of the APIs in this `public` block are deprecated.
vcoubard 1079:79c089630b38 36 * They have been relocated to the class BLEProtocol.
vcoubard 1079:79c089630b38 37 */
rgrover1 711:b2e1a2660ec2 38 public:
vcoubard 1079:79c089630b38 39 /**
vcoubard 1079:79c089630b38 40 * Address-type for BLEProtocol addresses.
vcoubard 1092:58b2dac13261 41 *
vcoubard 1087:75d4e8ce277d 42 * @note: deprecated. Use BLEProtocol::AddressType_t instead.
vcoubard 1079:79c089630b38 43 */
vcoubard 1087:75d4e8ce277d 44 typedef BLEProtocol::AddressType_t AddressType_t;
vcoubard 1087:75d4e8ce277d 45
vcoubard 1087:75d4e8ce277d 46 /**
vcoubard 1087:75d4e8ce277d 47 * Address-type for BLEProtocol addresses.
vcoubard 1087:75d4e8ce277d 48 * @note: deprecated. Use BLEProtocol::AddressType_t instead.
vcoubard 1088:4c6e11878033 49 */
vcoubard 1088:4c6e11878033 50 typedef BLEProtocol::AddressType_t addr_type_t;
vcoubard 1088:4c6e11878033 51
vcoubard 1092:58b2dac13261 52 /**
vcoubard 1092:58b2dac13261 53 * Address-type for BLEProtocol addresses.
vcoubard 1092:58b2dac13261 54 * @note: deprecated. Use BLEProtocol::AddressType_t instead.
vcoubard 1092:58b2dac13261 55 *
vcoubard 1092:58b2dac13261 56 * DEPRECATION ALERT: The following constants have been left in their
vcoubard 1092:58b2dac13261 57 * deprecated state to transparenly support existing applications which may
vcoubard 1092:58b2dac13261 58 * have used Gap::ADDR_TYPE_*.
vcoubard 1092:58b2dac13261 59 */
vcoubard 1092:58b2dac13261 60 enum {
vcoubard 1092:58b2dac13261 61 ADDR_TYPE_PUBLIC = BLEProtocol::AddressType::PUBLIC,
vcoubard 1092:58b2dac13261 62 ADDR_TYPE_RANDOM_STATIC = BLEProtocol::AddressType::RANDOM_STATIC,
vcoubard 1092:58b2dac13261 63 ADDR_TYPE_RANDOM_PRIVATE_RESOLVABLE = BLEProtocol::AddressType::RANDOM_PRIVATE_RESOLVABLE,
vcoubard 1092:58b2dac13261 64 ADDR_TYPE_RANDOM_PRIVATE_NON_RESOLVABLE = BLEProtocol::AddressType::RANDOM_PRIVATE_NON_RESOLVABLE
vcoubard 1092:58b2dac13261 65 };
vcoubard 1092:58b2dac13261 66
vcoubard 1079:79c089630b38 67 static const unsigned ADDR_LEN = BLEProtocol::ADDR_LEN; /**< Length (in octets) of the BLE MAC address. */
vcoubard 1079:79c089630b38 68 typedef BLEProtocol::Address_t Address_t; /**< 48-bit address, LSB format. @Note: Deprecated. Use BLEProtocol::Address_t instead. */
vcoubard 1079:79c089630b38 69 typedef BLEProtocol::Address_t address_t; /**< 48-bit address, LSB format. @Note: Deprecated. Use BLEProtocol::Address_t instead. */
vcoubard 1079:79c089630b38 70
vcoubard 1079:79c089630b38 71 public:
rgrover1 711:b2e1a2660ec2 72 enum TimeoutSource_t {
rgrover1 711:b2e1a2660ec2 73 TIMEOUT_SRC_ADVERTISING = 0x00, /**< Advertising timeout. */
rgrover1 711:b2e1a2660ec2 74 TIMEOUT_SRC_SECURITY_REQUEST = 0x01, /**< Security request timeout. */
rgrover1 711:b2e1a2660ec2 75 TIMEOUT_SRC_SCAN = 0x02, /**< Scanning timeout. */
rgrover1 711:b2e1a2660ec2 76 TIMEOUT_SRC_CONN = 0x03, /**< Connection timeout. */
rgrover1 711:b2e1a2660ec2 77 };
rgrover1 711:b2e1a2660ec2 78
rgrover1 711:b2e1a2660ec2 79 /**
rgrover1 711:b2e1a2660ec2 80 * Enumeration for disconnection reasons. The values for these reasons are
vcoubard 1049:efb29faf12fc 81 * derived from Nordic's implementation, but the reasons are meant to be
vcoubard 1049:efb29faf12fc 82 * independent of the transport. If you are returned a reason that is not
vcoubard 1049:efb29faf12fc 83 * covered by this enumeration, please refer to the underlying
rgrover1 711:b2e1a2660ec2 84 * transport library.
rgrover1 711:b2e1a2660ec2 85 */
rgrover1 711:b2e1a2660ec2 86 enum DisconnectionReason_t {
rgrover1 711:b2e1a2660ec2 87 CONNECTION_TIMEOUT = 0x08,
rgrover1 711:b2e1a2660ec2 88 REMOTE_USER_TERMINATED_CONNECTION = 0x13,
vcoubard 1049:efb29faf12fc 89 REMOTE_DEV_TERMINATION_DUE_TO_LOW_RESOURCES = 0x14, /**< Remote device terminated connection due to low resources.*/
vcoubard 1049:efb29faf12fc 90 REMOTE_DEV_TERMINATION_DUE_TO_POWER_OFF = 0x15, /**< Remote device terminated connection due to power off. */
rgrover1 711:b2e1a2660ec2 91 LOCAL_HOST_TERMINATED_CONNECTION = 0x16,
rgrover1 711:b2e1a2660ec2 92 CONN_INTERVAL_UNACCEPTABLE = 0x3B,
rgrover1 711:b2e1a2660ec2 93 };
rgrover1 711:b2e1a2660ec2 94
vcoubard 1049:efb29faf12fc 95 /* Describes the current state of the device (more than one bit can be set). */
rgrover1 711:b2e1a2660ec2 96 struct GapState_t {
vcoubard 1049:efb29faf12fc 97 unsigned advertising : 1; /**< Peripheral is currently advertising. */
vcoubard 1049:efb29faf12fc 98 unsigned connected : 1; /**< Peripheral is connected to a central. */
rgrover1 711:b2e1a2660ec2 99 };
rgrover1 711:b2e1a2660ec2 100
rgrover1 711:b2e1a2660ec2 101 typedef uint16_t Handle_t; /* Type for connection handle. */
rgrover1 711:b2e1a2660ec2 102
rgrover1 711:b2e1a2660ec2 103 typedef struct {
rgrover1 711:b2e1a2660ec2 104 uint16_t minConnectionInterval; /**< Minimum Connection Interval in 1.25 ms units, see @ref BLE_GAP_CP_LIMITS.*/
rgrover1 711:b2e1a2660ec2 105 uint16_t maxConnectionInterval; /**< Maximum Connection Interval in 1.25 ms units, see @ref BLE_GAP_CP_LIMITS.*/
rgrover1 711:b2e1a2660ec2 106 uint16_t slaveLatency; /**< Slave Latency in number of connection events, see @ref BLE_GAP_CP_LIMITS.*/
rgrover1 711:b2e1a2660ec2 107 uint16_t connectionSupervisionTimeout; /**< Connection Supervision Timeout in 10 ms units, see @ref BLE_GAP_CP_LIMITS.*/
rgrover1 711:b2e1a2660ec2 108 } ConnectionParams_t;
rgrover1 711:b2e1a2660ec2 109
rgrover1 711:b2e1a2660ec2 110 enum Role_t {
rgrover1 711:b2e1a2660ec2 111 PERIPHERAL = 0x1, /**< Peripheral Role. */
rgrover1 711:b2e1a2660ec2 112 CENTRAL = 0x2, /**< Central Role. */
rgrover1 711:b2e1a2660ec2 113 };
rgrover1 711:b2e1a2660ec2 114
rgrover1 711:b2e1a2660ec2 115 struct AdvertisementCallbackParams_t {
vcoubard 1080:6e2d9514f3df 116 BLEProtocol::Address_t peerAddr;
vcoubard 1080:6e2d9514f3df 117 int8_t rssi;
vcoubard 1080:6e2d9514f3df 118 bool isScanResponse;
vcoubard 1080:6e2d9514f3df 119 GapAdvertisingParams::AdvertisingType_t type;
vcoubard 1080:6e2d9514f3df 120 uint8_t advertisingDataLen;
vcoubard 1080:6e2d9514f3df 121 const uint8_t *advertisingData;
rgrover1 711:b2e1a2660ec2 122 };
rgrover1 711:b2e1a2660ec2 123 typedef FunctionPointerWithContext<const AdvertisementCallbackParams_t *> AdvertisementReportCallback_t;
rgrover1 711:b2e1a2660ec2 124
rgrover1 711:b2e1a2660ec2 125 struct ConnectionCallbackParams_t {
vcoubard 1079:79c089630b38 126 Handle_t handle;
vcoubard 1079:79c089630b38 127 Role_t role;
vcoubard 1079:79c089630b38 128 BLEProtocol::AddressType_t peerAddrType;
vcoubard 1080:6e2d9514f3df 129 BLEProtocol::Address_t peerAddr;
vcoubard 1079:79c089630b38 130 BLEProtocol::AddressType_t ownAddrType;
vcoubard 1080:6e2d9514f3df 131 BLEProtocol::Address_t ownAddr;
vcoubard 1079:79c089630b38 132 const ConnectionParams_t *connectionParams;
rgrover1 711:b2e1a2660ec2 133
vcoubard 1079:79c089630b38 134 ConnectionCallbackParams_t(Handle_t handleIn,
vcoubard 1079:79c089630b38 135 Role_t roleIn,
vcoubard 1079:79c089630b38 136 BLEProtocol::AddressType_t peerAddrTypeIn,
vcoubard 1079:79c089630b38 137 const uint8_t *peerAddrIn,
vcoubard 1079:79c089630b38 138 BLEProtocol::AddressType_t ownAddrTypeIn,
vcoubard 1079:79c089630b38 139 const uint8_t *ownAddrIn,
vcoubard 1079:79c089630b38 140 const ConnectionParams_t *connectionParamsIn) :
rgrover1 711:b2e1a2660ec2 141 handle(handleIn),
rgrover1 711:b2e1a2660ec2 142 role(roleIn),
rgrover1 711:b2e1a2660ec2 143 peerAddrType(peerAddrTypeIn),
rgrover1 711:b2e1a2660ec2 144 peerAddr(),
rgrover1 711:b2e1a2660ec2 145 ownAddrType(ownAddrTypeIn),
rgrover1 711:b2e1a2660ec2 146 ownAddr(),
rgrover1 711:b2e1a2660ec2 147 connectionParams(connectionParamsIn) {
rgrover1 711:b2e1a2660ec2 148 memcpy(peerAddr, peerAddrIn, ADDR_LEN);
rgrover1 711:b2e1a2660ec2 149 memcpy(ownAddr, ownAddrIn, ADDR_LEN);
rgrover1 711:b2e1a2660ec2 150 }
rgrover1 711:b2e1a2660ec2 151 };
rgrover1 711:b2e1a2660ec2 152
rgrover1 830:9072de50087b 153 struct DisconnectionCallbackParams_t {
rgrover1 830:9072de50087b 154 Handle_t handle;
rgrover1 830:9072de50087b 155 DisconnectionReason_t reason;
rgrover1 830:9072de50087b 156
rgrover1 830:9072de50087b 157 DisconnectionCallbackParams_t(Handle_t handleIn,
rgrover1 830:9072de50087b 158 DisconnectionReason_t reasonIn) :
rgrover1 830:9072de50087b 159 handle(handleIn),
rgrover1 830:9072de50087b 160 reason(reasonIn)
rgrover1 830:9072de50087b 161 {}
rgrover1 830:9072de50087b 162 };
rgrover1 830:9072de50087b 163
rgrover1 711:b2e1a2660ec2 164 static const uint16_t UNIT_1_25_MS = 1250; /**< Number of microseconds in 1.25 milliseconds. */
rgrover1 711:b2e1a2660ec2 165 static uint16_t MSEC_TO_GAP_DURATION_UNITS(uint32_t durationInMillis) {
rgrover1 711:b2e1a2660ec2 166 return (durationInMillis * 1000) / UNIT_1_25_MS;
rgrover1 711:b2e1a2660ec2 167 }
rgrover1 767:03f1a26f132f 168
vcoubard 1053:b55e1ad3e1b3 169 typedef FunctionPointerWithContext<TimeoutSource_t> TimeoutEventCallback_t;
vcoubard 1053:b55e1ad3e1b3 170 typedef CallChainOfFunctionPointersWithContext<TimeoutSource_t> TimeoutEventCallbackChain_t;
rgrover1 711:b2e1a2660ec2 171
vcoubard 1053:b55e1ad3e1b3 172 typedef FunctionPointerWithContext<const ConnectionCallbackParams_t *> ConnectionEventCallback_t;
vcoubard 1053:b55e1ad3e1b3 173 typedef CallChainOfFunctionPointersWithContext<const ConnectionCallbackParams_t *> ConnectionEventCallbackChain_t;
vcoubard 1053:b55e1ad3e1b3 174
vcoubard 1053:b55e1ad3e1b3 175 typedef FunctionPointerWithContext<const DisconnectionCallbackParams_t*> DisconnectionEventCallback_t;
vcoubard 1055:f59e5d9a992a 176 typedef CallChainOfFunctionPointersWithContext<const DisconnectionCallbackParams_t*> DisconnectionEventCallbackChain_t;
vcoubard 1053:b55e1ad3e1b3 177
rgrover1 754:0f60274cd3ad 178 typedef FunctionPointerWithContext<bool> RadioNotificationEventCallback_t;
rgrover1 711:b2e1a2660ec2 179
vcoubard 1091:148d8b9b56a5 180 typedef FunctionPointerWithContext<const Gap *> GapShutdownCallback_t;
vcoubard 1091:148d8b9b56a5 181 typedef CallChainOfFunctionPointersWithContext<const Gap *> GapShutdownCallbackChain_t;
vcoubard 1091:148d8b9b56a5 182
rgrover1 711:b2e1a2660ec2 183 /*
rgrover1 711:b2e1a2660ec2 184 * The following functions are meant to be overridden in the platform-specific sub-class.
rgrover1 711:b2e1a2660ec2 185 */
rgrover1 711:b2e1a2660ec2 186 public:
rgrover1 711:b2e1a2660ec2 187 /**
rgrover1 711:b2e1a2660ec2 188 * Set the BTLE MAC address and type. Please note that the address format is
vcoubard 1080:6e2d9514f3df 189 * least significant byte first (LSB). Please refer to BLEProtocol::Address_t.
rgrover1 711:b2e1a2660ec2 190 *
rgrover1 711:b2e1a2660ec2 191 * @return BLE_ERROR_NONE on success.
rgrover1 711:b2e1a2660ec2 192 */
vcoubard 1080:6e2d9514f3df 193 virtual ble_error_t setAddress(BLEProtocol::AddressType_t type, const BLEProtocol::Address_t address) {
rgrover1 735:4872b70437ce 194 /* avoid compiler warnings about unused variables */
rgrover1 735:4872b70437ce 195 (void)type;
rgrover1 735:4872b70437ce 196 (void)address;
rgrover1 735:4872b70437ce 197
rgrover1 729:997ba5e7b3b6 198 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 199 }
rgrover1 711:b2e1a2660ec2 200
rgrover1 711:b2e1a2660ec2 201 /**
rgrover1 711:b2e1a2660ec2 202 * Fetch the BTLE MAC address and type.
rgrover1 711:b2e1a2660ec2 203 *
rgrover1 711:b2e1a2660ec2 204 * @return BLE_ERROR_NONE on success.
rgrover1 711:b2e1a2660ec2 205 */
vcoubard 1080:6e2d9514f3df 206 virtual ble_error_t getAddress(BLEProtocol::AddressType_t *typeP, BLEProtocol::Address_t address) {
vcoubard 1049:efb29faf12fc 207 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 208 (void)typeP;
rgrover1 735:4872b70437ce 209 (void)address;
rgrover1 735:4872b70437ce 210
rgrover1 729:997ba5e7b3b6 211 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 212 }
rgrover1 711:b2e1a2660ec2 213
rgrover1 711:b2e1a2660ec2 214 /**
vcoubard 1057:ce2fb3d09929 215 * @return Minimum Advertising interval in milliseconds for connectable
vcoubard 1057:ce2fb3d09929 216 * undirected and connectable directed event types.
rgrover1 711:b2e1a2660ec2 217 */
rgrover1 711:b2e1a2660ec2 218 virtual uint16_t getMinAdvertisingInterval(void) const {
rgrover1 743:861ed7eb186d 219 return 0; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 220 }
rgrover1 711:b2e1a2660ec2 221
rgrover1 711:b2e1a2660ec2 222 /**
vcoubard 1057:ce2fb3d09929 223 * @return Minimum Advertising interval in milliseconds for scannable
vcoubard 1057:ce2fb3d09929 224 * undirected and non-connectable undirected event types.
rgrover1 711:b2e1a2660ec2 225 */
rgrover1 711:b2e1a2660ec2 226 virtual uint16_t getMinNonConnectableAdvertisingInterval(void) const {
rgrover1 743:861ed7eb186d 227 return 0; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 228 }
rgrover1 711:b2e1a2660ec2 229
rgrover1 711:b2e1a2660ec2 230 /**
rgrover1 711:b2e1a2660ec2 231 * @return Maximum Advertising interval in milliseconds.
rgrover1 711:b2e1a2660ec2 232 */
rgrover1 711:b2e1a2660ec2 233 virtual uint16_t getMaxAdvertisingInterval(void) const {
rgrover1 743:861ed7eb186d 234 return 0xFFFF; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 235 }
rgrover1 711:b2e1a2660ec2 236
rgrover1 711:b2e1a2660ec2 237 virtual ble_error_t stopAdvertising(void) {
rgrover1 729:997ba5e7b3b6 238 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 239 }
rgrover1 711:b2e1a2660ec2 240
rgrover1 711:b2e1a2660ec2 241 /**
rgrover1 711:b2e1a2660ec2 242 * Stop scanning. The current scanning parameters remain in effect.
rgrover1 711:b2e1a2660ec2 243 *
rgrover1 711:b2e1a2660ec2 244 * @retval BLE_ERROR_NONE if successfully stopped scanning procedure.
rgrover1 711:b2e1a2660ec2 245 */
rgrover1 711:b2e1a2660ec2 246 virtual ble_error_t stopScan() {
rgrover1 729:997ba5e7b3b6 247 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 248 }
rgrover1 711:b2e1a2660ec2 249
rgrover1 711:b2e1a2660ec2 250 /**
rgrover1 711:b2e1a2660ec2 251 * Create a connection (GAP Link Establishment).
rgrover1 711:b2e1a2660ec2 252 *
rgrover1 711:b2e1a2660ec2 253 * @param peerAddr
rgrover1 711:b2e1a2660ec2 254 * 48-bit address, LSB format.
rgrover1 711:b2e1a2660ec2 255 * @param peerAddrType
rgrover1 711:b2e1a2660ec2 256 * Address type of the peer.
rgrover1 711:b2e1a2660ec2 257 * @param connectionParams
rgrover1 711:b2e1a2660ec2 258 * Connection parameters.
rgrover1 711:b2e1a2660ec2 259 * @param scanParams
rgrover1 711:b2e1a2660ec2 260 * Paramters to be used while scanning for the peer.
rgrover1 711:b2e1a2660ec2 261 * @return BLE_ERROR_NONE if connection establishment procedure is started
rgrover1 830:9072de50087b 262 * successfully. The connectionCallChain (if set) will be invoked upon
rgrover1 711:b2e1a2660ec2 263 * a connection event.
rgrover1 711:b2e1a2660ec2 264 */
vcoubard 1080:6e2d9514f3df 265 virtual ble_error_t connect(const BLEProtocol::Address_t peerAddr,
vcoubard 1080:6e2d9514f3df 266 BLEProtocol::AddressType_t peerAddrType,
vcoubard 1080:6e2d9514f3df 267 const ConnectionParams_t *connectionParams,
vcoubard 1080:6e2d9514f3df 268 const GapScanningParams *scanParams) {
vcoubard 1049:efb29faf12fc 269 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 270 (void)peerAddr;
rgrover1 735:4872b70437ce 271 (void)peerAddrType;
rgrover1 735:4872b70437ce 272 (void)connectionParams;
rgrover1 735:4872b70437ce 273 (void)scanParams;
rgrover1 735:4872b70437ce 274
rgrover1 729:997ba5e7b3b6 275 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 276 }
rgrover1 711:b2e1a2660ec2 277
rgrover1 711:b2e1a2660ec2 278 /**
rgrover1 711:b2e1a2660ec2 279 * This call initiates the disconnection procedure, and its completion will
rgrover1 711:b2e1a2660ec2 280 * be communicated to the application with an invocation of the
rgrover1 711:b2e1a2660ec2 281 * disconnectionCallback.
rgrover1 711:b2e1a2660ec2 282 *
rgrover1 711:b2e1a2660ec2 283 * @param reason
vcoubard 1049:efb29faf12fc 284 * The reason for disconnection; to be sent back to the peer.
rgrover1 711:b2e1a2660ec2 285 */
rgrover1 711:b2e1a2660ec2 286 virtual ble_error_t disconnect(Handle_t connectionHandle, DisconnectionReason_t reason) {
rgrover1 735:4872b70437ce 287 /* avoid compiler warnings about unused variables */
rgrover1 735:4872b70437ce 288 (void)connectionHandle;
rgrover1 735:4872b70437ce 289 (void)reason;
rgrover1 735:4872b70437ce 290
rgrover1 729:997ba5e7b3b6 291 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 292 }
rgrover1 711:b2e1a2660ec2 293
rgrover1 711:b2e1a2660ec2 294 /**
rgrover1 711:b2e1a2660ec2 295 * This call initiates the disconnection procedure, and its completion will
rgrover1 711:b2e1a2660ec2 296 * be communicated to the application with an invocation of the
rgrover1 711:b2e1a2660ec2 297 * disconnectionCallback.
rgrover1 711:b2e1a2660ec2 298 *
rgrover1 711:b2e1a2660ec2 299 * @param reason
vcoubard 1049:efb29faf12fc 300 * The reason for disconnection; to be sent back to the peer.
rgrover1 711:b2e1a2660ec2 301 *
vcoubard 1049:efb29faf12fc 302 * @note: This version of disconnect() doesn't take a connection handle. It
vcoubard 1049:efb29faf12fc 303 * works reliably only for stacks that are limited to a single
rgrover1 711:b2e1a2660ec2 304 * connection. This API should be considered *deprecated* in favour of the
vcoubard 1049:efb29faf12fc 305 * alternative, which takes a connection handle. It will be dropped in the future.
rgrover1 711:b2e1a2660ec2 306 */
rgrover1 711:b2e1a2660ec2 307 virtual ble_error_t disconnect(DisconnectionReason_t reason) {
vcoubard 1049:efb29faf12fc 308 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 309 (void)reason;
rgrover1 735:4872b70437ce 310
rgrover1 729:997ba5e7b3b6 311 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 312 }
rgrover1 711:b2e1a2660ec2 313
rgrover1 711:b2e1a2660ec2 314 /**
rgrover1 711:b2e1a2660ec2 315 * Get the GAP peripheral preferred connection parameters. These are the
rgrover1 711:b2e1a2660ec2 316 * defaults that the peripheral would like to have in a connection. The
rgrover1 711:b2e1a2660ec2 317 * choice of the connection parameters is eventually up to the central.
rgrover1 711:b2e1a2660ec2 318 *
rgrover1 711:b2e1a2660ec2 319 * @param[out] params
rgrover1 711:b2e1a2660ec2 320 * The structure where the parameters will be stored. Memory
rgrover1 711:b2e1a2660ec2 321 * for this is owned by the caller.
rgrover1 711:b2e1a2660ec2 322 *
rgrover1 711:b2e1a2660ec2 323 * @return BLE_ERROR_NONE if the parameters were successfully filled into
rgrover1 711:b2e1a2660ec2 324 * the given structure pointed to by params.
rgrover1 711:b2e1a2660ec2 325 */
rgrover1 711:b2e1a2660ec2 326 virtual ble_error_t getPreferredConnectionParams(ConnectionParams_t *params) {
vcoubard 1049:efb29faf12fc 327 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 328 (void)params;
rgrover1 735:4872b70437ce 329
rgrover1 729:997ba5e7b3b6 330 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 331 }
rgrover1 711:b2e1a2660ec2 332
rgrover1 711:b2e1a2660ec2 333 /**
rgrover1 711:b2e1a2660ec2 334 * Set the GAP peripheral preferred connection parameters. These are the
rgrover1 711:b2e1a2660ec2 335 * defaults that the peripheral would like to have in a connection. The
rgrover1 711:b2e1a2660ec2 336 * choice of the connection parameters is eventually up to the central.
rgrover1 711:b2e1a2660ec2 337 *
rgrover1 711:b2e1a2660ec2 338 * @param[in] params
rgrover1 711:b2e1a2660ec2 339 * The structure containing the desired parameters.
rgrover1 711:b2e1a2660ec2 340 */
rgrover1 711:b2e1a2660ec2 341 virtual ble_error_t setPreferredConnectionParams(const ConnectionParams_t *params) {
vcoubard 1049:efb29faf12fc 342 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 343 (void)params;
rgrover1 735:4872b70437ce 344
rgrover1 729:997ba5e7b3b6 345 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 346 }
rgrover1 711:b2e1a2660ec2 347
rgrover1 711:b2e1a2660ec2 348 /**
rgrover1 817:2b4f0ef8c06e 349 * Update connection parameters.
vcoubard 1049:efb29faf12fc 350 * In the central role this will initiate a Link Layer connection parameter update procedure.
vcoubard 1049:efb29faf12fc 351 * In the peripheral role, this will send the corresponding L2CAP request and wait for
rgrover1 817:2b4f0ef8c06e 352 * the central to perform the procedure.
rgrover1 817:2b4f0ef8c06e 353 *
rgrover1 711:b2e1a2660ec2 354 * @param[in] handle
vcoubard 1049:efb29faf12fc 355 * Connection Handle.
rgrover1 711:b2e1a2660ec2 356 * @param[in] params
rgrover1 711:b2e1a2660ec2 357 * Pointer to desired connection parameters. If NULL is provided on a peripheral role,
rgrover1 711:b2e1a2660ec2 358 * the parameters in the PPCP characteristic of the GAP service will be used instead.
rgrover1 711:b2e1a2660ec2 359 */
rgrover1 711:b2e1a2660ec2 360 virtual ble_error_t updateConnectionParams(Handle_t handle, const ConnectionParams_t *params) {
rgrover1 735:4872b70437ce 361 /* avoid compiler warnings about unused variables */
rgrover1 735:4872b70437ce 362 (void)handle;
rgrover1 735:4872b70437ce 363 (void)params;
rgrover1 735:4872b70437ce 364
rgrover1 729:997ba5e7b3b6 365 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 366 }
rgrover1 711:b2e1a2660ec2 367
rgrover1 711:b2e1a2660ec2 368 /**
rgrover1 711:b2e1a2660ec2 369 * Set the device name characteristic in the GAP service.
rgrover1 711:b2e1a2660ec2 370 * @param[in] deviceName
rgrover1 711:b2e1a2660ec2 371 * The new value for the device-name. This is a UTF-8 encoded, <b>NULL-terminated</b> string.
rgrover1 711:b2e1a2660ec2 372 */
rgrover1 711:b2e1a2660ec2 373 virtual ble_error_t setDeviceName(const uint8_t *deviceName) {
vcoubard 1049:efb29faf12fc 374 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 375 (void)deviceName;
rgrover1 735:4872b70437ce 376
rgrover1 729:997ba5e7b3b6 377 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 378 }
rgrover1 711:b2e1a2660ec2 379
rgrover1 711:b2e1a2660ec2 380 /**
rgrover1 711:b2e1a2660ec2 381 * Get the value of the device name characteristic in the GAP service.
rgrover1 711:b2e1a2660ec2 382 * @param[out] deviceName
rgrover1 711:b2e1a2660ec2 383 * Pointer to an empty buffer where the UTF-8 *non NULL-
rgrover1 711:b2e1a2660ec2 384 * terminated* string will be placed. Set this
rgrover1 711:b2e1a2660ec2 385 * value to NULL in order to obtain the deviceName-length
rgrover1 711:b2e1a2660ec2 386 * from the 'length' parameter.
rgrover1 711:b2e1a2660ec2 387 *
rgrover1 711:b2e1a2660ec2 388 * @param[in/out] lengthP
rgrover1 711:b2e1a2660ec2 389 * (on input) Length of the buffer pointed to by deviceName;
rgrover1 711:b2e1a2660ec2 390 * (on output) the complete device name length (without the
rgrover1 711:b2e1a2660ec2 391 * null terminator).
rgrover1 711:b2e1a2660ec2 392 *
rgrover1 711:b2e1a2660ec2 393 * @note If the device name is longer than the size of the supplied buffer,
rgrover1 711:b2e1a2660ec2 394 * length will return the complete device name length, and not the
rgrover1 711:b2e1a2660ec2 395 * number of bytes actually returned in deviceName. The application may
rgrover1 711:b2e1a2660ec2 396 * use this information to retry with a suitable buffer size.
rgrover1 711:b2e1a2660ec2 397 */
rgrover1 711:b2e1a2660ec2 398 virtual ble_error_t getDeviceName(uint8_t *deviceName, unsigned *lengthP) {
rgrover1 735:4872b70437ce 399 /* avoid compiler warnings about unused variables */
rgrover1 735:4872b70437ce 400 (void)deviceName;
rgrover1 735:4872b70437ce 401 (void)lengthP;
rgrover1 735:4872b70437ce 402
rgrover1 729:997ba5e7b3b6 403 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 404 }
rgrover1 711:b2e1a2660ec2 405
rgrover1 711:b2e1a2660ec2 406 /**
rgrover1 711:b2e1a2660ec2 407 * Set the appearance characteristic in the GAP service.
rgrover1 711:b2e1a2660ec2 408 * @param[in] appearance
rgrover1 711:b2e1a2660ec2 409 * The new value for the device-appearance.
rgrover1 711:b2e1a2660ec2 410 */
rgrover1 711:b2e1a2660ec2 411 virtual ble_error_t setAppearance(GapAdvertisingData::Appearance appearance) {
vcoubard 1049:efb29faf12fc 412 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 413 (void)appearance;
rgrover1 735:4872b70437ce 414
rgrover1 729:997ba5e7b3b6 415 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 416 }
rgrover1 711:b2e1a2660ec2 417
rgrover1 711:b2e1a2660ec2 418 /**
rgrover1 711:b2e1a2660ec2 419 * Get the appearance characteristic in the GAP service.
rgrover1 711:b2e1a2660ec2 420 * @param[out] appearance
rgrover1 711:b2e1a2660ec2 421 * The new value for the device-appearance.
rgrover1 711:b2e1a2660ec2 422 */
rgrover1 711:b2e1a2660ec2 423 virtual ble_error_t getAppearance(GapAdvertisingData::Appearance *appearanceP) {
vcoubard 1049:efb29faf12fc 424 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 425 (void)appearanceP;
rgrover1 735:4872b70437ce 426
rgrover1 729:997ba5e7b3b6 427 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 428 }
rgrover1 711:b2e1a2660ec2 429
rgrover1 711:b2e1a2660ec2 430 /**
rgrover1 711:b2e1a2660ec2 431 * Set the radio's transmit power.
rgrover1 711:b2e1a2660ec2 432 * @param[in] txPower Radio transmit power in dBm.
rgrover1 711:b2e1a2660ec2 433 */
rgrover1 711:b2e1a2660ec2 434 virtual ble_error_t setTxPower(int8_t txPower) {
vcoubard 1049:efb29faf12fc 435 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 436 (void)txPower;
rgrover1 735:4872b70437ce 437
rgrover1 729:997ba5e7b3b6 438 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 439 }
rgrover1 711:b2e1a2660ec2 440
rgrover1 711:b2e1a2660ec2 441 /**
rgrover1 711:b2e1a2660ec2 442 * Query the underlying stack for permitted arguments for setTxPower().
rgrover1 711:b2e1a2660ec2 443 *
rgrover1 711:b2e1a2660ec2 444 * @param[out] valueArrayPP
rgrover1 711:b2e1a2660ec2 445 * Out parameter to receive the immutable array of Tx values.
rgrover1 711:b2e1a2660ec2 446 * @param[out] countP
rgrover1 711:b2e1a2660ec2 447 * Out parameter to receive the array's size.
rgrover1 711:b2e1a2660ec2 448 */
rgrover1 711:b2e1a2660ec2 449 virtual void getPermittedTxPowerValues(const int8_t **valueArrayPP, size_t *countP) {
vcoubard 1049:efb29faf12fc 450 /* Avoid compiler warnings about unused variables. */
rgrover1 735:4872b70437ce 451 (void)valueArrayPP;
rgrover1 735:4872b70437ce 452 (void)countP;
rgrover1 735:4872b70437ce 453
rgrover1 743:861ed7eb186d 454 *countP = 0; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 455 }
rgrover1 711:b2e1a2660ec2 456
rgrover1 711:b2e1a2660ec2 457 protected:
rgrover1 711:b2e1a2660ec2 458 /* Override the following in the underlying adaptation layer to provide the functionality of scanning. */
rgrover1 711:b2e1a2660ec2 459 virtual ble_error_t startRadioScan(const GapScanningParams &scanningParams) {
rgrover1 773:b6d27ab66c94 460 (void)scanningParams;
rgrover1 729:997ba5e7b3b6 461 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 711:b2e1a2660ec2 462 }
rgrover1 711:b2e1a2660ec2 463
rgrover1 711:b2e1a2660ec2 464 /*
rgrover1 711:b2e1a2660ec2 465 * APIs with non-virtual implementations.
rgrover1 711:b2e1a2660ec2 466 */
rgrover1 711:b2e1a2660ec2 467 public:
rgrover1 711:b2e1a2660ec2 468 /**
vcoubard 1049:efb29faf12fc 469 * Returns the current GAP state of the device using a bitmask that
vcoubard 1049:efb29faf12fc 470 * describes whether the device is advertising or connected.
rgrover1 711:b2e1a2660ec2 471 */
rgrover1 711:b2e1a2660ec2 472 GapState_t getState(void) const {
rgrover1 711:b2e1a2660ec2 473 return state;
rgrover1 711:b2e1a2660ec2 474 }
rgrover1 711:b2e1a2660ec2 475
rgrover1 711:b2e1a2660ec2 476 /**
rgrover1 711:b2e1a2660ec2 477 * Set the GAP advertising mode to use for this device.
rgrover1 711:b2e1a2660ec2 478 */
rgrover1 711:b2e1a2660ec2 479 void setAdvertisingType(GapAdvertisingParams::AdvertisingType_t advType) {
rgrover1 711:b2e1a2660ec2 480 _advParams.setAdvertisingType(advType);
rgrover1 711:b2e1a2660ec2 481 }
rgrover1 711:b2e1a2660ec2 482
rgrover1 711:b2e1a2660ec2 483 /**
rgrover1 711:b2e1a2660ec2 484 * @param[in] interval
rgrover1 711:b2e1a2660ec2 485 * Advertising interval in units of milliseconds. Advertising
rgrover1 711:b2e1a2660ec2 486 * is disabled if interval is 0. If interval is smaller than
rgrover1 711:b2e1a2660ec2 487 * the minimum supported value, then the minimum supported
rgrover1 711:b2e1a2660ec2 488 * value is used instead. This minimum value can be discovered
rgrover1 711:b2e1a2660ec2 489 * using getMinAdvertisingInterval().
rgrover1 711:b2e1a2660ec2 490 *
rgrover1 711:b2e1a2660ec2 491 * This field must be set to 0 if connectionMode is equal
rgrover1 711:b2e1a2660ec2 492 * to ADV_CONNECTABLE_DIRECTED.
rgrover1 711:b2e1a2660ec2 493 *
rgrover1 711:b2e1a2660ec2 494 * @note: Decreasing this value will allow central devices to detect a
vcoubard 1049:efb29faf12fc 495 * peripheral faster, at the expense of more power being used by the radio
rgrover1 711:b2e1a2660ec2 496 * due to the higher data transmit rate.
rgrover1 711:b2e1a2660ec2 497 *
rgrover1 711:b2e1a2660ec2 498 * @Note: [WARNING] This API previously used 0.625ms as the unit for its
rgrover1 711:b2e1a2660ec2 499 * 'interval' argument. That required an explicit conversion from
rgrover1 711:b2e1a2660ec2 500 * milliseconds using Gap::MSEC_TO_GAP_DURATION_UNITS(). This conversion is
rgrover1 711:b2e1a2660ec2 501 * no longer required as the new units are milliseconds. Any application
vcoubard 1049:efb29faf12fc 502 * code depending on the old semantics needs to be updated accordingly.
rgrover1 711:b2e1a2660ec2 503 */
rgrover1 711:b2e1a2660ec2 504 void setAdvertisingInterval(uint16_t interval) {
rgrover1 711:b2e1a2660ec2 505 if (interval == 0) {
rgrover1 711:b2e1a2660ec2 506 stopAdvertising();
rgrover1 711:b2e1a2660ec2 507 } else if (interval < getMinAdvertisingInterval()) {
rgrover1 711:b2e1a2660ec2 508 interval = getMinAdvertisingInterval();
rgrover1 711:b2e1a2660ec2 509 }
rgrover1 787:d6d7087d8377 510 _advParams.setInterval(interval);
rgrover1 711:b2e1a2660ec2 511 }
rgrover1 711:b2e1a2660ec2 512
rgrover1 711:b2e1a2660ec2 513 /**
rgrover1 711:b2e1a2660ec2 514 * @param[in] timeout
rgrover1 711:b2e1a2660ec2 515 * Advertising timeout (in seconds) between 0x1 and 0x3FFF (1
rgrover1 711:b2e1a2660ec2 516 * and 16383). Use 0 to disable the advertising timeout.
rgrover1 711:b2e1a2660ec2 517 */
rgrover1 711:b2e1a2660ec2 518 void setAdvertisingTimeout(uint16_t timeout) {
rgrover1 711:b2e1a2660ec2 519 _advParams.setTimeout(timeout);
rgrover1 711:b2e1a2660ec2 520 }
rgrover1 711:b2e1a2660ec2 521
rgrover1 711:b2e1a2660ec2 522 /**
rgrover1 711:b2e1a2660ec2 523 * Start advertising.
rgrover1 711:b2e1a2660ec2 524 */
rgrover1 711:b2e1a2660ec2 525 ble_error_t startAdvertising(void) {
vcoubard 1049:efb29faf12fc 526 setAdvertisingData(); /* Update the underlying stack. */
rgrover1 711:b2e1a2660ec2 527 return startAdvertising(_advParams);
rgrover1 711:b2e1a2660ec2 528 }
rgrover1 711:b2e1a2660ec2 529
rgrover1 711:b2e1a2660ec2 530 /**
rgrover1 711:b2e1a2660ec2 531 * Reset any advertising payload prepared from prior calls to
rgrover1 711:b2e1a2660ec2 532 * accumulateAdvertisingPayload(). This automatically propagates the re-
vcoubard 1049:efb29faf12fc 533 * initialized advertising payload to the underlying stack.
rgrover1 711:b2e1a2660ec2 534 */
rgrover1 711:b2e1a2660ec2 535 void clearAdvertisingPayload(void) {
rgrover1 711:b2e1a2660ec2 536 _advPayload.clear();
rgrover1 711:b2e1a2660ec2 537 setAdvertisingData();
rgrover1 711:b2e1a2660ec2 538 }
rgrover1 711:b2e1a2660ec2 539
rgrover1 711:b2e1a2660ec2 540 /**
rgrover1 711:b2e1a2660ec2 541 * Accumulate an AD structure in the advertising payload. Please note that
rgrover1 711:b2e1a2660ec2 542 * the payload is limited to 31 bytes. The SCAN_RESPONSE message may be used
vcoubard 1049:efb29faf12fc 543 * as an additional 31 bytes if the advertising payload is too
rgrover1 711:b2e1a2660ec2 544 * small.
rgrover1 711:b2e1a2660ec2 545 *
rgrover1 711:b2e1a2660ec2 546 * @param[in] flags
rgrover1 711:b2e1a2660ec2 547 * The flags to be added. Please refer to
rgrover1 711:b2e1a2660ec2 548 * GapAdvertisingData::Flags for valid flags. Multiple
rgrover1 711:b2e1a2660ec2 549 * flags may be specified in combination.
rgrover1 711:b2e1a2660ec2 550 */
rgrover1 711:b2e1a2660ec2 551 ble_error_t accumulateAdvertisingPayload(uint8_t flags) {
rgrover1 711:b2e1a2660ec2 552 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 553 if ((rc = _advPayload.addFlags(flags)) != BLE_ERROR_NONE) {
rgrover1 711:b2e1a2660ec2 554 return rc;
rgrover1 711:b2e1a2660ec2 555 }
rgrover1 711:b2e1a2660ec2 556
rgrover1 711:b2e1a2660ec2 557 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 558 }
rgrover1 711:b2e1a2660ec2 559
rgrover1 711:b2e1a2660ec2 560 /**
rgrover1 711:b2e1a2660ec2 561 * Accumulate an AD structure in the advertising payload. Please note that
rgrover1 711:b2e1a2660ec2 562 * the payload is limited to 31 bytes. The SCAN_RESPONSE message may be used
vcoubard 1049:efb29faf12fc 563 * as an additional 31 bytes if the advertising payload is too
rgrover1 711:b2e1a2660ec2 564 * small.
rgrover1 711:b2e1a2660ec2 565 *
rgrover1 711:b2e1a2660ec2 566 * @param app
rgrover1 711:b2e1a2660ec2 567 * The appearance of the peripheral.
rgrover1 711:b2e1a2660ec2 568 */
rgrover1 711:b2e1a2660ec2 569 ble_error_t accumulateAdvertisingPayload(GapAdvertisingData::Appearance app) {
rgrover1 711:b2e1a2660ec2 570 setAppearance(app);
rgrover1 711:b2e1a2660ec2 571
rgrover1 711:b2e1a2660ec2 572 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 573 if ((rc = _advPayload.addAppearance(app)) != BLE_ERROR_NONE) {
rgrover1 711:b2e1a2660ec2 574 return rc;
rgrover1 711:b2e1a2660ec2 575 }
rgrover1 711:b2e1a2660ec2 576
rgrover1 711:b2e1a2660ec2 577 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 578 }
rgrover1 711:b2e1a2660ec2 579
rgrover1 711:b2e1a2660ec2 580 /**
rgrover1 711:b2e1a2660ec2 581 * Accumulate an AD structure in the advertising payload. Please note that
rgrover1 711:b2e1a2660ec2 582 * the payload is limited to 31 bytes. The SCAN_RESPONSE message may be used
vcoubard 1049:efb29faf12fc 583 * as an additional 31 bytes if the advertising payload is too
rgrover1 711:b2e1a2660ec2 584 * small.
rgrover1 711:b2e1a2660ec2 585 *
vcoubard 1049:efb29faf12fc 586 * @param power
rgrover1 765:1e560f0d45e1 587 * The max transmit power to be used by the controller (in dBm).
rgrover1 711:b2e1a2660ec2 588 */
rgrover1 711:b2e1a2660ec2 589 ble_error_t accumulateAdvertisingPayloadTxPower(int8_t power) {
rgrover1 711:b2e1a2660ec2 590 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 591 if ((rc = _advPayload.addTxPower(power)) != BLE_ERROR_NONE) {
rgrover1 711:b2e1a2660ec2 592 return rc;
rgrover1 711:b2e1a2660ec2 593 }
rgrover1 711:b2e1a2660ec2 594
rgrover1 711:b2e1a2660ec2 595 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 596 }
rgrover1 711:b2e1a2660ec2 597
rgrover1 711:b2e1a2660ec2 598 /**
rgrover1 711:b2e1a2660ec2 599 * Accumulate a variable length byte-stream as an AD structure in the
rgrover1 711:b2e1a2660ec2 600 * advertising payload. Please note that the payload is limited to 31 bytes.
rgrover1 711:b2e1a2660ec2 601 * The SCAN_RESPONSE message may be used as an additional 31 bytes if the
vcoubard 1049:efb29faf12fc 602 * advertising payload is too small.
rgrover1 711:b2e1a2660ec2 603 *
vcoubard 1049:efb29faf12fc 604 * @param type The type describing the variable length data.
vcoubard 1049:efb29faf12fc 605 * @param data Data bytes.
vcoubard 1049:efb29faf12fc 606 * @param len Length of data.
rgrover1 711:b2e1a2660ec2 607 */
rgrover1 711:b2e1a2660ec2 608 ble_error_t accumulateAdvertisingPayload(GapAdvertisingData::DataType type, const uint8_t *data, uint8_t len) {
rgrover1 711:b2e1a2660ec2 609 if (type == GapAdvertisingData::COMPLETE_LOCAL_NAME) {
rgrover1 711:b2e1a2660ec2 610 setDeviceName(data);
rgrover1 711:b2e1a2660ec2 611 }
rgrover1 711:b2e1a2660ec2 612
rgrover1 711:b2e1a2660ec2 613 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 614 if ((rc = _advPayload.addData(type, data, len)) != BLE_ERROR_NONE) {
rgrover1 711:b2e1a2660ec2 615 return rc;
rgrover1 711:b2e1a2660ec2 616 }
rgrover1 711:b2e1a2660ec2 617
rgrover1 711:b2e1a2660ec2 618 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 619 }
rgrover1 711:b2e1a2660ec2 620
rgrover1 711:b2e1a2660ec2 621 /**
rgrover1 766:4cd91998cd48 622 * Update a particular ADV field in the advertising payload (based on
vcoubard 1097:c3a43f09f1c5 623 * matching type).
rgrover1 764:36c3e2b1f1ae 624 *
vcoubard 1049:efb29faf12fc 625 * @param[in] type The ADV type field describing the variable length data.
vcoubard 1049:efb29faf12fc 626 * @param[in] data Data bytes.
vcoubard 1049:efb29faf12fc 627 * @param[in] len Length of data.
rgrover1 766:4cd91998cd48 628 *
rgrover1 766:4cd91998cd48 629 * @note: If advertisements are enabled, then the update will take effect immediately.
rgrover1 766:4cd91998cd48 630 *
rgrover1 766:4cd91998cd48 631 * @return BLE_ERROR_NONE if the advertisement payload was updated based on
vcoubard 1097:c3a43f09f1c5 632 * matching AD type; otherwise, an appropriate error.
rgrover1 764:36c3e2b1f1ae 633 */
rgrover1 764:36c3e2b1f1ae 634 ble_error_t updateAdvertisingPayload(GapAdvertisingData::DataType type, const uint8_t *data, uint8_t len) {
rgrover1 764:36c3e2b1f1ae 635 if (type == GapAdvertisingData::COMPLETE_LOCAL_NAME) {
rgrover1 764:36c3e2b1f1ae 636 setDeviceName(data);
rgrover1 764:36c3e2b1f1ae 637 }
rgrover1 764:36c3e2b1f1ae 638
rgrover1 764:36c3e2b1f1ae 639 ble_error_t rc;
rgrover1 764:36c3e2b1f1ae 640 if ((rc = _advPayload.updateData(type, data, len)) != BLE_ERROR_NONE) {
rgrover1 764:36c3e2b1f1ae 641 return rc;
rgrover1 764:36c3e2b1f1ae 642 }
rgrover1 764:36c3e2b1f1ae 643
rgrover1 764:36c3e2b1f1ae 644 return setAdvertisingData();
rgrover1 764:36c3e2b1f1ae 645 }
rgrover1 764:36c3e2b1f1ae 646
rgrover1 764:36c3e2b1f1ae 647 /**
vcoubard 1049:efb29faf12fc 648 * Set up a particular, user-constructed advertisement payload for the
rgrover1 711:b2e1a2660ec2 649 * underlying stack. It would be uncommon for this API to be used directly;
rgrover1 711:b2e1a2660ec2 650 * there are other APIs to build an advertisement payload (see above).
rgrover1 711:b2e1a2660ec2 651 */
rgrover1 711:b2e1a2660ec2 652 ble_error_t setAdvertisingPayload(const GapAdvertisingData &payload) {
rgrover1 711:b2e1a2660ec2 653 _advPayload = payload;
rgrover1 711:b2e1a2660ec2 654 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 655 }
rgrover1 711:b2e1a2660ec2 656
rgrover1 711:b2e1a2660ec2 657 /**
rgrover1 711:b2e1a2660ec2 658 * @return Read back advertising data. Useful for storing and
rgrover1 711:b2e1a2660ec2 659 * restoring payload.
rgrover1 711:b2e1a2660ec2 660 */
rgrover1 711:b2e1a2660ec2 661 const GapAdvertisingData &getAdvertisingPayload(void) const {
rgrover1 711:b2e1a2660ec2 662 return _advPayload;
rgrover1 711:b2e1a2660ec2 663 }
rgrover1 711:b2e1a2660ec2 664
rgrover1 711:b2e1a2660ec2 665 /**
rgrover1 711:b2e1a2660ec2 666 * Accumulate a variable length byte-stream as an AD structure in the
rgrover1 711:b2e1a2660ec2 667 * scanResponse payload.
rgrover1 711:b2e1a2660ec2 668 *
vcoubard 1049:efb29faf12fc 669 * @param[in] type The type describing the variable length data.
vcoubard 1049:efb29faf12fc 670 * @param[in] data Data bytes.
vcoubard 1049:efb29faf12fc 671 * @param[in] len Length of data.
rgrover1 711:b2e1a2660ec2 672 */
rgrover1 711:b2e1a2660ec2 673 ble_error_t accumulateScanResponse(GapAdvertisingData::DataType type, const uint8_t *data, uint8_t len) {
rgrover1 711:b2e1a2660ec2 674 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 675 if ((rc = _scanResponse.addData(type, data, len)) != BLE_ERROR_NONE) {
rgrover1 711:b2e1a2660ec2 676 return rc;
rgrover1 711:b2e1a2660ec2 677 }
rgrover1 711:b2e1a2660ec2 678
rgrover1 711:b2e1a2660ec2 679 return setAdvertisingData();
rgrover1 711:b2e1a2660ec2 680 }
rgrover1 711:b2e1a2660ec2 681
rgrover1 711:b2e1a2660ec2 682 /**
rgrover1 711:b2e1a2660ec2 683 * Reset any scan response prepared from prior calls to
rgrover1 711:b2e1a2660ec2 684 * accumulateScanResponse().
rgrover1 711:b2e1a2660ec2 685 *
rgrover1 711:b2e1a2660ec2 686 * Note: This should be followed by a call to setAdvertisingPayload() or
rgrover1 711:b2e1a2660ec2 687 * startAdvertising() before the update takes effect.
rgrover1 711:b2e1a2660ec2 688 */
rgrover1 711:b2e1a2660ec2 689 void clearScanResponse(void) {
rgrover1 711:b2e1a2660ec2 690 _scanResponse.clear();
rgrover1 711:b2e1a2660ec2 691 setAdvertisingData();
rgrover1 711:b2e1a2660ec2 692 }
rgrover1 711:b2e1a2660ec2 693
rgrover1 711:b2e1a2660ec2 694 /**
vcoubard 1049:efb29faf12fc 695 * Set up parameters for GAP scanning (observer mode).
rgrover1 711:b2e1a2660ec2 696 * @param[in] interval
rgrover1 711:b2e1a2660ec2 697 * Scan interval (in milliseconds) [valid values lie between 2.5ms and 10.24s].
rgrover1 711:b2e1a2660ec2 698 * @param[in] window
rgrover1 711:b2e1a2660ec2 699 * Scan Window (in milliseconds) [valid values lie between 2.5ms and 10.24s].
rgrover1 711:b2e1a2660ec2 700 * @param[in] timeout
vcoubard 1049:efb29faf12fc 701 * Scan timeout (in seconds) between 0x0001 and 0xFFFF; 0x0000 disables the timeout.
rgrover1 711:b2e1a2660ec2 702 * @param[in] activeScanning
rgrover1 711:b2e1a2660ec2 703 * Set to True if active-scanning is required. This is used to fetch the
rgrover1 711:b2e1a2660ec2 704 * scan response from a peer if possible.
rgrover1 711:b2e1a2660ec2 705 *
rgrover1 711:b2e1a2660ec2 706 * The scanning window divided by the interval determines the duty cycle for
rgrover1 711:b2e1a2660ec2 707 * scanning. For example, if the interval is 100ms and the window is 10ms,
rgrover1 711:b2e1a2660ec2 708 * then the controller will scan for 10 percent of the time. It is possible
rgrover1 711:b2e1a2660ec2 709 * to have the interval and window set to the same value. In this case,
rgrover1 711:b2e1a2660ec2 710 * scanning is continuous, with a change of scanning frequency once every
rgrover1 711:b2e1a2660ec2 711 * interval.
rgrover1 711:b2e1a2660ec2 712 *
rgrover1 711:b2e1a2660ec2 713 * Once the scanning parameters have been configured, scanning can be
rgrover1 711:b2e1a2660ec2 714 * enabled by using startScan().
rgrover1 711:b2e1a2660ec2 715 *
rgrover1 711:b2e1a2660ec2 716 * @Note: The scan interval and window are recommendations to the BLE stack.
rgrover1 711:b2e1a2660ec2 717 */
rgrover1 711:b2e1a2660ec2 718 ble_error_t setScanParams(uint16_t interval = GapScanningParams::SCAN_INTERVAL_MAX,
rgrover1 711:b2e1a2660ec2 719 uint16_t window = GapScanningParams::SCAN_WINDOW_MAX,
rgrover1 711:b2e1a2660ec2 720 uint16_t timeout = 0,
rgrover1 711:b2e1a2660ec2 721 bool activeScanning = false) {
rgrover1 711:b2e1a2660ec2 722 ble_error_t rc;
rgrover1 711:b2e1a2660ec2 723 if (((rc = _scanningParams.setInterval(interval)) == BLE_ERROR_NONE) &&
rgrover1 711:b2e1a2660ec2 724 ((rc = _scanningParams.setWindow(window)) == BLE_ERROR_NONE) &&
rgrover1 711:b2e1a2660ec2 725 ((rc = _scanningParams.setTimeout(timeout)) == BLE_ERROR_NONE)) {
rgrover1 711:b2e1a2660ec2 726 _scanningParams.setActiveScanning(activeScanning);
rgrover1 711:b2e1a2660ec2 727 return BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 728 }
rgrover1 711:b2e1a2660ec2 729
rgrover1 711:b2e1a2660ec2 730 return rc;
rgrover1 711:b2e1a2660ec2 731 }
rgrover1 711:b2e1a2660ec2 732
rgrover1 711:b2e1a2660ec2 733 /**
vcoubard 1049:efb29faf12fc 734 * Set up the scanInterval parameter for GAP scanning (observer mode).
rgrover1 711:b2e1a2660ec2 735 * @param[in] interval
rgrover1 711:b2e1a2660ec2 736 * Scan interval (in milliseconds) [valid values lie between 2.5ms and 10.24s].
rgrover1 711:b2e1a2660ec2 737 *
rgrover1 711:b2e1a2660ec2 738 * The scanning window divided by the interval determines the duty cycle for
rgrover1 711:b2e1a2660ec2 739 * scanning. For example, if the interval is 100ms and the window is 10ms,
rgrover1 711:b2e1a2660ec2 740 * then the controller will scan for 10 percent of the time. It is possible
rgrover1 711:b2e1a2660ec2 741 * to have the interval and window set to the same value. In this case,
rgrover1 711:b2e1a2660ec2 742 * scanning is continuous, with a change of scanning frequency once every
rgrover1 711:b2e1a2660ec2 743 * interval.
rgrover1 711:b2e1a2660ec2 744 *
rgrover1 711:b2e1a2660ec2 745 * Once the scanning parameters have been configured, scanning can be
rgrover1 711:b2e1a2660ec2 746 * enabled by using startScan().
rgrover1 711:b2e1a2660ec2 747 */
rgrover1 711:b2e1a2660ec2 748 ble_error_t setScanInterval(uint16_t interval) {
rgrover1 711:b2e1a2660ec2 749 return _scanningParams.setInterval(interval);
rgrover1 711:b2e1a2660ec2 750 }
rgrover1 711:b2e1a2660ec2 751
rgrover1 711:b2e1a2660ec2 752 /**
vcoubard 1049:efb29faf12fc 753 * Set up the scanWindow parameter for GAP scanning (observer mode).
rgrover1 711:b2e1a2660ec2 754 * @param[in] window
rgrover1 711:b2e1a2660ec2 755 * Scan Window (in milliseconds) [valid values lie between 2.5ms and 10.24s].
rgrover1 711:b2e1a2660ec2 756 *
rgrover1 711:b2e1a2660ec2 757 * The scanning window divided by the interval determines the duty cycle for
rgrover1 711:b2e1a2660ec2 758 * scanning. For example, if the interval is 100ms and the window is 10ms,
rgrover1 711:b2e1a2660ec2 759 * then the controller will scan for 10 percent of the time. It is possible
rgrover1 711:b2e1a2660ec2 760 * to have the interval and window set to the same value. In this case,
rgrover1 711:b2e1a2660ec2 761 * scanning is continuous, with a change of scanning frequency once every
rgrover1 711:b2e1a2660ec2 762 * interval.
rgrover1 711:b2e1a2660ec2 763 *
rgrover1 711:b2e1a2660ec2 764 * Once the scanning parameters have been configured, scanning can be
rgrover1 711:b2e1a2660ec2 765 * enabled by using startScan().
rgrover1 771:079b714e9c1a 766 *
rgrover1 771:079b714e9c1a 767 * If scanning is already active, the updated value of scanWindow will be
rgrover1 771:079b714e9c1a 768 * propagated to the underlying BLE stack.
rgrover1 711:b2e1a2660ec2 769 */
rgrover1 711:b2e1a2660ec2 770 ble_error_t setScanWindow(uint16_t window) {
rgrover1 771:079b714e9c1a 771 ble_error_t rc;
rgrover1 771:079b714e9c1a 772 if ((rc = _scanningParams.setWindow(window)) != BLE_ERROR_NONE) {
rgrover1 771:079b714e9c1a 773 return rc;
rgrover1 771:079b714e9c1a 774 }
rgrover1 771:079b714e9c1a 775
rgrover1 771:079b714e9c1a 776 /* If scanning is already active, propagate the new setting to the stack. */
rgrover1 771:079b714e9c1a 777 if (scanningActive) {
rgrover1 771:079b714e9c1a 778 return startRadioScan(_scanningParams);
rgrover1 771:079b714e9c1a 779 }
rgrover1 771:079b714e9c1a 780
rgrover1 771:079b714e9c1a 781 return BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 782 }
rgrover1 711:b2e1a2660ec2 783
rgrover1 711:b2e1a2660ec2 784 /**
vcoubard 1049:efb29faf12fc 785 * Set up parameters for GAP scanning (observer mode).
rgrover1 711:b2e1a2660ec2 786 * @param[in] timeout
vcoubard 1049:efb29faf12fc 787 * Scan timeout (in seconds) between 0x0001 and 0xFFFF; 0x0000 disables the timeout.
rgrover1 711:b2e1a2660ec2 788 *
rgrover1 711:b2e1a2660ec2 789 * Once the scanning parameters have been configured, scanning can be
rgrover1 711:b2e1a2660ec2 790 * enabled by using startScan().
rgrover1 771:079b714e9c1a 791 *
rgrover1 771:079b714e9c1a 792 * If scanning is already active, the updated value of scanTimeout will be
rgrover1 771:079b714e9c1a 793 * propagated to the underlying BLE stack.
rgrover1 711:b2e1a2660ec2 794 */
rgrover1 711:b2e1a2660ec2 795 ble_error_t setScanTimeout(uint16_t timeout) {
rgrover1 771:079b714e9c1a 796 ble_error_t rc;
rgrover1 771:079b714e9c1a 797 if ((rc = _scanningParams.setTimeout(timeout)) != BLE_ERROR_NONE) {
rgrover1 771:079b714e9c1a 798 return rc;
rgrover1 771:079b714e9c1a 799 }
rgrover1 771:079b714e9c1a 800
rgrover1 771:079b714e9c1a 801 /* If scanning is already active, propagate the new settings to the stack. */
rgrover1 771:079b714e9c1a 802 if (scanningActive) {
rgrover1 771:079b714e9c1a 803 return startRadioScan(_scanningParams);
rgrover1 771:079b714e9c1a 804 }
rgrover1 771:079b714e9c1a 805
rgrover1 771:079b714e9c1a 806 return BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 807 }
rgrover1 711:b2e1a2660ec2 808
rgrover1 711:b2e1a2660ec2 809 /**
vcoubard 1049:efb29faf12fc 810 * Set up parameters for GAP scanning (observer mode).
rgrover1 711:b2e1a2660ec2 811 * @param[in] activeScanning
rgrover1 711:b2e1a2660ec2 812 * Set to True if active-scanning is required. This is used to fetch the
rgrover1 711:b2e1a2660ec2 813 * scan response from a peer if possible.
rgrover1 711:b2e1a2660ec2 814 *
rgrover1 711:b2e1a2660ec2 815 * Once the scanning parameters have been configured, scanning can be
rgrover1 711:b2e1a2660ec2 816 * enabled by using startScan().
rgrover1 771:079b714e9c1a 817 *
rgrover1 771:079b714e9c1a 818 * If scanning is already in progress, then active-scanning will be enabled
rgrover1 771:079b714e9c1a 819 * for the underlying BLE stack.
rgrover1 711:b2e1a2660ec2 820 */
rgrover1 771:079b714e9c1a 821 ble_error_t setActiveScanning(bool activeScanning) {
rgrover1 711:b2e1a2660ec2 822 _scanningParams.setActiveScanning(activeScanning);
rgrover1 771:079b714e9c1a 823
rgrover1 771:079b714e9c1a 824 /* If scanning is already active, propagate the new settings to the stack. */
rgrover1 771:079b714e9c1a 825 if (scanningActive) {
rgrover1 771:079b714e9c1a 826 return startRadioScan(_scanningParams);
rgrover1 771:079b714e9c1a 827 }
rgrover1 771:079b714e9c1a 828
rgrover1 771:079b714e9c1a 829 return BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 830 }
rgrover1 711:b2e1a2660ec2 831
rgrover1 711:b2e1a2660ec2 832 /**
rgrover1 711:b2e1a2660ec2 833 * Start scanning (Observer Procedure) based on the parameters currently in
rgrover1 711:b2e1a2660ec2 834 * effect.
rgrover1 711:b2e1a2660ec2 835 *
rgrover1 711:b2e1a2660ec2 836 * @param[in] callback
vcoubard 1049:efb29faf12fc 837 * The application-specific callback to be invoked upon
rgrover1 711:b2e1a2660ec2 838 * receiving every advertisement report. This can be passed in
rgrover1 711:b2e1a2660ec2 839 * as NULL, in which case scanning may not be enabled at all.
rgrover1 711:b2e1a2660ec2 840 */
rgrover1 711:b2e1a2660ec2 841 ble_error_t startScan(void (*callback)(const AdvertisementCallbackParams_t *params)) {
rgrover1 711:b2e1a2660ec2 842 ble_error_t err = BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 843 if (callback) {
rgrover1 711:b2e1a2660ec2 844 if ((err = startRadioScan(_scanningParams)) == BLE_ERROR_NONE) {
rgrover1 771:079b714e9c1a 845 scanningActive = true;
rgrover1 711:b2e1a2660ec2 846 onAdvertisementReport.attach(callback);
rgrover1 711:b2e1a2660ec2 847 }
rgrover1 711:b2e1a2660ec2 848 }
rgrover1 711:b2e1a2660ec2 849
rgrover1 711:b2e1a2660ec2 850 return err;
rgrover1 711:b2e1a2660ec2 851 }
rgrover1 711:b2e1a2660ec2 852
rgrover1 711:b2e1a2660ec2 853 /**
rgrover1 711:b2e1a2660ec2 854 * Same as above, but this takes an (object, method) pair for a callback.
rgrover1 711:b2e1a2660ec2 855 */
rgrover1 711:b2e1a2660ec2 856 template<typename T>
rgrover1 711:b2e1a2660ec2 857 ble_error_t startScan(T *object, void (T::*callbackMember)(const AdvertisementCallbackParams_t *params)) {
rgrover1 711:b2e1a2660ec2 858 ble_error_t err = BLE_ERROR_NONE;
rgrover1 711:b2e1a2660ec2 859 if (object && callbackMember) {
rgrover1 711:b2e1a2660ec2 860 if ((err = startRadioScan(_scanningParams)) == BLE_ERROR_NONE) {
rgrover1 771:079b714e9c1a 861 scanningActive = true;
rgrover1 711:b2e1a2660ec2 862 onAdvertisementReport.attach(object, callbackMember);
rgrover1 711:b2e1a2660ec2 863 }
rgrover1 711:b2e1a2660ec2 864 }
rgrover1 711:b2e1a2660ec2 865
rgrover1 711:b2e1a2660ec2 866 return err;
rgrover1 711:b2e1a2660ec2 867 }
rgrover1 711:b2e1a2660ec2 868
rgrover1 754:0f60274cd3ad 869 /**
rgrover1 754:0f60274cd3ad 870 * Initialize radio-notification events to be generated from the stack.
vcoubard 1049:efb29faf12fc 871 * This API doesn't need to be called directly.
rgrover1 754:0f60274cd3ad 872 *
rgrover1 754:0f60274cd3ad 873 * Radio Notification is a feature that enables ACTIVE and INACTIVE
rgrover1 754:0f60274cd3ad 874 * (nACTIVE) signals from the stack that notify the application when the
rgrover1 754:0f60274cd3ad 875 * radio is in use.
rgrover1 754:0f60274cd3ad 876 *
vcoubard 1049:efb29faf12fc 877 * The ACTIVE signal is sent before the radio event starts. The nACTIVE
vcoubard 1049:efb29faf12fc 878 * signal is sent at the end of the radio event. These signals can be used
rgrover1 754:0f60274cd3ad 879 * by the application programmer to synchronize application logic with radio
rgrover1 754:0f60274cd3ad 880 * activity. For example, the ACTIVE signal can be used to shut off external
vcoubard 1049:efb29faf12fc 881 * devices, to manage peak current drawn during periods when the radio is on,
rgrover1 754:0f60274cd3ad 882 * or to trigger sensor data collection for transmission in the Radio Event.
rgrover1 754:0f60274cd3ad 883 *
rgrover1 754:0f60274cd3ad 884 * @return BLE_ERROR_NONE on successful initialization, otherwise an error code.
rgrover1 754:0f60274cd3ad 885 */
rgrover1 754:0f60274cd3ad 886 virtual ble_error_t initRadioNotification(void) {
rgrover1 754:0f60274cd3ad 887 return BLE_ERROR_NOT_IMPLEMENTED; /* Requesting action from porter(s): override this API if this capability is supported. */
rgrover1 754:0f60274cd3ad 888 }
rgrover1 754:0f60274cd3ad 889
rgrover1 711:b2e1a2660ec2 890 private:
rgrover1 711:b2e1a2660ec2 891 ble_error_t setAdvertisingData(void) {
rgrover1 711:b2e1a2660ec2 892 return setAdvertisingData(_advPayload, _scanResponse);
rgrover1 711:b2e1a2660ec2 893 }
rgrover1 711:b2e1a2660ec2 894
rgrover1 711:b2e1a2660ec2 895 private:
rgrover1 897:791741895cd8 896 virtual ble_error_t setAdvertisingData(const GapAdvertisingData &advData, const GapAdvertisingData &scanResponse) = 0;
rgrover1 897:791741895cd8 897 virtual ble_error_t startAdvertising(const GapAdvertisingParams &) = 0;
rgrover1 711:b2e1a2660ec2 898
rgrover1 711:b2e1a2660ec2 899 public:
rgrover1 711:b2e1a2660ec2 900 /**
rgrover1 711:b2e1a2660ec2 901 * Accessors to read back currently active advertising params.
rgrover1 711:b2e1a2660ec2 902 */
rgrover1 711:b2e1a2660ec2 903 GapAdvertisingParams &getAdvertisingParams(void) {
rgrover1 711:b2e1a2660ec2 904 return _advParams;
rgrover1 711:b2e1a2660ec2 905 }
rgrover1 711:b2e1a2660ec2 906 const GapAdvertisingParams &getAdvertisingParams(void) const {
rgrover1 711:b2e1a2660ec2 907 return _advParams;
rgrover1 711:b2e1a2660ec2 908 }
rgrover1 711:b2e1a2660ec2 909
rgrover1 711:b2e1a2660ec2 910 /**
vcoubard 1049:efb29faf12fc 911 * Set up a particular, user-constructed set of advertisement parameters for
rgrover1 711:b2e1a2660ec2 912 * the underlying stack. It would be uncommon for this API to be used
rgrover1 711:b2e1a2660ec2 913 * directly; there are other APIs to tweak advertisement parameters
rgrover1 711:b2e1a2660ec2 914 * individually.
rgrover1 711:b2e1a2660ec2 915 */
rgrover1 711:b2e1a2660ec2 916 void setAdvertisingParams(const GapAdvertisingParams &newParams) {
rgrover1 711:b2e1a2660ec2 917 _advParams = newParams;
rgrover1 711:b2e1a2660ec2 918 }
rgrover1 711:b2e1a2660ec2 919
rgrover1 711:b2e1a2660ec2 920 /* Event callback handlers. */
rgrover1 711:b2e1a2660ec2 921 public:
rgrover1 711:b2e1a2660ec2 922 /**
vcoubard 1049:efb29faf12fc 923 * Set up a callback for timeout events. Refer to TimeoutSource_t for
rgrover1 711:b2e1a2660ec2 924 * possible event types.
vcoubard 1053:b55e1ad3e1b3 925 * @note It is possible to unregister callbacks using onTimeout().detach(callback)
rgrover1 711:b2e1a2660ec2 926 */
vcoubard 1053:b55e1ad3e1b3 927 void onTimeout(TimeoutEventCallback_t callback) {
vcoubard 1053:b55e1ad3e1b3 928 timeoutCallbackChain.add(callback);
vcoubard 1053:b55e1ad3e1b3 929 }
vcoubard 1053:b55e1ad3e1b3 930
vcoubard 1053:b55e1ad3e1b3 931 /**
vcoubard 1053:b55e1ad3e1b3 932 * @brief provide access to the callchain of timeout event callbacks
vcoubard 1053:b55e1ad3e1b3 933 * It is possible to register callbacks using onTimeout().add(callback);
vcoubard 1055:f59e5d9a992a 934 * It is possible to unregister callbacks using onTimeout().detach(callback)
vcoubard 1053:b55e1ad3e1b3 935 * @return The timeout event callbacks chain
vcoubard 1053:b55e1ad3e1b3 936 */
vcoubard 1053:b55e1ad3e1b3 937 TimeoutEventCallbackChain_t& onTimeout() {
vcoubard 1053:b55e1ad3e1b3 938 return timeoutCallbackChain;
vcoubard 1053:b55e1ad3e1b3 939 }
rgrover1 711:b2e1a2660ec2 940
rgrover1 711:b2e1a2660ec2 941 /**
rgrover1 830:9072de50087b 942 * Append to a chain of callbacks to be invoked upon GAP connection.
vcoubard 1053:b55e1ad3e1b3 943 * @note It is possible to unregister callbacks using onConnection().detach(callback)
rgrover1 711:b2e1a2660ec2 944 */
rgrover1 830:9072de50087b 945 void onConnection(ConnectionEventCallback_t callback) {connectionCallChain.add(callback);}
rgrover1 711:b2e1a2660ec2 946
rgrover1 830:9072de50087b 947 template<typename T>
rgrover1 830:9072de50087b 948 void onConnection(T *tptr, void (T::*mptr)(const ConnectionCallbackParams_t*)) {connectionCallChain.add(tptr, mptr);}
rgrover1 711:b2e1a2660ec2 949
rgrover1 711:b2e1a2660ec2 950 /**
vcoubard 1053:b55e1ad3e1b3 951 * @brief provide access to the callchain of connection event callbacks
vcoubard 1053:b55e1ad3e1b3 952 * It is possible to register callbacks using onConnection().add(callback);
vcoubard 1055:f59e5d9a992a 953 * It is possible to unregister callbacks using onConnection().detach(callback)
vcoubard 1053:b55e1ad3e1b3 954 * @return The connection event callbacks chain
vcoubard 1053:b55e1ad3e1b3 955 */
vcoubard 1055:f59e5d9a992a 956 ConnectionEventCallbackChain_t& onConnection() {
vcoubard 1053:b55e1ad3e1b3 957 return connectionCallChain;
vcoubard 1053:b55e1ad3e1b3 958 }
vcoubard 1053:b55e1ad3e1b3 959
vcoubard 1053:b55e1ad3e1b3 960 /**
rgrover1 830:9072de50087b 961 * Append to a chain of callbacks to be invoked upon GAP disconnection.
vcoubard 1053:b55e1ad3e1b3 962 * @note It is possible to unregister callbacks using onDisconnection().detach(callback)
rgrover1 817:2b4f0ef8c06e 963 */
rgrover1 830:9072de50087b 964 void onDisconnection(DisconnectionEventCallback_t callback) {disconnectionCallChain.add(callback);}
rgrover1 817:2b4f0ef8c06e 965
rgrover1 711:b2e1a2660ec2 966 template<typename T>
rgrover1 830:9072de50087b 967 void onDisconnection(T *tptr, void (T::*mptr)(const DisconnectionCallbackParams_t*)) {disconnectionCallChain.add(tptr, mptr);}
rgrover1 711:b2e1a2660ec2 968
rgrover1 711:b2e1a2660ec2 969 /**
vcoubard 1053:b55e1ad3e1b3 970 * @brief provide access to the callchain of disconnection event callbacks
vcoubard 1053:b55e1ad3e1b3 971 * It is possible to register callbacks using onDisconnection().add(callback);
vcoubard 1055:f59e5d9a992a 972 * It is possible to unregister callbacks using onDisconnection().detach(callback)
vcoubard 1053:b55e1ad3e1b3 973 * @return The disconnection event callbacks chain
vcoubard 1053:b55e1ad3e1b3 974 */
vcoubard 1053:b55e1ad3e1b3 975 DisconnectionEventCallbackChain_t& onDisconnection() {
vcoubard 1053:b55e1ad3e1b3 976 return disconnectionCallChain;
vcoubard 1053:b55e1ad3e1b3 977 }
vcoubard 1053:b55e1ad3e1b3 978
vcoubard 1053:b55e1ad3e1b3 979 /**
rgrover1 711:b2e1a2660ec2 980 * Set the application callback for radio-notification events.
rgrover1 711:b2e1a2660ec2 981 *
rgrover1 711:b2e1a2660ec2 982 * Radio Notification is a feature that enables ACTIVE and INACTIVE
rgrover1 711:b2e1a2660ec2 983 * (nACTIVE) signals from the stack that notify the application when the
rgrover1 754:0f60274cd3ad 984 * radio is in use.
rgrover1 711:b2e1a2660ec2 985 *
vcoubard 1049:efb29faf12fc 986 * The ACTIVE signal is sent before the radio event starts. The nACTIVE
vcoubard 1049:efb29faf12fc 987 * signal is sent at the end of the radio event. These signals can be used
rgrover1 711:b2e1a2660ec2 988 * by the application programmer to synchronize application logic with radio
rgrover1 711:b2e1a2660ec2 989 * activity. For example, the ACTIVE signal can be used to shut off external
vcoubard 1049:efb29faf12fc 990 * devices, to manage peak current drawn during periods when the radio is on,
rgrover1 711:b2e1a2660ec2 991 * or to trigger sensor data collection for transmission in the Radio Event.
rgrover1 711:b2e1a2660ec2 992 *
rgrover1 711:b2e1a2660ec2 993 * @param callback
rgrover1 711:b2e1a2660ec2 994 * The application handler to be invoked in response to a radio
rgrover1 711:b2e1a2660ec2 995 * ACTIVE/INACTIVE event.
rgrover1 755:9b391fb5c5d7 996 *
vcoubard 1049:efb29faf12fc 997 * Or in the other version:
rgrover1 755:9b391fb5c5d7 998 *
rgrover1 755:9b391fb5c5d7 999 * @param tptr
rgrover1 755:9b391fb5c5d7 1000 * Pointer to the object of a class defining the member callback
rgrover1 755:9b391fb5c5d7 1001 * function (mptr).
rgrover1 755:9b391fb5c5d7 1002 * @param mptr
rgrover1 755:9b391fb5c5d7 1003 * The member callback (within the context of an object) to be
rgrover1 755:9b391fb5c5d7 1004 * invoked in response to a radio ACTIVE/INACTIVE event.
rgrover1 711:b2e1a2660ec2 1005 */
rgrover1 754:0f60274cd3ad 1006 void onRadioNotification(void (*callback)(bool param)) {
rgrover1 754:0f60274cd3ad 1007 radioNotificationCallback.attach(callback);
rgrover1 754:0f60274cd3ad 1008 }
rgrover1 754:0f60274cd3ad 1009 template <typename T>
rgrover1 754:0f60274cd3ad 1010 void onRadioNotification(T *tptr, void (T::*mptr)(bool)) {
rgrover1 754:0f60274cd3ad 1011 radioNotificationCallback.attach(tptr, mptr);
rgrover1 754:0f60274cd3ad 1012 }
rgrover1 711:b2e1a2660ec2 1013
vcoubard 1091:148d8b9b56a5 1014 /**
vcoubard 1091:148d8b9b56a5 1015 * Setup a callback to be invoked to notify the user application that the
vcoubard 1091:148d8b9b56a5 1016 * Gap instance is about to shutdown (possibly as a result of a call
vcoubard 1091:148d8b9b56a5 1017 * to BLE::shutdown()).
vcoubard 1091:148d8b9b56a5 1018 *
vcoubard 1091:148d8b9b56a5 1019 * @Note: It is possible to chain together multiple onShutdown callbacks
vcoubard 1091:148d8b9b56a5 1020 * (potentially from different modules of an application) to be notified
vcoubard 1091:148d8b9b56a5 1021 * before the Gap instance is shutdown.
vcoubard 1091:148d8b9b56a5 1022 *
vcoubard 1091:148d8b9b56a5 1023 * @Note: It is also possible to set up a callback into a member function of
vcoubard 1091:148d8b9b56a5 1024 * some object.
vcoubard 1091:148d8b9b56a5 1025 *
vcoubard 1091:148d8b9b56a5 1026 * @Note It is possible to unregister a callback using onShutdown().detach(callback)
vcoubard 1091:148d8b9b56a5 1027 */
vcoubard 1091:148d8b9b56a5 1028 void onShutdown(const GapShutdownCallback_t& callback) {
vcoubard 1091:148d8b9b56a5 1029 shutdownCallChain.add(callback);
vcoubard 1091:148d8b9b56a5 1030 }
vcoubard 1091:148d8b9b56a5 1031 template <typename T>
vcoubard 1091:148d8b9b56a5 1032 void onShutdown(T *objPtr, void (T::*memberPtr)(void)) {
vcoubard 1091:148d8b9b56a5 1033 shutdownCallChain.add(objPtr, memberPtr);
vcoubard 1091:148d8b9b56a5 1034 }
vcoubard 1091:148d8b9b56a5 1035
vcoubard 1091:148d8b9b56a5 1036 /**
vcoubard 1091:148d8b9b56a5 1037 * @brief provide access to the callchain of shutdown event callbacks
vcoubard 1091:148d8b9b56a5 1038 * It is possible to register callbacks using onShutdown().add(callback);
vcoubard 1091:148d8b9b56a5 1039 * It is possible to unregister callbacks using onShutdown().detach(callback)
vcoubard 1091:148d8b9b56a5 1040 * @return The shutdown event callbacks chain
vcoubard 1091:148d8b9b56a5 1041 */
vcoubard 1091:148d8b9b56a5 1042 GapShutdownCallbackChain_t& onShutdown() {
vcoubard 1091:148d8b9b56a5 1043 return shutdownCallChain;
vcoubard 1091:148d8b9b56a5 1044 }
vcoubard 1091:148d8b9b56a5 1045
vcoubard 1083:127667021827 1046 public:
vcoubard 1083:127667021827 1047 /**
vcoubard 1091:148d8b9b56a5 1048 * Notify all registered onShutdown callbacks that the Gap instance is
vcoubard 1091:148d8b9b56a5 1049 * about to be shutdown and clear all Gap state of the
vcoubard 1091:148d8b9b56a5 1050 * associated object.
vcoubard 1083:127667021827 1051 *
vcoubard 1083:127667021827 1052 * This function is meant to be overridden in the platform-specific
vcoubard 1083:127667021827 1053 * sub-class. Nevertheless, the sub-class is only expected to reset its
vcoubard 1083:127667021827 1054 * state and not the data held in Gap members. This shall be achieved by a
vcoubard 1083:127667021827 1055 * call to Gap::reset() from the sub-class' reset() implementation.
vcoubard 1083:127667021827 1056 *
vcoubard 1083:127667021827 1057 * @return BLE_ERROR_NONE on success.
vcoubard 1083:127667021827 1058 *
vcoubard 1083:127667021827 1059 * @note: Currently a call to reset() does not reset the advertising and
vcoubard 1083:127667021827 1060 * scan parameters to default values.
vcoubard 1083:127667021827 1061 */
vcoubard 1083:127667021827 1062 virtual ble_error_t reset(void) {
vcoubard 1091:148d8b9b56a5 1063 /* Notify that the instance is about to shutdown */
vcoubard 1091:148d8b9b56a5 1064 shutdownCallChain.call(this);
vcoubard 1091:148d8b9b56a5 1065 shutdownCallChain.clear();
vcoubard 1091:148d8b9b56a5 1066
vcoubard 1083:127667021827 1067 /* Clear Gap state */
vcoubard 1083:127667021827 1068 state.advertising = 0;
vcoubard 1085:40c1e518d6de 1069 state.connected = 0;
vcoubard 1083:127667021827 1070
vcoubard 1083:127667021827 1071 /* Clear scanning state */
vcoubard 1083:127667021827 1072 scanningActive = false;
vcoubard 1083:127667021827 1073
vcoubard 1083:127667021827 1074 /* Clear advertising and scanning data */
vcoubard 1083:127667021827 1075 _advPayload.clear();
vcoubard 1083:127667021827 1076 _scanResponse.clear();
vcoubard 1083:127667021827 1077
vcoubard 1083:127667021827 1078 /* Clear callbacks */
vcoubard 1083:127667021827 1079 timeoutCallbackChain.clear();
vcoubard 1083:127667021827 1080 connectionCallChain.clear();
vcoubard 1083:127667021827 1081 disconnectionCallChain.clear();
vcoubard 1083:127667021827 1082 radioNotificationCallback = NULL;
vcoubard 1085:40c1e518d6de 1083 onAdvertisementReport = NULL;
vcoubard 1083:127667021827 1084
vcoubard 1083:127667021827 1085 return BLE_ERROR_NONE;
vcoubard 1083:127667021827 1086 }
vcoubard 1083:127667021827 1087
rgrover1 711:b2e1a2660ec2 1088 protected:
rgrover1 711:b2e1a2660ec2 1089 Gap() :
rgrover1 711:b2e1a2660ec2 1090 _advParams(),
rgrover1 711:b2e1a2660ec2 1091 _advPayload(),
rgrover1 711:b2e1a2660ec2 1092 _scanningParams(),
rgrover1 711:b2e1a2660ec2 1093 _scanResponse(),
rgrover1 711:b2e1a2660ec2 1094 state(),
rgrover1 771:079b714e9c1a 1095 scanningActive(false),
vcoubard 1053:b55e1ad3e1b3 1096 timeoutCallbackChain(),
rgrover1 711:b2e1a2660ec2 1097 radioNotificationCallback(),
rgrover1 711:b2e1a2660ec2 1098 onAdvertisementReport(),
rgrover1 817:2b4f0ef8c06e 1099 connectionCallChain(),
rgrover1 711:b2e1a2660ec2 1100 disconnectionCallChain() {
rgrover1 711:b2e1a2660ec2 1101 _advPayload.clear();
rgrover1 711:b2e1a2660ec2 1102 _scanResponse.clear();
rgrover1 711:b2e1a2660ec2 1103 }
rgrover1 711:b2e1a2660ec2 1104
rgrover1 711:b2e1a2660ec2 1105 /* Entry points for the underlying stack to report events back to the user. */
rgrover1 711:b2e1a2660ec2 1106 public:
vcoubard 1080:6e2d9514f3df 1107 void processConnectionEvent(Handle_t handle,
vcoubard 1080:6e2d9514f3df 1108 Role_t role,
vcoubard 1080:6e2d9514f3df 1109 BLEProtocol::AddressType_t peerAddrType,
vcoubard 1080:6e2d9514f3df 1110 const BLEProtocol::Address_t peerAddr,
vcoubard 1080:6e2d9514f3df 1111 BLEProtocol::AddressType_t ownAddrType,
vcoubard 1080:6e2d9514f3df 1112 const BLEProtocol::Address_t ownAddr,
vcoubard 1080:6e2d9514f3df 1113 const ConnectionParams_t *connectionParams) {
rgrover1 711:b2e1a2660ec2 1114 state.connected = 1;
rgrover1 830:9072de50087b 1115 ConnectionCallbackParams_t callbackParams(handle, role, peerAddrType, peerAddr, ownAddrType, ownAddr, connectionParams);
rgrover1 830:9072de50087b 1116 connectionCallChain.call(&callbackParams);
rgrover1 711:b2e1a2660ec2 1117 }
rgrover1 711:b2e1a2660ec2 1118
rgrover1 711:b2e1a2660ec2 1119 void processDisconnectionEvent(Handle_t handle, DisconnectionReason_t reason) {
rgrover1 711:b2e1a2660ec2 1120 state.connected = 0;
rgrover1 830:9072de50087b 1121 DisconnectionCallbackParams_t callbackParams(handle, reason);
rgrover1 830:9072de50087b 1122 disconnectionCallChain.call(&callbackParams);
rgrover1 711:b2e1a2660ec2 1123 }
rgrover1 711:b2e1a2660ec2 1124
vcoubard 1080:6e2d9514f3df 1125 void processAdvertisementReport(const BLEProtocol::Address_t peerAddr,
vcoubard 1080:6e2d9514f3df 1126 int8_t rssi,
vcoubard 1080:6e2d9514f3df 1127 bool isScanResponse,
rgrover1 711:b2e1a2660ec2 1128 GapAdvertisingParams::AdvertisingType_t type,
vcoubard 1080:6e2d9514f3df 1129 uint8_t advertisingDataLen,
vcoubard 1080:6e2d9514f3df 1130 const uint8_t *advertisingData) {
rgrover1 711:b2e1a2660ec2 1131 AdvertisementCallbackParams_t params;
rgrover1 711:b2e1a2660ec2 1132 memcpy(params.peerAddr, peerAddr, ADDR_LEN);
rgrover1 711:b2e1a2660ec2 1133 params.rssi = rssi;
rgrover1 711:b2e1a2660ec2 1134 params.isScanResponse = isScanResponse;
rgrover1 711:b2e1a2660ec2 1135 params.type = type;
rgrover1 711:b2e1a2660ec2 1136 params.advertisingDataLen = advertisingDataLen;
rgrover1 711:b2e1a2660ec2 1137 params.advertisingData = advertisingData;
rgrover1 711:b2e1a2660ec2 1138 onAdvertisementReport.call(&params);
rgrover1 711:b2e1a2660ec2 1139 }
rgrover1 711:b2e1a2660ec2 1140
rgrover1 711:b2e1a2660ec2 1141 void processTimeoutEvent(TimeoutSource_t source) {
vcoubard 1053:b55e1ad3e1b3 1142 if (timeoutCallbackChain) {
vcoubard 1053:b55e1ad3e1b3 1143 timeoutCallbackChain(source);
rgrover1 711:b2e1a2660ec2 1144 }
rgrover1 711:b2e1a2660ec2 1145 }
rgrover1 711:b2e1a2660ec2 1146
rgrover1 711:b2e1a2660ec2 1147 protected:
rgrover1 711:b2e1a2660ec2 1148 GapAdvertisingParams _advParams;
rgrover1 711:b2e1a2660ec2 1149 GapAdvertisingData _advPayload;
rgrover1 711:b2e1a2660ec2 1150 GapScanningParams _scanningParams;
rgrover1 711:b2e1a2660ec2 1151 GapAdvertisingData _scanResponse;
rgrover1 711:b2e1a2660ec2 1152
rgrover1 711:b2e1a2660ec2 1153 GapState_t state;
rgrover1 771:079b714e9c1a 1154 bool scanningActive;
rgrover1 711:b2e1a2660ec2 1155
rgrover1 711:b2e1a2660ec2 1156 protected:
vcoubard 1053:b55e1ad3e1b3 1157 TimeoutEventCallbackChain_t timeoutCallbackChain;
vcoubard 1053:b55e1ad3e1b3 1158 RadioNotificationEventCallback_t radioNotificationCallback;
vcoubard 1053:b55e1ad3e1b3 1159 AdvertisementReportCallback_t onAdvertisementReport;
vcoubard 1053:b55e1ad3e1b3 1160 ConnectionEventCallbackChain_t connectionCallChain;
vcoubard 1053:b55e1ad3e1b3 1161 DisconnectionEventCallbackChain_t disconnectionCallChain;
rgrover1 711:b2e1a2660ec2 1162
rgrover1 711:b2e1a2660ec2 1163 private:
vcoubard 1091:148d8b9b56a5 1164 GapShutdownCallbackChain_t shutdownCallChain;
vcoubard 1091:148d8b9b56a5 1165
vcoubard 1091:148d8b9b56a5 1166 private:
vcoubard 1049:efb29faf12fc 1167 /* Disallow copy and assignment. */
rgrover1 711:b2e1a2660ec2 1168 Gap(const Gap &);
rgrover1 711:b2e1a2660ec2 1169 Gap& operator=(const Gap &);
rgrover1 711:b2e1a2660ec2 1170 };
rgrover1 711:b2e1a2660ec2 1171
rgrover1 711:b2e1a2660ec2 1172 #endif // ifndef __GAP_H__