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: source/BlueNRGGap.cpp
- Revision:
- 223:36df860f7ffc
- Parent:
- 222:37a7e289ee3d
- Child:
- 224:d8669b6b3175
--- a/source/BlueNRGGap.cpp Wed Apr 06 18:06:07 2016 +0200 +++ b/source/BlueNRGGap.cpp Fri Apr 08 17:42:38 2016 +0200 @@ -419,7 +419,7 @@ } advtInterval = params.getIntervalInADVUnits(); - PRINTF("advtInterval=%ld\n\r", advtInterval); + printf("advtInterval=%ld advType=%d\n\r", advtInterval, params.getAdvertisingType()); ret = aci_gap_set_discoverable(params.getAdvertisingType(), // AdvType advtInterval, // AdvIntervMin @@ -434,9 +434,9 @@ 0); // SlaveConnIntervMax - PRINTF("!!!setting discoverable (servUuidlength=0x%x)\n\r", servUuidlength); + printf("!!!setting discoverable (servUuidlength=0x%x)\n\r", servUuidlength); if(BLE_STATUS_SUCCESS!=ret) { - PRINTF("error occurred while setting discoverable (ret=0x%x)\n\r", ret); + printf("error occurred while setting discoverable (ret=0x%x)\n\r", ret); switch (ret) { case BLE_STATUS_INVALID_PARAMS: return BLE_ERROR_INVALID_PARAM; @@ -1156,9 +1156,11 @@ tBleStatus ret = BLE_STATUS_SUCCESS; // Stop ADV before scanning + /* if (state.advertising == 1) { stopAdvertising(); } + */ PRINTF("Scanning...\n\r"); ret = btleStartRadioScan(scanningParams.getActiveScanning(),