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.
x-nucleo-idb0xa1/bluenrg-hci/ble_osal.h
- Committer:
- Andrea Palmieri
- Date:
- 2016-09-16
- Revision:
- 307:fa98703ece8e
- Parent:
- 298:a16d2170c282
File content as of revision 307:fa98703ece8e:
/******************** (C) COPYRIGHT 2012 STMicroelectronics ******************** * File Name : ble_osal.h * Author : AMS - HEA&RF BU * Version : V1.0.0 * Date : 19-July-2012 * Description : This header file defines the OS abstraction layer used by * the BLE stack. OSAL defines the set of functions * which needs to be ported to target operating system and * target platform. ******************************************************************************** * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE TIME. * AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY DIRECT, * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING FROM THE * CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE CODING * INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. *******************************************************************************/ #ifndef __OSAL_H__ #define __OSAL_H__ /****************************************************************************** * Includes *****************************************************************************/ #include <ble_hal_types.h> #ifdef __ICCARM__ #include <intrinsics.h> #endif /****************************************************************************** * Macros *****************************************************************************/ /****************************************************************************** * Function Prototypes *****************************************************************************/ /** * This function copies size number of bytes from a * memory location pointed by src to a destination * memory location pointed by dest * * @param[in] dest Destination address * @param[in] src Source address * @param[in] size size in the bytes * * @return Address of the destination */ extern void* Osal_MemCpy(void *dest,const void *src, unsigned int size); /** * This function sets first number of bytes, specified * by size, to the destination memory pointed by ptr * to the specified value * * @param[in] ptr Destination address * @param[in] value Value to be set * @param[in] size Size in the bytes * * @return Address of the destination */ extern void* Osal_MemSet(void *ptr, int value, unsigned int size); /** * Osal_Get_Cur_Time * * returns the current time in milliseconds */ /** * Returns the number of ticks (1 tick = 1 millisecond) * * @return Time in milliseconds */ uint32_t Osal_Get_Cur_Time(void); #endif /* __OSAL_H__ */