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 ST Expansion SW Team

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.

Committer:
Vincent Coubard
Date:
Thu Sep 15 10:51:47 2016 +0100
Branch:
34e2f6254ad7de7fc7f377a0614c3a672cf7cd5c
Revision:
280:fbee0e3444be
Parent:
source/bluenrg-hci/utils/osal.c@132:51056160fa4a
Child:
298:a16d2170c282
Sync with 34e2f6254ad7de7fc7f377a0614c3a672cf7cd5c

2016-07-28 15:27:24+02:00: Andrea Palmieri
Add ble_ prefix to filename

Signed-off-by: Andrea Palmieri <andrea.palmieri@st.com>

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Wolfgang Betz 132:51056160fa4a 1 /**
Wolfgang Betz 132:51056160fa4a 2 ******************************************************************************
Wolfgang Betz 132:51056160fa4a 3 * @file osal.c
Wolfgang Betz 132:51056160fa4a 4 * @author AMS - HEA&RF BU / CL
Wolfgang Betz 132:51056160fa4a 5 * @version V1.0.0
Wolfgang Betz 132:51056160fa4a 6 * @date 04-July-2014
Wolfgang Betz 132:51056160fa4a 7 * @brief Implementation of OS abstraction layer functions used by the
Wolfgang Betz 132:51056160fa4a 8 * library.
Wolfgang Betz 132:51056160fa4a 9 ******************************************************************************
Wolfgang Betz 132:51056160fa4a 10 * @attention
Wolfgang Betz 132:51056160fa4a 11 *
Wolfgang Betz 132:51056160fa4a 12 * <h2><center>&copy; COPYRIGHT(c) 2014 STMicroelectronics</center></h2>
Wolfgang Betz 132:51056160fa4a 13 *
Wolfgang Betz 132:51056160fa4a 14 * Redistribution and use in source and binary forms, with or without modification,
Wolfgang Betz 132:51056160fa4a 15 * are permitted provided that the following conditions are met:
Wolfgang Betz 132:51056160fa4a 16 * 1. Redistributions of source code must retain the above copyright notice,
Wolfgang Betz 132:51056160fa4a 17 * this list of conditions and the following disclaimer.
Wolfgang Betz 132:51056160fa4a 18 * 2. Redistributions in binary form must reproduce the above copyright notice,
Wolfgang Betz 132:51056160fa4a 19 * this list of conditions and the following disclaimer in the documentation
Wolfgang Betz 132:51056160fa4a 20 * and/or other materials provided with the distribution.
Wolfgang Betz 132:51056160fa4a 21 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Wolfgang Betz 132:51056160fa4a 22 * may be used to endorse or promote products derived from this software
Wolfgang Betz 132:51056160fa4a 23 * without specific prior written permission.
Wolfgang Betz 132:51056160fa4a 24 *
Wolfgang Betz 132:51056160fa4a 25 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Wolfgang Betz 132:51056160fa4a 26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Wolfgang Betz 132:51056160fa4a 27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Wolfgang Betz 132:51056160fa4a 28 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Wolfgang Betz 132:51056160fa4a 29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Wolfgang Betz 132:51056160fa4a 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Wolfgang Betz 132:51056160fa4a 31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Wolfgang Betz 132:51056160fa4a 32 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Wolfgang Betz 132:51056160fa4a 33 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Wolfgang Betz 132:51056160fa4a 34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Wolfgang Betz 132:51056160fa4a 35 *
Wolfgang Betz 132:51056160fa4a 36 ******************************************************************************
Wolfgang Betz 132:51056160fa4a 37 */
Wolfgang Betz 132:51056160fa4a 38
Wolfgang Betz 132:51056160fa4a 39 /* Includes ------------------------------------------------------------------*/
Wolfgang Betz 132:51056160fa4a 40 #include <string.h>
Wolfgang Betz 132:51056160fa4a 41 #include <osal.h>
Wolfgang Betz 132:51056160fa4a 42
Wolfgang Betz 132:51056160fa4a 43 /**
Wolfgang Betz 132:51056160fa4a 44 * @brief Osal_MemCpy
Wolfgang Betz 132:51056160fa4a 45 * @param dest: Pointer to the destination buffer
Wolfgang Betz 132:51056160fa4a 46 * @param src : Pointer to the source buffer
Wolfgang Betz 132:51056160fa4a 47 * @param size: Number of bytes to copy from the source to the destination
Wolfgang Betz 132:51056160fa4a 48 * buffer
Wolfgang Betz 132:51056160fa4a 49 * @retval Pointer to the destination buffer
Wolfgang Betz 132:51056160fa4a 50 */
Wolfgang Betz 132:51056160fa4a 51 void* Osal_MemCpy(void *dest, const void *src, unsigned int size)
Wolfgang Betz 132:51056160fa4a 52 {
Wolfgang Betz 132:51056160fa4a 53 return(memcpy(dest,src,size));
Wolfgang Betz 132:51056160fa4a 54 }
Wolfgang Betz 132:51056160fa4a 55
Wolfgang Betz 132:51056160fa4a 56 /**
Wolfgang Betz 132:51056160fa4a 57 * @brief Osal_MemSet
Wolfgang Betz 132:51056160fa4a 58 * @param ptr : Pointer to block of memory to fill
Wolfgang Betz 132:51056160fa4a 59 * @param value: Value to assign to each byte of the memory block
Wolfgang Betz 132:51056160fa4a 60 * @param size : Number of bytes to be set to "value"
Wolfgang Betz 132:51056160fa4a 61 * @retval Pointer to the filled block of memory
Wolfgang Betz 132:51056160fa4a 62 */
Wolfgang Betz 132:51056160fa4a 63 void* Osal_MemSet(void *ptr, int value, unsigned int size)
Wolfgang Betz 132:51056160fa4a 64 {
Wolfgang Betz 132:51056160fa4a 65 return(memset(ptr,value,size));
Wolfgang Betz 132:51056160fa4a 66 }
Wolfgang Betz 132:51056160fa4a 67
Wolfgang Betz 132:51056160fa4a 68 /******************************************************************************
Wolfgang Betz 132:51056160fa4a 69 * local Functions
Wolfgang Betz 132:51056160fa4a 70 *****************************************************************************/
Wolfgang Betz 132:51056160fa4a 71
Wolfgang Betz 132:51056160fa4a 72 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/