Prototype RF driver for STM Sub-1 GHz RF expansion board based on the SPSGRF-868 module for STM32 Nucleo.
Prototype RF Driver for STM Sub-1 GHz RF Expansion Boards based on the SPSGRF-868 and SPSGRF-915 Modules for STM32 Nucleo
Currently supported boards:
Note, in order to use expansion board X-NUCLEO-IDS01A4
in mbed you need to perform the following HW modifications on the board:
- Unmount resistor
R4
- Mount resistor
R7
Furthermore, on some Nucleo development boards (e.g. the NUCLEO_F429ZI), in order to be able to use Ethernet together with these Sub-1 GHz RF expansion boards, you need to compile this driver with macro SPIRIT1_SPI_MOSI=PB_5
defined, while the development board typically requires some HW modification as e.g. described here!
This driver can be used together with the 6LoWPAN stack (a.k.a. Nanostack).
source/libs/Contiki_STM32_Library/platform-conf.h
- Committer:
- Wolfgang Betz
- Date:
- 2017-07-06
- Revision:
- 67:93bec0baf1de
- Parent:
- 34:edda6a7238ec
File content as of revision 67:93bec0baf1de:
/** ****************************************************************************** * @file platform/stm32nucleo-spirit1/platform-conf.h * @author System LAB * @version V1.0.0 * @date 17-May-2015 * @brief Configuration parameters ****************************************************************************** * @attention * * <h2><center>© COPYRIGHT(c) 2014 STMicroelectronics</center></h2> * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * 3. Neither the name of STMicroelectronics nor the names of its contributors * may be used to endorse or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ****************************************************************************** */ /*---------------------------------------------------------------------------*/ /** * \addtogroup stm32nucleo-spirit1 * @{ * * \defgroup stm32nucleo-spirit1-peripherals User Button on STM32 Nucleo * * Defines some of the platforms capabilities * @{ * * \file * Header file for the stm32nucleo-spirit1 platform configuration */ /*---------------------------------------------------------------------------*/ #ifndef __PLATFORM_CONF_H__ #define __PLATFORM_CONF_H__ /*---------------------------------------------------------------------------*/ #ifdef USE_STM32L1XX_NUCLEO #include <inttypes.h> #include <string.h> /*---------------------------------------------------------------------------*/ #define PLATFORM_HAS_LEDS 1 #define PLATFORM_HAS_BUTTON 1 #define PLATFORM_HAS_RADIO 1 #define LEDS_GREEN 1 /*Nucleo LED*/ #define LEDS_RED 2 /*SPIRIT1 LED*/ #ifdef COMPILE_SENSORS #define LEDS_CONF_ALL 1 /*Can't use SPIRIT1 LED in this case*/ #else #define LEDS_CONF_ALL 3 /*No sensors -> we can use SPIRIT1 LED in this case*/ #endif /*COMPILE_SENSORS*/ /*---------------------------------------------------------------------------*/ #define F_CPU 32000000ul #define RTIMER_ARCH_SECOND 32768 #define PRESCALER ((F_CPU / (RTIMER_ARCH_SECOND*2))) #define UART1_CONF_TX_WITH_INTERRUPT 0 #define WITH_SERIAL_LINE_INPUT 1 #define TELNETD_CONF_NUMLINES 6 #define NETSTACK_CONF_RADIO spirit_radio_driver #define NETSTACK_RADIO_MAX_PAYLOAD_LEN 96 /* spirit1-config.h */ #if WITH_IP64 #include "ip64-conf.h" #define WITH_SLIP 1 #ifndef UIP_FALLBACK_INTERFACE #define UIP_FALLBACK_INTERFACE ip64_uip_fallback_interface #endif #endif /* WITH_IP64 */ /*---------------------------------------------------------------------------*/ /* define ticks/second for slow and fast clocks. Notice that these should be a power of two, eg 64,128,256,512 etc, for efficiency as POT's can be optimized well. */ #define CLOCK_CONF_SECOND 128 #define RELOAD_VALUE ((F_CPU/CLOCK_CONF_SECOND) - 1) /* One tick: 62.5 ms */ #define RTIMER_CLOCK_LT(a,b) ((signed short)((a)-(b)) < 0) /*---------------------------------------------------------------------------*/ typedef unsigned long clock_time_t; typedef unsigned long long rtimer_clock_t; /*---------------------------------------------------------------------------*/ #define CC_CONF_REGISTER_ARGS 0 #define CC_CONF_FUNCTION_POINTER_ARGS 1 #define CC_CONF_FASTCALL #define CC_CONF_VA_ARGS 1 #define CC_CONF_INLINE inline #define CCIF #define CLIF /*---------------------------------------------------------------------------*/ typedef uint8_t u8_t; typedef uint16_t u16_t; typedef uint32_t u32_t; typedef int32_t s32_t; typedef unsigned short uip_stats_t; /*---------------------------------------------------------------------------*/ #define MULTICHAN_CONF_SET_CHANNEL(x) #define MULTICHAN_CONF_READ_RSSI(x) 0 /*---------------------------------------------------------------------------*/ #endif//USE_STM32L1XX_NUCLEO #ifdef USE_STM32F4XX_NUCLEO #include <inttypes.h> #include <string.h> #include "main.h" /*---------------------------------------------------------------------------*/ #define PLATFORM_HAS_LEDS 1 #define PLATFORM_HAS_BUTTON 1 #define PLATFORM_HAS_RADIO 1 #define LEDS_GREEN 1 /*Nucleo LED*/ #define LEDS_RED 2 /*SPIRIT1 LED*/ #ifdef COMPILE_SENSORS #define LEDS_CONF_ALL 1 /*Can't use SPIRIT1 LED in this case*/ #else #define LEDS_CONF_ALL 3 /*No sensors -> we can use SPIRIT1 LED in this case*/ #endif /*COMPILE_SENSORS*/ /*---------------------------------------------------------------------------*/ #define F_CPU 84000000ul #define RTIMER_ARCH_SECOND 96000//32678 //#define PRESCALER uwPrescalerValue #define UART1_CONF_TX_WITH_INTERRUPT 0 #define WITH_SERIAL_LINE_INPUT 1 #define TELNETD_CONF_NUMLINES 6 #define NETSTACK_CONF_RADIO spirit_radio_driver #define NETSTACK_RADIO_MAX_PAYLOAD_LEN 96 /* spirit1-config.h */ #if WITH_IP64 #include "ip64-conf.h" #define WITH_SLIP 1 #ifndef UIP_FALLBACK_INTERFACE #define UIP_FALLBACK_INTERFACE ip64_uip_fallback_interface #endif #endif /* WITH_IP64 */ /*---------------------------------------------------------------------------*/ /* define ticks/second for slow and fast clocks. Notice that these should be a power of two, eg 64,128,256,512 etc, for efficiency as POT's can be optimized well. */ #define CLOCK_CONF_SECOND 512 #define RELOAD_VALUE ((F_CPU/CLOCK_CONF_SECOND) - 1) /* One tick: 62.5 ms */ #define RTIMER_CLOCK_LT(a,b) ((signed short)((a)-(b)) < 0) /*---------------------------------------------------------------------------*/ typedef unsigned long clock_time_t; typedef unsigned long long rtimer_clock_t; /*---------------------------------------------------------------------------*/ #define CC_CONF_REGISTER_ARGS 0 #define CC_CONF_FUNCTION_POINTER_ARGS 1 #define CC_CONF_FASTCALL #define CC_CONF_VA_ARGS 1 #define CC_CONF_INLINE inline #define CCIF #define CLIF /*---------------------------------------------------------------------------*/ typedef uint8_t u8_t; typedef uint16_t u16_t; typedef uint32_t u32_t; typedef int32_t s32_t; typedef unsigned short uip_stats_t; /*---------------------------------------------------------------------------*/ #define MULTICHAN_CONF_SET_CHANNEL(x) #define MULTICHAN_CONF_READ_RSSI(x) 0 /*---------------------------------------------------------------------------*/ #endif//USE_STM32F4XX_NUCLEO #endif /* __PLATFORM_CONF_H__ */ /*---------------------------------------------------------------------------*/ /** * @} * @} */