From 13bbda2a7d65feeb651ad1ef4ae0f86425287cad Mon Sep 17 00:00:00 2001 From: Rohit Grover Date: Fri, 24 Apr 2015 15:13:11 +0100 Subject: [PATCH] add API for startScanning() --- nRF51Gap.h | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/nRF51Gap.h b/nRF51Gap.h index 6a17280..c052f4b 100644 --- a/nRF51Gap.h +++ b/nRF51Gap.h @@ -77,6 +77,26 @@ public: ble_radio_notification_init(NRF_APP_PRIORITY_HIGH, NRF_RADIO_NOTIFICATION_DISTANCE_800US, onRadioNotification); } + virtual ble_error_t startScanning(const GapScanningParams &scanningParams, AdvertisementReportCallback_t callback) { + if ((onAdvertisementReport = callback) != NULL) { + + ble_gap_scan_params_t scanParams = { + .active = 0, /**< 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. */ + .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. */ + }; + + if (sd_ble_gap_scan_start(&scanParams) != NRF_SUCCESS) { + return BLE_ERROR_PARAM_OUT_OF_RANGE; + } + } + + return BLE_ERROR_NONE; + } + private: uint16_t m_connectionHandle; nRF51Gap() {