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

Committer:
Wolfgang Betz
Date:
Tue Nov 22 11:40:10 2016 +0100
Revision:
34:edda6a7238ec
Child:
67:93bec0baf1de
Perform re-naming

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Wolfgang Betz 34:edda6a7238ec 1 /**
Wolfgang Betz 34:edda6a7238ec 2 ******************************************************************************
Wolfgang Betz 34:edda6a7238ec 3 * @file SPIRIT_Commands.h
Wolfgang Betz 34:edda6a7238ec 4 * @author VMA division - AMS
Wolfgang Betz 34:edda6a7238ec 5 * @version 3.2.2
Wolfgang Betz 34:edda6a7238ec 6 * @date 08-July-2015
Wolfgang Betz 34:edda6a7238ec 7 * @brief Management of SPIRIT Commands.
Wolfgang Betz 34:edda6a7238ec 8 *
Wolfgang Betz 34:edda6a7238ec 9 * @details
Wolfgang Betz 34:edda6a7238ec 10 *
Wolfgang Betz 34:edda6a7238ec 11 * In this module can be found all the API used to strobe commands to
Wolfgang Betz 34:edda6a7238ec 12 * Spirit.
Wolfgang Betz 34:edda6a7238ec 13 * Every command strobe is an SPI transaction with a specific command code.
Wolfgang Betz 34:edda6a7238ec 14 *
Wolfgang Betz 34:edda6a7238ec 15 * <b>Example:</b>
Wolfgang Betz 34:edda6a7238ec 16 * @code
Wolfgang Betz 34:edda6a7238ec 17 * ...
Wolfgang Betz 34:edda6a7238ec 18 *
Wolfgang Betz 34:edda6a7238ec 19 * SpiritCmdStrobeRx();
Wolfgang Betz 34:edda6a7238ec 20 *
Wolfgang Betz 34:edda6a7238ec 21 * ...
Wolfgang Betz 34:edda6a7238ec 22 * @endcode
Wolfgang Betz 34:edda6a7238ec 23 *
Wolfgang Betz 34:edda6a7238ec 24 *
Wolfgang Betz 34:edda6a7238ec 25 * @attention
Wolfgang Betz 34:edda6a7238ec 26 *
Wolfgang Betz 34:edda6a7238ec 27 * <h2><center>&copy; COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
Wolfgang Betz 34:edda6a7238ec 28 *
Wolfgang Betz 34:edda6a7238ec 29 * Redistribution and use in source and binary forms, with or without modification,
Wolfgang Betz 34:edda6a7238ec 30 * are permitted provided that the following conditions are met:
Wolfgang Betz 34:edda6a7238ec 31 * 1. Redistributions of source code must retain the above copyright notice,
Wolfgang Betz 34:edda6a7238ec 32 * this list of conditions and the following disclaimer.
Wolfgang Betz 34:edda6a7238ec 33 * 2. Redistributions in binary form must reproduce the above copyright notice,
Wolfgang Betz 34:edda6a7238ec 34 * this list of conditions and the following disclaimer in the documentation
Wolfgang Betz 34:edda6a7238ec 35 * and/or other materials provided with the distribution.
Wolfgang Betz 34:edda6a7238ec 36 * 3. Neither the name of STMicroelectronics nor the names of its contributors
Wolfgang Betz 34:edda6a7238ec 37 * may be used to endorse or promote products derived from this software
Wolfgang Betz 34:edda6a7238ec 38 * without specific prior written permission.
Wolfgang Betz 34:edda6a7238ec 39 *
Wolfgang Betz 34:edda6a7238ec 40 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Wolfgang Betz 34:edda6a7238ec 41 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Wolfgang Betz 34:edda6a7238ec 42 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Wolfgang Betz 34:edda6a7238ec 43 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
Wolfgang Betz 34:edda6a7238ec 44 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Wolfgang Betz 34:edda6a7238ec 45 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Wolfgang Betz 34:edda6a7238ec 46 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Wolfgang Betz 34:edda6a7238ec 47 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Wolfgang Betz 34:edda6a7238ec 48 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Wolfgang Betz 34:edda6a7238ec 49 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Wolfgang Betz 34:edda6a7238ec 50 *
Wolfgang Betz 34:edda6a7238ec 51 ******************************************************************************
Wolfgang Betz 34:edda6a7238ec 52 */
Wolfgang Betz 34:edda6a7238ec 53
Wolfgang Betz 34:edda6a7238ec 54 /* Define to prevent recursive inclusion -------------------------------------*/
Wolfgang Betz 34:edda6a7238ec 55 #ifndef __SPIRIT_COMMANDS_H
Wolfgang Betz 34:edda6a7238ec 56 #define __SPIRIT_COMMANDS_H
Wolfgang Betz 34:edda6a7238ec 57
Wolfgang Betz 34:edda6a7238ec 58
Wolfgang Betz 34:edda6a7238ec 59 /* Includes ------------------------------------------------------------------*/
Wolfgang Betz 34:edda6a7238ec 60
Wolfgang Betz 34:edda6a7238ec 61 #include "SPIRIT_Regs.h"
Wolfgang Betz 34:edda6a7238ec 62 #include "SPIRIT_Types.h"
Wolfgang Betz 34:edda6a7238ec 63
Wolfgang Betz 34:edda6a7238ec 64
Wolfgang Betz 34:edda6a7238ec 65 #ifdef __cplusplus
Wolfgang Betz 34:edda6a7238ec 66 extern "C" {
Wolfgang Betz 34:edda6a7238ec 67 #endif
Wolfgang Betz 34:edda6a7238ec 68
Wolfgang Betz 34:edda6a7238ec 69
Wolfgang Betz 34:edda6a7238ec 70 /**
Wolfgang Betz 34:edda6a7238ec 71 * @addtogroup SPIRIT_Libraries
Wolfgang Betz 34:edda6a7238ec 72 * @{
Wolfgang Betz 34:edda6a7238ec 73 */
Wolfgang Betz 34:edda6a7238ec 74
Wolfgang Betz 34:edda6a7238ec 75
Wolfgang Betz 34:edda6a7238ec 76 /**
Wolfgang Betz 34:edda6a7238ec 77 * @defgroup SPIRIT_Commands Commands
Wolfgang Betz 34:edda6a7238ec 78 * @brief Management of SPIRIT Commands.
Wolfgang Betz 34:edda6a7238ec 79 * @details See the file <i>@ref SPIRIT_Commands.h</i> for more details.
Wolfgang Betz 34:edda6a7238ec 80 * @{
Wolfgang Betz 34:edda6a7238ec 81 */
Wolfgang Betz 34:edda6a7238ec 82
Wolfgang Betz 34:edda6a7238ec 83 /**
Wolfgang Betz 34:edda6a7238ec 84 * @defgroup Commands_Exported_Types Commands Exported Types
Wolfgang Betz 34:edda6a7238ec 85 * @{
Wolfgang Betz 34:edda6a7238ec 86 */
Wolfgang Betz 34:edda6a7238ec 87
Wolfgang Betz 34:edda6a7238ec 88 /**
Wolfgang Betz 34:edda6a7238ec 89 * @brief SPIRIT Commands codes enumeration
Wolfgang Betz 34:edda6a7238ec 90 */
Wolfgang Betz 34:edda6a7238ec 91 typedef enum
Wolfgang Betz 34:edda6a7238ec 92 {
Wolfgang Betz 34:edda6a7238ec 93 CMD_TX = COMMAND_TX, /*!< Start to transmit; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 94 CMD_RX = COMMAND_RX, /*!< Start to receive; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 95 CMD_READY = COMMAND_READY, /*!< Go to READY; valid only from STANDBY or SLEEP or LOCK */
Wolfgang Betz 34:edda6a7238ec 96 CMD_STANDBY = COMMAND_STANDBY, /*!< Go to STANDBY; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 97 CMD_SLEEP = COMMAND_SLEEP, /*!< Go to SLEEP; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 98 CMD_LOCKRX = COMMAND_LOCKRX, /*!< Go to LOCK state by using the RX configuration of the synth; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 99 CMD_LOCKTX = COMMAND_LOCKTX, /*!< Go to LOCK state by using the TX configuration of the synth; valid only from READY */
Wolfgang Betz 34:edda6a7238ec 100 CMD_SABORT = COMMAND_SABORT, /*!< Force exit form TX or RX states and go to READY state; valid only from TX or RX */
Wolfgang Betz 34:edda6a7238ec 101 CMD_LDC_RELOAD = COMMAND_LDC_RELOAD, /*!< LDC Mode: Reload the LDC timer with the value stored in the LDC_PRESCALER / COUNTER registers; valid from all states */
Wolfgang Betz 34:edda6a7238ec 102 CMD_SEQUENCE_UPDATE = COMMAND_SEQUENCE_UPDATE, /*!< Autoretransmission: Reload the Packet sequence counter with the value stored in the PROTOCOL[2] register valid from all states */
Wolfgang Betz 34:edda6a7238ec 103 CMD_AES_ENC = COMMAND_AES_ENC, /*!< Commands: Start the encryption routine; valid from all states; valid from all states */
Wolfgang Betz 34:edda6a7238ec 104 CMD_AES_KEY = COMMAND_AES_KEY, /*!< Commands: Start the procedure to compute the key for the decryption; valid from all states */
Wolfgang Betz 34:edda6a7238ec 105 CMD_AES_DEC = COMMAND_AES_DEC, /*!< Commands: Start the decryption routine using the current key; valid from all states */
Wolfgang Betz 34:edda6a7238ec 106 CMD_AES_KEY_DEC = COMMAND_AES_KEY_DEC, /*!< Commands: Compute the key and start the decryption; valid from all states */
Wolfgang Betz 34:edda6a7238ec 107 CMD_SRES = COMMAND_SRES, /*!< Reset of all digital part, except SPI registers */
Wolfgang Betz 34:edda6a7238ec 108 CMD_FLUSHRXFIFO = COMMAND_FLUSHRXFIFO, /*!< Clean the RX FIFO; valid from all states */
Wolfgang Betz 34:edda6a7238ec 109 CMD_FLUSHTXFIFO = COMMAND_FLUSHTXFIFO, /*!< Clean the TX FIFO; valid from all states */
Wolfgang Betz 34:edda6a7238ec 110 } SpiritCmd;
Wolfgang Betz 34:edda6a7238ec 111
Wolfgang Betz 34:edda6a7238ec 112 #define IS_SPIRIT_CMD(CMD) (CMD == CMD_TX || \
Wolfgang Betz 34:edda6a7238ec 113 CMD == CMD_RX || \
Wolfgang Betz 34:edda6a7238ec 114 CMD == CMD_READY || \
Wolfgang Betz 34:edda6a7238ec 115 CMD == CMD_STANDBY || \
Wolfgang Betz 34:edda6a7238ec 116 CMD == CMD_SLEEP || \
Wolfgang Betz 34:edda6a7238ec 117 CMD == CMD_LOCKRX || \
Wolfgang Betz 34:edda6a7238ec 118 CMD == CMD_LOCKTX || \
Wolfgang Betz 34:edda6a7238ec 119 CMD == CMD_SABORT || \
Wolfgang Betz 34:edda6a7238ec 120 CMD == CMD_LDC_RELOAD || \
Wolfgang Betz 34:edda6a7238ec 121 CMD == CMD_SEQUENCE_UPDATE || \
Wolfgang Betz 34:edda6a7238ec 122 CMD == CMD_AES_ENC || \
Wolfgang Betz 34:edda6a7238ec 123 CMD == CMD_AES_KEY || \
Wolfgang Betz 34:edda6a7238ec 124 CMD == CMD_AES_DEC || \
Wolfgang Betz 34:edda6a7238ec 125 CMD == CMD_AES_KEY_DEC || \
Wolfgang Betz 34:edda6a7238ec 126 CMD == CMD_SRES || \
Wolfgang Betz 34:edda6a7238ec 127 CMD == CMD_FLUSHRXFIFO || \
Wolfgang Betz 34:edda6a7238ec 128 CMD == CMD_FLUSHTXFIFO \
Wolfgang Betz 34:edda6a7238ec 129 )
Wolfgang Betz 34:edda6a7238ec 130
Wolfgang Betz 34:edda6a7238ec 131 /**
Wolfgang Betz 34:edda6a7238ec 132 * @}
Wolfgang Betz 34:edda6a7238ec 133 */
Wolfgang Betz 34:edda6a7238ec 134
Wolfgang Betz 34:edda6a7238ec 135
Wolfgang Betz 34:edda6a7238ec 136 /**
Wolfgang Betz 34:edda6a7238ec 137 * @defgroup Commands_Exported_Constants Commands Exported Constants
Wolfgang Betz 34:edda6a7238ec 138 * @{
Wolfgang Betz 34:edda6a7238ec 139 */
Wolfgang Betz 34:edda6a7238ec 140
Wolfgang Betz 34:edda6a7238ec 141
Wolfgang Betz 34:edda6a7238ec 142 /**
Wolfgang Betz 34:edda6a7238ec 143 * @}
Wolfgang Betz 34:edda6a7238ec 144 */
Wolfgang Betz 34:edda6a7238ec 145
Wolfgang Betz 34:edda6a7238ec 146
Wolfgang Betz 34:edda6a7238ec 147 /**
Wolfgang Betz 34:edda6a7238ec 148 * @defgroup Commands_Exported_Macros Commands Exported Macros
Wolfgang Betz 34:edda6a7238ec 149 * @{
Wolfgang Betz 34:edda6a7238ec 150 */
Wolfgang Betz 34:edda6a7238ec 151
Wolfgang Betz 34:edda6a7238ec 152 /**
Wolfgang Betz 34:edda6a7238ec 153 * @brief Sends the TX command to SPIRIT. Start to transmit.
Wolfgang Betz 34:edda6a7238ec 154 * @param None.
Wolfgang Betz 34:edda6a7238ec 155 * @retval None.
Wolfgang Betz 34:edda6a7238ec 156 */
Wolfgang Betz 34:edda6a7238ec 157 #define SpiritCmdStrobeTx() {SpiritManagementWaCmdStrobeTx(); \
Wolfgang Betz 34:edda6a7238ec 158 SpiritCmdStrobeCommand(CMD_TX);}
Wolfgang Betz 34:edda6a7238ec 159
Wolfgang Betz 34:edda6a7238ec 160
Wolfgang Betz 34:edda6a7238ec 161 /**
Wolfgang Betz 34:edda6a7238ec 162 * @brief Sends the RX command to SPIRIT. Start to receive.
Wolfgang Betz 34:edda6a7238ec 163 * @param None.
Wolfgang Betz 34:edda6a7238ec 164 * @retval None.
Wolfgang Betz 34:edda6a7238ec 165 */
Wolfgang Betz 34:edda6a7238ec 166 #define SpiritCmdStrobeRx() {SpiritManagementWaCmdStrobeRx(); \
Wolfgang Betz 34:edda6a7238ec 167 SpiritCmdStrobeCommand(CMD_RX); \
Wolfgang Betz 34:edda6a7238ec 168 }
Wolfgang Betz 34:edda6a7238ec 169
Wolfgang Betz 34:edda6a7238ec 170
Wolfgang Betz 34:edda6a7238ec 171 /**
Wolfgang Betz 34:edda6a7238ec 172 * @brief Sends the Ready state command to SPIRIT. Go to READY.
Wolfgang Betz 34:edda6a7238ec 173 * @param None.
Wolfgang Betz 34:edda6a7238ec 174 * @retval None.
Wolfgang Betz 34:edda6a7238ec 175 */
Wolfgang Betz 34:edda6a7238ec 176 #define SpiritCmdStrobeReady() SpiritCmdStrobeCommand(CMD_READY)
Wolfgang Betz 34:edda6a7238ec 177
Wolfgang Betz 34:edda6a7238ec 178
Wolfgang Betz 34:edda6a7238ec 179
Wolfgang Betz 34:edda6a7238ec 180 /**
Wolfgang Betz 34:edda6a7238ec 181 * @brief Sends the Standby command to SPIRIT. Go to STANDBY.
Wolfgang Betz 34:edda6a7238ec 182 * @param None.
Wolfgang Betz 34:edda6a7238ec 183 * @retval None.
Wolfgang Betz 34:edda6a7238ec 184 */
Wolfgang Betz 34:edda6a7238ec 185 #define SpiritCmdStrobeStandby() SpiritCmdStrobeCommand(CMD_STANDBY)
Wolfgang Betz 34:edda6a7238ec 186
Wolfgang Betz 34:edda6a7238ec 187
Wolfgang Betz 34:edda6a7238ec 188
Wolfgang Betz 34:edda6a7238ec 189 /**
Wolfgang Betz 34:edda6a7238ec 190 * @brief Sends the Sleep command to SPIRIT. Go to SLEEP.
Wolfgang Betz 34:edda6a7238ec 191 * @param None.
Wolfgang Betz 34:edda6a7238ec 192 * @retval None.
Wolfgang Betz 34:edda6a7238ec 193 */
Wolfgang Betz 34:edda6a7238ec 194 #define SpiritCmdStrobeSleep() SpiritCmdStrobeCommand(CMD_SLEEP)
Wolfgang Betz 34:edda6a7238ec 195
Wolfgang Betz 34:edda6a7238ec 196
Wolfgang Betz 34:edda6a7238ec 197
Wolfgang Betz 34:edda6a7238ec 198 /**
Wolfgang Betz 34:edda6a7238ec 199 * @brief Sends the LOCK_RX command to SPIRIT. Go to the LOCK state by using the RX configuration of the synthesizer.
Wolfgang Betz 34:edda6a7238ec 200 * @param None.
Wolfgang Betz 34:edda6a7238ec 201 * @retval None.
Wolfgang Betz 34:edda6a7238ec 202 */
Wolfgang Betz 34:edda6a7238ec 203 #define SpiritCmdStrobeLockRx() SpiritCmdStrobeCommand(CMD_LOCKRX)
Wolfgang Betz 34:edda6a7238ec 204
Wolfgang Betz 34:edda6a7238ec 205
Wolfgang Betz 34:edda6a7238ec 206
Wolfgang Betz 34:edda6a7238ec 207 /**
Wolfgang Betz 34:edda6a7238ec 208 * @brief Sends the LOCK_TX command to SPIRIT. Go to the LOCK state by using the TX configuration of the synthesizer.
Wolfgang Betz 34:edda6a7238ec 209 * @param None.
Wolfgang Betz 34:edda6a7238ec 210 * @retval None.
Wolfgang Betz 34:edda6a7238ec 211 */
Wolfgang Betz 34:edda6a7238ec 212 #define SpiritCmdStrobeLockTx() SpiritCmdStrobeCommand(CMD_LOCKTX)
Wolfgang Betz 34:edda6a7238ec 213
Wolfgang Betz 34:edda6a7238ec 214
Wolfgang Betz 34:edda6a7238ec 215
Wolfgang Betz 34:edda6a7238ec 216 /**
Wolfgang Betz 34:edda6a7238ec 217 * @brief Sends the SABORT command to SPIRIT. Exit from TX or RX states and go to READY state.
Wolfgang Betz 34:edda6a7238ec 218 * @param None.
Wolfgang Betz 34:edda6a7238ec 219 * @retval None.
Wolfgang Betz 34:edda6a7238ec 220 */
Wolfgang Betz 34:edda6a7238ec 221 #define SpiritCmdStrobeSabort() SpiritCmdStrobeCommand(CMD_SABORT)
Wolfgang Betz 34:edda6a7238ec 222
Wolfgang Betz 34:edda6a7238ec 223
Wolfgang Betz 34:edda6a7238ec 224 /**
Wolfgang Betz 34:edda6a7238ec 225 * @brief Sends the LDC_RELOAD command to SPIRIT. Reload the LDC timer with the value stored in the LDC_PRESCALER / COUNTER registers.
Wolfgang Betz 34:edda6a7238ec 226 * @param None.
Wolfgang Betz 34:edda6a7238ec 227 * @retval None.
Wolfgang Betz 34:edda6a7238ec 228 */
Wolfgang Betz 34:edda6a7238ec 229 #define SpiritCmdStrobeLdcReload() SpiritCmdStrobeCommand(CMD_LDC_RELOAD)
Wolfgang Betz 34:edda6a7238ec 230
Wolfgang Betz 34:edda6a7238ec 231
Wolfgang Betz 34:edda6a7238ec 232
Wolfgang Betz 34:edda6a7238ec 233 /**
Wolfgang Betz 34:edda6a7238ec 234 * @brief Sends the SEQUENCE_UPDATE command to SPIRIT. Reload the Packet sequence counter with the value stored in the PROTOCOL[2] register.
Wolfgang Betz 34:edda6a7238ec 235 * @param None.
Wolfgang Betz 34:edda6a7238ec 236 * @retval None.
Wolfgang Betz 34:edda6a7238ec 237 */
Wolfgang Betz 34:edda6a7238ec 238 #define SpiritCmdStrobeSequenceUpdate() SpiritCmdStrobeCommand(CMD_SEQUENCE_UPDATE)
Wolfgang Betz 34:edda6a7238ec 239
Wolfgang Betz 34:edda6a7238ec 240
Wolfgang Betz 34:edda6a7238ec 241
Wolfgang Betz 34:edda6a7238ec 242 /**
Wolfgang Betz 34:edda6a7238ec 243 * @brief Sends the AES_ENC command to SPIRIT. Starts the encryption routine.
Wolfgang Betz 34:edda6a7238ec 244 * @param None.
Wolfgang Betz 34:edda6a7238ec 245 * @retval None.
Wolfgang Betz 34:edda6a7238ec 246 */
Wolfgang Betz 34:edda6a7238ec 247 #define SpiritCmdStrobeAesEnc() SpiritCmdStrobeCommand(CMD_AES_ENC)
Wolfgang Betz 34:edda6a7238ec 248
Wolfgang Betz 34:edda6a7238ec 249
Wolfgang Betz 34:edda6a7238ec 250
Wolfgang Betz 34:edda6a7238ec 251 /**
Wolfgang Betz 34:edda6a7238ec 252 * @brief Sends the AES_KEY command to SPIRIT. Starts the procedure to compute the key for the decryption.
Wolfgang Betz 34:edda6a7238ec 253 * @param None.
Wolfgang Betz 34:edda6a7238ec 254 * @retval None.
Wolfgang Betz 34:edda6a7238ec 255 */
Wolfgang Betz 34:edda6a7238ec 256 #define SpiritCmdStrobeAesKey() SpiritCmdStrobeCommand(CMD_AES_KEY)
Wolfgang Betz 34:edda6a7238ec 257
Wolfgang Betz 34:edda6a7238ec 258
Wolfgang Betz 34:edda6a7238ec 259
Wolfgang Betz 34:edda6a7238ec 260 /**
Wolfgang Betz 34:edda6a7238ec 261 * @brief Sends the AES_DEC command to SPIRIT. Starts the decryption using the current key.
Wolfgang Betz 34:edda6a7238ec 262 * @param None.
Wolfgang Betz 34:edda6a7238ec 263 * @retval None.
Wolfgang Betz 34:edda6a7238ec 264 */
Wolfgang Betz 34:edda6a7238ec 265 #define SpiritCmdStrobeAesDec() SpiritCmdStrobeCommand(CMD_AES_DEC)
Wolfgang Betz 34:edda6a7238ec 266
Wolfgang Betz 34:edda6a7238ec 267
Wolfgang Betz 34:edda6a7238ec 268
Wolfgang Betz 34:edda6a7238ec 269 /**
Wolfgang Betz 34:edda6a7238ec 270 * @brief Sends the KEY_DEC command to SPIRIT. Computes the key derivation and start the decryption.
Wolfgang Betz 34:edda6a7238ec 271 * @param None.
Wolfgang Betz 34:edda6a7238ec 272 * @retval None.
Wolfgang Betz 34:edda6a7238ec 273 */
Wolfgang Betz 34:edda6a7238ec 274 #define SpiritCmdStrobeAesKeyDec() SpiritCmdStrobeCommand(CMD_AES_KEY_DEC)
Wolfgang Betz 34:edda6a7238ec 275
Wolfgang Betz 34:edda6a7238ec 276 /**
Wolfgang Betz 34:edda6a7238ec 277 * @brief Sends the SRES command to SPIRIT. Partial reset: all digital circuit will be reset (exception for SPI only).
Wolfgang Betz 34:edda6a7238ec 278 * @param None.
Wolfgang Betz 34:edda6a7238ec 279 * @retval None.
Wolfgang Betz 34:edda6a7238ec 280 */
Wolfgang Betz 34:edda6a7238ec 281 #define SpiritCmdStrobeSres() SpiritCmdStrobeCommand(CMD_SRES)
Wolfgang Betz 34:edda6a7238ec 282
Wolfgang Betz 34:edda6a7238ec 283
Wolfgang Betz 34:edda6a7238ec 284 /**
Wolfgang Betz 34:edda6a7238ec 285 * @brief Sends the FLUSHRXFIFO command to SPIRIT. Clean the RX FIFO.
Wolfgang Betz 34:edda6a7238ec 286 * @param None.
Wolfgang Betz 34:edda6a7238ec 287 * @retval None.
Wolfgang Betz 34:edda6a7238ec 288 */
Wolfgang Betz 34:edda6a7238ec 289 #define SpiritCmdStrobeFlushRxFifo() SpiritCmdStrobeCommand(CMD_FLUSHRXFIFO)
Wolfgang Betz 34:edda6a7238ec 290
Wolfgang Betz 34:edda6a7238ec 291
Wolfgang Betz 34:edda6a7238ec 292
Wolfgang Betz 34:edda6a7238ec 293 /**
Wolfgang Betz 34:edda6a7238ec 294 * @brief Sends the FLUSHTXFIFO command to SPIRIT. Clean the TX FIFO.
Wolfgang Betz 34:edda6a7238ec 295 * @param None.
Wolfgang Betz 34:edda6a7238ec 296 * @retval None.
Wolfgang Betz 34:edda6a7238ec 297 */
Wolfgang Betz 34:edda6a7238ec 298 #define SpiritCmdStrobeFlushTxFifo() SpiritCmdStrobeCommand(CMD_FLUSHTXFIFO)
Wolfgang Betz 34:edda6a7238ec 299
Wolfgang Betz 34:edda6a7238ec 300
Wolfgang Betz 34:edda6a7238ec 301
Wolfgang Betz 34:edda6a7238ec 302 /**
Wolfgang Betz 34:edda6a7238ec 303 * @}
Wolfgang Betz 34:edda6a7238ec 304 */
Wolfgang Betz 34:edda6a7238ec 305
Wolfgang Betz 34:edda6a7238ec 306
Wolfgang Betz 34:edda6a7238ec 307 /**
Wolfgang Betz 34:edda6a7238ec 308 * @defgroup Commands_Exported_Functions Commands Exported Functions
Wolfgang Betz 34:edda6a7238ec 309 * @{
Wolfgang Betz 34:edda6a7238ec 310 */
Wolfgang Betz 34:edda6a7238ec 311 void SpiritCmdStrobeCommand(SpiritCmd xCommandCode);
Wolfgang Betz 34:edda6a7238ec 312
Wolfgang Betz 34:edda6a7238ec 313
Wolfgang Betz 34:edda6a7238ec 314 /**
Wolfgang Betz 34:edda6a7238ec 315 * @}
Wolfgang Betz 34:edda6a7238ec 316 */
Wolfgang Betz 34:edda6a7238ec 317
Wolfgang Betz 34:edda6a7238ec 318 /**
Wolfgang Betz 34:edda6a7238ec 319 * @}
Wolfgang Betz 34:edda6a7238ec 320 */
Wolfgang Betz 34:edda6a7238ec 321
Wolfgang Betz 34:edda6a7238ec 322
Wolfgang Betz 34:edda6a7238ec 323 /**
Wolfgang Betz 34:edda6a7238ec 324 * @}
Wolfgang Betz 34:edda6a7238ec 325 */
Wolfgang Betz 34:edda6a7238ec 326
Wolfgang Betz 34:edda6a7238ec 327
Wolfgang Betz 34:edda6a7238ec 328
Wolfgang Betz 34:edda6a7238ec 329
Wolfgang Betz 34:edda6a7238ec 330 #ifdef __cplusplus
Wolfgang Betz 34:edda6a7238ec 331 }
Wolfgang Betz 34:edda6a7238ec 332 #endif
Wolfgang Betz 34:edda6a7238ec 333
Wolfgang Betz 34:edda6a7238ec 334 #endif
Wolfgang Betz 34:edda6a7238ec 335
Wolfgang Betz 34:edda6a7238ec 336 /******************* (C) COPYRIGHT 2015 STMicroelectronics *****END OF FILE****/