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: BLE_HeartRate_IDB0XA1
Fork of X_NUCLEO_IDB0XA1 by
Diff: x-nucleo-idb0xa1/BlueNRGGap.h
- Revision:
- 132:51056160fa4a
- Parent:
- 131:e09947216ccb
- Child:
- 144:bdf5e8432131
--- a/x-nucleo-idb0xa1/BlueNRGGap.h Tue Oct 06 15:19:19 2015 +0200
+++ b/x-nucleo-idb0xa1/BlueNRGGap.h Wed Oct 07 08:39:04 2015 +0200
@@ -40,7 +40,7 @@
#include "btle.h"
#include "ble/GapAdvertisingParams.h"
#include "ble/GapAdvertisingData.h"
-#include <ble/Gap.h>
+#include "ble/Gap.h"
#define BLE_CONN_HANDLE_INVALID 0x0
#define BDADDR_SIZE 6
@@ -49,6 +49,19 @@
#define BLUENRG_GAP_ADV_INTERVAL_MAX (0)
#define BLE_GAP_ADV_NONCON_INTERVAL_MIN (0)
+// Scanning and Connection Params used by Central for creating connection
+#define LIMITED_DISCOVERY_PROCEDURE 0x01
+#define GENERAL_DISCOVERY_PROCEDURE 0x02
+
+#define SCAN_P (0x4000)
+#define SCAN_L (0x4000)
+#define SUPERV_TIMEOUT (600)
+#define CONN_P(x) ((int)((x)/1.25f))
+#define CONN_L(x) ((int)((x)/0.625f))
+#define CONN_P1 (CONN_P(50))//(CONN_P(1000))
+#define CONN_P2 (CONN_P(50))//(CONN_P(1000))
+#define CONN_L1 (CONN_L(5))
+#define CONN_L2 (CONN_L(5))
#define UUID_BUFFER_SIZE 13 //6*2(16-bit UUIDs)+1
#define ADV_DATA_MAX_SIZE 31
@@ -67,12 +80,18 @@
}
// <<<ANDREA>>>
+ /*
enum AdvType_t {
ADV_IND = GapAdvertisingParams::ADV_CONNECTABLE_UNDIRECTED,//Gap::ADV_IND,
ADV_DIRECT_IND = GapAdvertisingParams::ADV_CONNECTABLE_DIRECTED,//Gap::ADV_DIRECT_IND,
ADV_SCAN_IND = GapAdvertisingParams::ADV_SCANNABLE_UNDIRECTED,//Gap::ADV_SCAN_IND,
ADV_NONCONN_IND = GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED//Gap::ADV_NONCONN_IND
};
+ */
+ enum Reason_t {
+ DEVICE_FOUND,
+ DISCOVERY_COMPLETE
+ };
/* Functions that must be implemented from Gap */
virtual ble_error_t setAddress(addr_type_t type, const Address_t address);
@@ -98,12 +117,23 @@
virtual ble_error_t setTxPower(int8_t txPower);
virtual void getPermittedTxPowerValues(const int8_t **, size_t *);
// <<<ANDREA>>>
+ virtual ble_error_t connect(const Address_t peerAddr,
+ Gap::AddressType_t peerAddrType,
+ const ConnectionParams_t *connectionParams,
+ const GapScanningParams *scanParams);
+ void Discovery_CB(Reason_t reason,
+ uint8_t adv_type,
+ uint8_t *addr_type,
+ uint8_t *addr,
+ uint8_t *data_length,
+ uint8_t *data,
+ uint8_t *RSSI);
+ ble_error_t makeConnection(void);
void setConnectionHandle(uint16_t con_handle);
uint16_t getConnectionHandle(void);
- //tHalUint8* getAddress();
bool getIsSetAddress();
Timeout getAdvTimeout(void) const {
@@ -121,7 +151,11 @@
private:
uint16_t m_connectionHandle;
+ AddressType_t addr_type;
+ Address_t _peerAddr;
uint8_t bdaddr[BDADDR_SIZE];
+ bool _scanning;
+ bool _connecting;
bool isSetAddress;
tBleStatus ret; // FIXME: delete this
uint8_t *DeviceName;
@@ -143,6 +177,7 @@
BlueNRGGap() {
m_connectionHandle = BLE_CONN_HANDLE_INVALID;
+ addr_type = Gap::ADDR_TYPE_PUBLIC;
isSetAddress = false;
DeviceName = NULL;
}
