BLE_API wrapper library for STMicroelectronics' BlueNRG Bluetooth Low Energy expansion board shield (Component)
Dependents: Nucleo_Zumo_BLE_IDB04A1 contest_IOT5 contest_IOT6 contest_IOT_10 ... more
Fork of X_NUCLEO_IDB0XA1 by
Arduino Connector Compatibility Warning
X-NUCLEO-IDB04A1 and X-NUCLEO-IDB05A1 are Arduino compatible with an exception: instead of using pin D13
for the SPI clock, they use pin D3
.
The default configuration for this library is having the SPI clock on pin D3
.
To be fully Arduino compatible, X-NUCLEO-IDB04A1 and X-NUCLEO-IDB05A1 need a small HW patch.
For X-NUCLEO-IDB04A1 this patch consists in removing zero resistor R10
and instead soldering zero resistor R11
.
For X-NUCLEO-IDB05A1 this patch consists in removing zero resistor R4
and instead soldering zero resistor R6
.
In case you patch your board, then you also have to configure this library to use pin D13
to drive the SPI clock (see macro IDB0XA1_D13_PATCH
in file x_nucleo_idb0xa1_targets.h
).
If you use pin D13
for the SPI clock, please be aware that on STM32 Nucleo boards you may not drive the LED, otherwise you will get a conflict: the LED on STM32 Nucleo boards is connected to pin D13
.
Referring to the current list of tested platforms (see X-NUCLEO-IDB04A1 and X-NUCLEO-IDB05A1 pages), the patch is required by ST-Nucleo-F103RB; ST-Nucleo-F302R8; ST-Nucleo-F411RE; and ST-Nucleo-F446RE.
Diff: x-nucleo-idb0xa1/BlueNRGGap.h
- Revision:
- 228:25368f053411
- Parent:
- 224:d8669b6b3175
- Child:
- 229:9981f62cdb1a
--- a/x-nucleo-idb0xa1/BlueNRGGap.h Tue Apr 26 14:33:08 2016 +0200 +++ b/x-nucleo-idb0xa1/BlueNRGGap.h Tue Apr 26 14:44:54 2016 +0200 @@ -95,7 +95,7 @@ }; /* Functions that must be implemented from Gap */ - virtual ble_error_t setAddress(addr_type_t type, const Address_t address); + /*virtual ble_error_t setAddress(addr_type_t type, const Address_t address);*/ virtual ble_error_t getAddress(addr_type_t *typeP, Address_t address); virtual ble_error_t setAdvertisingData(const GapAdvertisingData &, const GapAdvertisingData &); virtual ble_error_t startAdvertising(const GapAdvertisingParams &); @@ -160,7 +160,6 @@ bool _scanning; bool _connecting; bool isSetAddress; - uint8_t *DeviceName; uint8_t deviceAppearance[2]; uint8_t local_name_length; @@ -177,9 +176,9 @@ BlueNRGGap() { m_connectionHandle = BLE_CONN_HANDLE_INVALID; - addr_type = BLEProtocol::AddressType::PUBLIC; + addr_type = BLEProtocol::AddressType::RANDOM_STATIC; isSetAddress = false; - DeviceName = NULL; + memset(deviceAppearance, 0, sizeof(deviceAppearance)); } BlueNRGGap(BlueNRGGap const &);