Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: microbit_rubber_ducky microbit_mouse_BLE microbit_mouse_BLE_daybreak_version microbit_presenter
Fork of nRF51822 by
Revision 596:b66851544182, committed 2016-01-11
- Comitter:
- vcoubard
- Date:
- Mon Jan 11 10:19:34 2016 +0000
- Parent:
- 595:5e2a961fd9ac
- Child:
- 597:bcd5e287c494
- Commit message:
- Synchronized with git rev fdead9ec
Author: Andres Amaya Garcia
Early whitelisting API prototype implementation
Changed in this revision
| source/nRF5xGap.cpp | Show annotated file Show diff for this revision Revisions of this file |
| source/nRF5xGap.h | Show annotated file Show diff for this revision Revisions of this file |
--- a/source/nRF5xGap.cpp Mon Jan 11 10:19:34 2016 +0000
+++ b/source/nRF5xGap.cpp Mon Jan 11 10:19:34 2016 +0000
@@ -173,8 +173,8 @@
adv_para.type = params.getAdvertisingType();
adv_para.p_peer_addr = NULL; // Undirected advertisement
- adv_para.fp = BLE_GAP_ADV_FP_ANY;
- adv_para.p_whitelist = NULL;
+ adv_para.fp = advertisingPolicyMode;
+ adv_para.p_whitelist = &whitelist;
adv_para.interval = params.getIntervalInADVUnits(); // advertising interval (in units of 0.625 ms)
adv_para.timeout = params.getTimeout();
@@ -234,8 +234,8 @@
}
ble_gap_scan_params_t scanParams;
- scanParams.selective = 0; /**< If 1, ignore unknown devices (non whitelisted). */
- scanParams.p_whitelist = NULL; /**< Pointer to whitelist, NULL if none is given. */
+ scanParams.selective = scanningPolicyMode; /**< If 1, ignore unknown devices (non whitelisted). */
+ scanParams.p_whitelist = &whitelist; /**< Pointer to whitelist, NULL if none is given. */
if (scanParamsIn != NULL) {
scanParams.active = scanParamsIn->getActiveScanning(); /**< If 1, perform active scanning (scan requests). */
scanParams.interval = scanParamsIn->getInterval(); /**< Scan interval between 0x0004 and 0x4000 in 0.625ms units (2.5ms to 10.24s). */
@@ -506,4 +506,66 @@
*valueArrayPP = permittedTxValues;
*countP = sizeof(permittedTxValues) / sizeof(int8_t);
-}
\ No newline at end of file
+}
+
+/////////////////////////WHITELISTING
+int8_t nRF5xGap::getMaxWhitelistSize(void) const
+{
+ return YOTTA_CFG_WHITELIST_MAX_SIZE;
+}
+
+ble_error_t nRF5xGap::getWhitelist(std::set<BLEProtocol::Address_t> &whitelist) const
+{
+ for (uint8_t i = 0; i < whitelistAddressesSize; i++) {
+ BLEProtocol::Address_t addr;//((BLEProtocol::AddressType_t)whitelistAddrs[i].addr_type, (BLEProtocol::AddressBytes_t) whitelistAddrs[i].addr);
+ addr.type = (BLEProtocol::AddressType_t) whitelistAddrs[i].addr_type;
+ memcpy(addr.address, whitelistAddrs[i].addr, sizeof(BLEProtocol::AddressBytes_t));
+ whitelist.insert(addr);
+ }
+ return BLE_ERROR_NONE;
+}
+
+ble_error_t nRF5xGap::setWhitelist(std::set<BLEProtocol::Address_t> whitelistIn)
+{
+ whitelistAddressesSize = 0;
+ for (std::set<BLEProtocol::Address_t>::iterator it = whitelistIn.begin(); it != whitelistIn.end(); it++) {
+ whitelistAddrs[whitelistAddressesSize].addr_type = it->type;
+ memcpy(whitelistAddrs[whitelistAddressesSize].addr, it->address, sizeof(BLEProtocol::AddressBytes_t));
+ whitelistAddressesSize++;
+ }
+ whitelist.addr_count = whitelistAddressesSize;
+ whitelist.irk_count = whitelistIrksSize;
+ return BLE_ERROR_NONE;
+}
+
+// Accessors
+void nRF5xGap::setAdvertisingPolicyMode(Gap::AdvertisingPolicyMode_t mode)
+{
+ advertisingPolicyMode = mode;
+}
+
+void nRF5xGap::setScanningPolicyMode(Gap::ScanningPolicyMode_t mode)
+{
+ scanningPolicyMode = mode;
+}
+
+void nRF5xGap::setInitiatorPolicyMode(Gap::InitiatorPolicyMode_t mode)
+{
+ initiatorPolicyMode = mode;
+}
+
+Gap::AdvertisingPolicyMode_t nRF5xGap::getAdvertisingPolicyMode(void) const
+{
+ return advertisingPolicyMode;
+}
+
+Gap::ScanningPolicyMode_t nRF5xGap::getScanningPolicyMode(void) const
+{
+ return scanningPolicyMode;
+}
+
+Gap::InitiatorPolicyMode_t nRF5xGap::getInitiatorPolicyMode(void) const
+{
+ return initiatorPolicyMode;
+}
+/////////////////////////
\ No newline at end of file
--- a/source/nRF5xGap.h Mon Jan 11 10:19:34 2016 +0000
+++ b/source/nRF5xGap.h Mon Jan 11 10:19:34 2016 +0000
@@ -22,6 +22,12 @@
#else
#include "mbed.h"
#endif
+#ifndef YOTTA_CFG_WHITELIST_MAX_SIZE
+ #define YOTTA_CFG_WHITELIST_MAX_SIZE BLE_GAP_WHITELIST_ADDR_MAX_COUNT
+#elif YOTTA_CFG_WHITELIST_MAX_SIZE > BLE_GAP_WHITELIST_ADDR_MAX_COUNT
+ #undef YOTTA_CFG_WHITELIST_MAX_SIZE
+ #define YOTTA_CFG_WHITELIST_MAX_SIZE BLE_GAP_WHITELIST_ADDR_MAX_COUNT
+#endif
#include "ble/blecommon.h"
#include "ble.h"
#include "ble/GapAdvertisingParams.h"
@@ -37,6 +43,8 @@
#include "btle_security.h"
+#include <set>
+
void radioNotificationStaticCallback(bool param);
/**************************************************************************/
@@ -80,6 +88,20 @@
virtual ble_error_t reset(void);
+ /////////////////// WHITELISTING
+ virtual int8_t getMaxWhitelistSize(void) const;
+ virtual ble_error_t getWhitelist(std::set<BLEProtocol::Address_t> &whitelist) const;
+ virtual ble_error_t setWhitelist(std::set<BLEProtocol::Address_t> whitelist);
+
+ // Accessors
+ virtual void setAdvertisingPolicyMode(AdvertisingPolicyMode_t mode);
+ virtual void setScanningPolicyMode(ScanningPolicyMode_t mode);
+ virtual void setInitiatorPolicyMode(InitiatorPolicyMode_t mode);
+ virtual Gap::AdvertisingPolicyMode_t getAdvertisingPolicyMode(void) const;
+ virtual Gap::ScanningPolicyMode_t getScanningPolicyMode(void) const;
+ virtual Gap::InitiatorPolicyMode_t getInitiatorPolicyMode(void) const;
+ ///////////////////
+
virtual ble_error_t initRadioNotification(void) {
if (ble_radio_notification_init(NRF_APP_PRIORITY_HIGH, NRF_RADIO_NOTIFICATION_DISTANCE_800US, radioNotificationStaticCallback) == NRF_SUCCESS) {
return BLE_ERROR_NONE;
@@ -93,8 +115,8 @@
virtual ble_error_t startRadioScan(const GapScanningParams &scanningParams) {
ble_gap_scan_params_t scanParams = {
.active = scanningParams.getActiveScanning(), /**< If 1, perform active scanning (scan requests). */
- .selective = 0, /**< If 1, ignore unknown devices (non whitelisted). */
- .p_whitelist = NULL, /**< Pointer to whitelist, NULL if none is given. */
+ .selective = scanningPolicyMode, /**< If 1, ignore unknown devices (non whitelisted). */
+ .p_whitelist = &whitelist, /**< Pointer to whitelist, NULL if none is given. */
.interval = scanningParams.getInterval(), /**< Scan interval between 0x0004 and 0x4000 in 0.625ms units (2.5ms to 10.24s). */
.window = scanningParams.getWindow(), /**< Scan window between 0x0004 and 0x4000 in 0.625ms units (2.5ms to 10.24s). */
.timeout = scanningParams.getTimeout(), /**< Scan timeout between 0x0001 and 0xFFFF in seconds, 0x0000 disables timeout. */
@@ -117,6 +139,21 @@
#endif
private:
+ /////////////////WHITELISTING
+ Gap::AdvertisingPolicyMode_t advertisingPolicyMode;
+ Gap::ScanningPolicyMode_t scanningPolicyMode;
+ Gap::InitiatorPolicyMode_t initiatorPolicyMode; /* Unused */
+
+ ble_gap_addr_t whitelistAddrs[YOTTA_CFG_WHITELIST_MAX_SIZE];
+ ble_gap_addr_t *whitelistAddresses[YOTTA_CFG_WHITELIST_MAX_SIZE];
+ uint8_t whitelistAddressesSize;
+ ble_gap_irk_t *whitelistIrks[YOTTA_CFG_WHITELIST_MAX_SIZE];
+ uint8_t whitelistIrksSize;
+
+ ble_gap_whitelist_t whitelist;
+
+ /////////////////
+
bool radioNotificationCallbackParam; /* parameter to be passed into the Timeout-generated radio notification callback. */
Timeout radioNotificationTimeout;
@@ -206,8 +243,19 @@
*/
friend class nRF5xn;
- nRF5xGap() {
+ nRF5xGap() :
+ advertisingPolicyMode(Gap::ADV_POLICY_IGNORE_WHITELIST),
+ scanningPolicyMode(Gap::SCAN_POLICY_IGNORE_WHITELIST),
+ initiatorPolicyMode(Gap::INIT_POLICY_IGNORE_WHITELIST),
+ whitelistAddressesSize(0),
+ whitelistIrksSize(0) {
m_connectionHandle = BLE_CONN_HANDLE_INVALID;
+
+ whitelist.pp_addrs = whitelistAddresses;
+ for (int i = 0; i < YOTTA_CFG_WHITELIST_MAX_SIZE; i++) {
+ whitelistAddresses[i] = &(whitelistAddrs[i]);
+ }
+ whitelist.pp_irks = whitelistIrks;
}
nRF5xGap(nRF5xGap const &);
