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).

Revision:
34:edda6a7238ec
Parent:
33:c226804be492
Child:
35:f3f444c379d0
--- a/libs/spirit1/SPIRIT1_Library/Src/SPIRIT_Calibration.c	Mon Nov 21 13:26:17 2016 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,491 +0,0 @@
-/**
-  ******************************************************************************
- * @file    SPIRIT_Calibration.c
-  * @author  VMA division - AMS
-  * @version 3.2.2
-  * @date    08-July-2015
- * @brief   Configuration and management of SPIRIT VCO-RCO calibration.
- *
-  * @attention
- *
-  * <h2><center>&copy; COPYRIGHT(c) 2015 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.
-  *
-  ******************************************************************************
- */
-
-/* Includes ------------------------------------------------------------------*/
-#include "SPIRIT_Calibration.h"
-#include "MCU_Interface.h"
-
-
-
-
-/**
- * @addtogroup SPIRIT_Libraries
- * @{
- */
-
-
-/**
- * @addtogroup SPIRIT_Calibration
- * @{
- */
-
-
-/**
- * @defgroup Calibration_Private_TypesDefinitions       Calibration Private Types Definitions
- * @{
- */
-
-/**
- *@}
- */
-
-
-/**
- * @defgroup Calibration_Private_Defines                Calibration Private Defines
- * @{
- */
-
-
-/**
- *@}
- */
-
-
-/**
- * @defgroup Calibration_Private_Macros                 Calibration Private Macros
- * @{
- */
-
-/**
- *@}
- */
-
-
-/**
- * @defgroup Calibration_Private_Variables              Calibration Private Variables
- * @{
- */
-
-/**
- *@}
- */
-
-
-
-/**
- * @defgroup Calibration_Private_FunctionPrototypes     Calibration Private Function Prototypes
- * @{
- */
-
-/**
- *@}
- */
-
-
-/**
- * @defgroup Calibration_Private_Functions              Calibration Private Functions
- * @{
- */
-
-/**
- * @brief  Enables or Disables the RCO calibration.
- * @param  xNewState new state for RCO calibration.
-           This parameter can be S_ENABLE or S_DISABLE.
- * @retval None.
- */
-void SpiritCalibrationRco(SpiritFunctionalState xNewState)
-{
-  uint8_t tempRegValue;
-
-  /* Check the parameters */
-  s_assert_param(IS_SPIRIT_FUNCTIONAL_STATE(xNewState));
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(PROTOCOL2_BASE, 1, &tempRegValue);
-
-  /* Build new value for the register */
-  if(xNewState==S_ENABLE)
-  {
-    tempRegValue |= PROTOCOL2_RCO_CALIBRATION_MASK;
-  }
-  else
-  {
-    tempRegValue &= ~PROTOCOL2_RCO_CALIBRATION_MASK;
-  }
-
-  /* Writes register to enable or disable the RCO calibration */
-  g_xStatus = SpiritSpiWriteRegisters(PROTOCOL2_BASE, 1, &tempRegValue);
-
-}
-
-
-/**
- * @brief  Enables or Disables the VCO calibration.
- * @param  xNewState new state for VCO calibration.
-           This parameter can be S_ENABLE or S_DISABLE.
- * @retval None.
- */
-void SpiritCalibrationVco(SpiritFunctionalState xNewState)
-{
-  uint8_t tempRegValue;
-
-  /* Check the parameters */
-  s_assert_param(IS_SPIRIT_FUNCTIONAL_STATE(xNewState));
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(PROTOCOL2_BASE, 1, &tempRegValue);
-
-   /* Build new value for the register */
-  if(xNewState==S_ENABLE)
-    tempRegValue |= PROTOCOL2_VCO_CALIBRATION_MASK;
-  else
-    tempRegValue &= ~PROTOCOL2_VCO_CALIBRATION_MASK;
-
-  /* Writes register to enable or disable the VCO calibration */
-  g_xStatus = SpiritSpiWriteRegisters(PROTOCOL2_BASE, 1, &tempRegValue);
-
-}
-
-
-/**
- * @brief  Sets the RCO calibration words.
- * @param  cRwt RWT word for RCO calibration.
- *         This parameter can be a value of uint8_t.
- * @param  cRfb RFB word for RCO calibration.
- *         This parameter can be a value of uint8_t.
- * @retval None.
- */
-void SpiritCalibrationSetRcoCalWords(uint8_t cRwt, uint8_t cRfb)
-{
-  uint8_t tempRegValue[2];
-
-  /* Build the value of RWT and the MSbits of the RFB word */
-  tempRegValue[0] = (cRwt << 4) | (cRfb >> 1);
-
-  /* Reads the register value to update the LSbit of RFB */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_IN1_BASE, 1, &tempRegValue[1]);
-
-  /* Build new value for the register */
-  tempRegValue[1] = (tempRegValue[1] & 0x7F) | (cRfb<<7);
-
-  /* Writes the new value for RCO calibration words */
-  g_xStatus = SpiritSpiWriteRegisters(RCO_VCO_CALIBR_IN2_BASE, 2, tempRegValue);
-
-}
-
-
-/**
- * @brief  Returns the RCO calibration words.
- * @param  pcRwt pointer to the variable in which the RWT word has to be stored.
- *         This parameter is a variable of uint8_t*.
- * @param  pcRfb pointer to the variable in which the RFB word has to be stored.
- *         This parameter is a variable of uint8_t*.
- * @retval None.
- */
-void SpiritCalibrationGetRcoCalWords(uint8_t* pcRwt, uint8_t* pcRfb)
-{
-  uint8_t tempRegValue[2];
-
-  /* Reads the registers values */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_OUT1_BASE, 2, tempRegValue);
-
-  /* Build the RWT value */
-  (*pcRwt) = tempRegValue[0] >> 4;
-  /* Build the RFB value */
-  (*pcRfb) = (tempRegValue[0] & 0x0F)<<1 | (tempRegValue[1]>>7);
-
-}
-
-
-/**
- * @brief  Returns the VCO calibration data from internal VCO calibrator.
- * @param  None.
- * @retval uint8_t VCO calibration data word.
- */
-uint8_t SpiritCalibrationGetVcoCalData(void)
-{
-  uint8_t tempRegValue;
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_OUT0_BASE, 1, &tempRegValue);
-
-  /* Build and returns the VCO calibration data value */
-  return (tempRegValue & 0x7F);
-
-}
-
-
-/**
- * @brief  Sets the VCO calibration data to be used in TX mode.
- * @param  cVcoCalData calibration data word to be set.
- *         This parameter is a variable of uint8_t.
- * @retval None.
- */
-void SpiritCalibrationSetVcoCalDataTx(uint8_t cVcoCalData)
-{
-  uint8_t tempRegValue;
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_IN1_BASE, 1, &tempRegValue);
-
-  /* Build the value to be written */
-  tempRegValue &= 0x80;
-  tempRegValue |= cVcoCalData;
-
-  /* Writes the new value of calibration data in TX */
-  g_xStatus = SpiritSpiWriteRegisters(RCO_VCO_CALIBR_IN1_BASE, 1, &tempRegValue);
-
-}
-
-
-/**
- * @brief  Returns the actual VCO calibration data used in TX mode.
- * @param  None.
- * @retval uint8_t Calibration data word used in TX mode.
- */
-uint8_t SpiritCalibrationGetVcoCalDataTx(void)
-{
-  uint8_t tempRegValue;
-
-  /* Reads the register containing the calibration data word used in TX mode */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_IN1_BASE, 1, &tempRegValue);
-
-  /* Mask the VCO_CALIBR_TX field and returns the value */
-  return (tempRegValue & 0x7F);
-
-}
-
-
-/**
- * @brief  Sets the VCO calibration data to be used in RX mode.
- * @param  cVcoCalData calibration data word to be set.
- *         This parameter is a variable of uint8_t.
- * @retval None.
- */
-void SpiritCalibrationSetVcoCalDataRx(uint8_t cVcoCalData)
-{
-  uint8_t tempRegValue;
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_IN0_BASE, 1, &tempRegValue);
-
-  /* Build the value to be written */
-  tempRegValue &= 0x80;
-  tempRegValue |= cVcoCalData;
-
-  /* Writes the new value of calibration data in RX */
-  g_xStatus = SpiritSpiWriteRegisters(RCO_VCO_CALIBR_IN0_BASE, 1, &tempRegValue);
-
-}
-
-
-/**
- * @brief  Returns the actual VCO calibration data used in RX mode.
- * @param  None.
- * @retval uint8_t Calibration data word used in RX mode.
- */
-uint8_t SpiritCalibrationGetVcoCalDataRx(void)
-{
-  uint8_t tempRegValue;
-
-  /* Reads the register containing the calibration data word used in TX mode */
-  g_xStatus = SpiritSpiReadRegisters(RCO_VCO_CALIBR_IN0_BASE, 1, &tempRegValue);
-
-  /* Mask the VCO_CALIBR_RX field and returns the value */
-  return (tempRegValue & 0x7F);
-
-}
-
-
-/**
- * @brief  Sets the VCO calibration window.
- * @param  xRefWord value of REFWORD corresponding to the Ref_period according to the formula: CALIBRATION_WIN = 11*Ref_period/fxo.
-           This parameter can be a value of @ref VcoWin.
- * @retval None.
- */
-void SpiritCalibrationSetVcoWindow(VcoWin xRefWord)
-{
-  uint8_t tempRegValue;
-
-  /* Check the parameters */
-  s_assert_param(IS_VCO_WIN(xRefWord));
-
-  /* Reads the register value */
-  g_xStatus = SpiritSpiReadRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue);
-
-  /* Build the values to be written */
-  tempRegValue &= 0xFC;
-  tempRegValue |= xRefWord;
-
-  /* Writes the new value of VCO calibration window */
-  g_xStatus = SpiritSpiWriteRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue);
-
-}
-
-
-/**
- * @brief  Returns the VCO calibration window.
- * @param  None.
- * @retval VcoWin Value of REFWORD corresponding to the Ref_period according to the formula: CALIBRATION_WIN = 11*Ref_period/fxo.
- *         This parameter can be a value of @ref VcoWin.
- */
-VcoWin SpiritCalibrationGetVcoWindow(void)
-{
-  uint8_t tempRegValue1, tempRegValue2;
-  VcoWin refWord;
-
-  /* Reads the register containing the REFWORD value */
-  g_xStatus = SpiritSpiReadRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue1);
-
-  /* Reads the Xtal configuration */
-  g_xStatus = SpiritSpiReadRegisters(ANA_FUNC_CONF0_BASE, 1, &tempRegValue2);
-
-  /* Mask the REFWORD field */
-  tempRegValue1 &= 0x03;
-
-  /* Mask the 24_26_MHz_SELECT field */
-  tempRegValue2 = ((tempRegValue2 & 0x40)>>6);
-
-  /* In case of 26 MHz crystal */
-  if(tempRegValue2)
-  {
-    switch(tempRegValue1)
-    {
-    case 0:
-      refWord = CALIB_TIME_6_77_US_26MHZ;
-      break;
-    case 1:
-      refWord = CALIB_TIME_13_54_US_26MHZ;
-      break;
-    case 2:
-      refWord = CALIB_TIME_27_08_US_26MHZ;
-      break;
-    case 3:
-      refWord = CALIB_TIME_54_15_US_26MHZ;
-      break;
-    }
-  }
-
-  /* In case of 24 MHz crystal */
-  else
-  {
-    switch(tempRegValue1)
-    {
-    case 0:
-      refWord = CALIB_TIME_7_33_US_24MHZ;
-      break;
-    case 1:
-      refWord = CALIB_TIME_14_67_US_24MHZ;
-      break;
-    case 2:
-      refWord = CALIB_TIME_29_33_US_24MHZ;
-      break;
-    case 3:
-      refWord = CALIB_TIME_58_67_US_24MHZ;
-      break;
-    }
-  }
-
-  return refWord;
-
-}
-
-/**
- * @brief  Selects a VCO.
- * @param  xVco can be VCO_H or VCO_L according to which VCO select.
- *         This parameter can be a value of @ref VcoSel.
- * @retval None.
- */
-void SpiritCalibrationSelectVco(VcoSel xVco)
-{
-  uint8_t tempRegValue;
-  
-  /* Check the parameter */
-  s_assert_param(IS_VCO_SEL(xVco));
-  
-  SpiritSpiReadRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue);
-  
-  tempRegValue &= 0xF9;
-  
-  if(xVco == VCO_H)
-  {
-    tempRegValue |= 0x02;
-    
-  }
-  else
-  {
-    tempRegValue |= 0x04;
-  }
-  SpiritSpiWriteRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue);  
-  
-}
-
-
-
-/**
- * @brief  Returns the VCO selected.
- * @param  void.
- * @retval VCO_H or VCO_L according to which VCO selected.
- *         This parameter can be a value of @ref VcoSel.
- */
-VcoSel SpiritCalibrationGetVcoSelecttion(void)
-{
-  uint8_t tempRegValue;
-  
-  SpiritSpiReadRegisters(SYNTH_CONFIG1_BASE, 1, &tempRegValue);
-  
-  tempRegValue = (tempRegValue>>1)&0x3;
-  
-  if(tempRegValue == 0x01)
-  {
-    return VCO_H;
-    
-  }
-  else
-  {
-    return VCO_L;
-  }
-  
-}
-
-
-/**
- *@}
- */
-
-/**
- *@}
- */
-
-
-/**
- *@}
- */
-
-
-
-/******************* (C) COPYRIGHT 2015 STMicroelectronics *****END OF FILE****/