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.
source/bluenrg-hci/utils/ble_osal.c@280:fbee0e3444be, 2016-09-15 (annotated)
- 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?
User | Revision | Line number | New 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>© 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****/ |