2 ******************************************************************************
3 * @file stm32f7xx_hal_spi.c
4 * @author MCD Application Team
5 * @brief SPI HAL module driver.
6 * This file provides firmware functions to manage the following
7 * functionalities of the Serial Peripheral Interface (SPI) peripheral:
8 * + Initialization and de-initialization functions
9 * + IO operation functions
10 * + Peripheral Control functions
11 * + Peripheral State functions
14 ==============================================================================
15 ##### How to use this driver #####
16 ==============================================================================
18 The SPI HAL driver can be used as follows:
20 (#) Declare a SPI_HandleTypeDef handle structure, for example:
21 SPI_HandleTypeDef hspi;
23 (#)Initialize the SPI low level resources by implementing the HAL_SPI_MspInit() API:
24 (##) Enable the SPIx interface clock
25 (##) SPI pins configuration
26 (+++) Enable the clock for the SPI GPIOs
27 (+++) Configure these SPI pins as alternate function push-pull
28 (##) NVIC configuration if you need to use interrupt process
29 (+++) Configure the SPIx interrupt priority
30 (+++) Enable the NVIC SPI IRQ handle
31 (##) DMA Configuration if you need to use DMA process
32 (+++) Declare a DMA_HandleTypeDef handle structure for the transmit or receive Stream/Channel
33 (+++) Enable the DMAx clock
34 (+++) Configure the DMA handle parameters
35 (+++) Configure the DMA Tx or Rx Stream/Channel
36 (+++) Associate the initialized hdma_tx(or _rx) handle to the hspi DMA Tx or Rx handle
37 (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on the DMA Tx or Rx Stream/Channel
39 (#) Program the Mode, BidirectionalMode , Data size, Baudrate Prescaler, NSS
40 management, Clock polarity and phase, FirstBit and CRC configuration in the hspi Init structure.
42 (#) Initialize the SPI registers by calling the HAL_SPI_Init() API:
43 (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc)
44 by calling the customized HAL_SPI_MspInit() API.
46 Circular mode restriction:
47 (#) The DMA circular mode cannot be used when the SPI is configured in these modes:
48 (##) Master 2Lines RxOnly
50 (#) The CRC feature is not managed when the DMA circular mode is enabled
51 (#) When the SPI DMA Pause/Stop features are used, we must use the following APIs
52 the HAL_SPI_DMAPause()/ HAL_SPI_DMAStop() only under the SPI callbacks
54 Master Receive mode restriction:
55 (#) In Master unidirectional receive-only mode (MSTR =1, BIDIMODE=0, RXONLY=1) or
56 bidirectional receive mode (MSTR=1, BIDIMODE=1, BIDIOE=0), to ensure that the SPI
57 does not initiate a new transfer the following procedure has to be respected:
61 Callback registration:
63 (#) The compilation flag USE_HAL_SPI_REGISTER_CALLBACKS when set to 1U
64 allows the user to configure dynamically the driver callbacks.
65 Use Functions HAL_SPI_RegisterCallback() to register an interrupt callback.
67 Function HAL_SPI_RegisterCallback() allows to register following callbacks:
68 (+) TxCpltCallback : SPI Tx Completed callback
69 (+) RxCpltCallback : SPI Rx Completed callback
70 (+) TxRxCpltCallback : SPI TxRx Completed callback
71 (+) TxHalfCpltCallback : SPI Tx Half Completed callback
72 (+) RxHalfCpltCallback : SPI Rx Half Completed callback
73 (+) TxRxHalfCpltCallback : SPI TxRx Half Completed callback
74 (+) ErrorCallback : SPI Error callback
75 (+) AbortCpltCallback : SPI Abort callback
76 (+) MspInitCallback : SPI Msp Init callback
77 (+) MspDeInitCallback : SPI Msp DeInit callback
78 This function takes as parameters the HAL peripheral handle, the Callback ID
79 and a pointer to the user callback function.
82 (#) Use function HAL_SPI_UnRegisterCallback to reset a callback to the default
84 HAL_SPI_UnRegisterCallback takes as parameters the HAL peripheral handle,
86 This function allows to reset following callbacks:
87 (+) TxCpltCallback : SPI Tx Completed callback
88 (+) RxCpltCallback : SPI Rx Completed callback
89 (+) TxRxCpltCallback : SPI TxRx Completed callback
90 (+) TxHalfCpltCallback : SPI Tx Half Completed callback
91 (+) RxHalfCpltCallback : SPI Rx Half Completed callback
92 (+) TxRxHalfCpltCallback : SPI TxRx Half Completed callback
93 (+) ErrorCallback : SPI Error callback
94 (+) AbortCpltCallback : SPI Abort callback
95 (+) MspInitCallback : SPI Msp Init callback
96 (+) MspDeInitCallback : SPI Msp DeInit callback
98 By default, after the HAL_SPI_Init() and when the state is HAL_SPI_STATE_RESET
99 all callbacks are set to the corresponding weak functions:
100 examples HAL_SPI_MasterTxCpltCallback(), HAL_SPI_MasterRxCpltCallback().
101 Exception done for MspInit and MspDeInit functions that are
102 reset to the legacy weak functions in the HAL_SPI_Init()/ HAL_SPI_DeInit() only when
103 these callbacks are null (not registered beforehand).
104 If MspInit or MspDeInit are not null, the HAL_SPI_Init()/ HAL_SPI_DeInit()
105 keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state.
107 Callbacks can be registered/unregistered in HAL_SPI_STATE_READY state only.
108 Exception done MspInit/MspDeInit functions that can be registered/unregistered
109 in HAL_SPI_STATE_READY or HAL_SPI_STATE_RESET state,
110 thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit.
111 Then, the user first registers the MspInit/MspDeInit user callbacks
112 using HAL_SPI_RegisterCallback() before calling HAL_SPI_DeInit()
113 or HAL_SPI_Init() function.
115 When The compilation define USE_HAL_PPP_REGISTER_CALLBACKS is set to 0 or
116 not defined, the callback registering feature is not available
117 and weak (surcharged) callbacks are used.
120 Using the HAL it is not possible to reach all supported SPI frequency with the different SPI Modes,
121 the following table resume the max SPI frequency reached with data size 8bits/16bits,
122 according to frequency of the APBx Peripheral Clock (fPCLK) used by the SPI instance.
128 DataSize = SPI_DATASIZE_8BIT:
129 +----------------------------------------------------------------------------------------------+
130 | | | 2Lines Fullduplex | 2Lines RxOnly | 1Line |
131 | Process | Tranfert mode |---------------------|----------------------|----------------------|
132 | | | Master | Slave | Master | Slave | Master | Slave |
133 |==============================================================================================|
134 | T | Polling | Fpclk/4 | Fpclk/8 | NA | NA | NA | NA |
135 | X |----------------|----------|----------|-----------|----------|-----------|----------|
136 | / | Interrupt | Fpclk/4 | Fpclk/16 | NA | NA | NA | NA |
137 | R |----------------|----------|----------|-----------|----------|-----------|----------|
138 | X | DMA | Fpclk/2 | Fpclk/2 | NA | NA | NA | NA |
139 |=========|================|==========|==========|===========|==========|===========|==========|
140 | | Polling | Fpclk/4 | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 |
141 | |----------------|----------|----------|-----------|----------|-----------|----------|
142 | R | Interrupt | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | Fpclk/4 |
143 | X |----------------|----------|----------|-----------|----------|-----------|----------|
144 | | DMA | Fpclk/4 | Fpclk/2 | Fpclk/2 | Fpclk/16 | Fpclk/2 | Fpclk/16 |
145 |=========|================|==========|==========|===========|==========|===========|==========|
146 | | Polling | Fpclk/8 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/8 |
147 | |----------------|----------|----------|-----------|----------|-----------|----------|
148 | T | Interrupt | Fpclk/2 | Fpclk/4 | NA | NA | Fpclk/16 | Fpclk/8 |
149 | X |----------------|----------|----------|-----------|----------|-----------|----------|
150 | | DMA | Fpclk/2 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/16 |
151 +----------------------------------------------------------------------------------------------+
153 DataSize = SPI_DATASIZE_16BIT:
154 +----------------------------------------------------------------------------------------------+
155 | | | 2Lines Fullduplex | 2Lines RxOnly | 1Line |
156 | Process | Tranfert mode |---------------------|----------------------|----------------------|
157 | | | Master | Slave | Master | Slave | Master | Slave |
158 |==============================================================================================|
159 | T | Polling | Fpclk/4 | Fpclk/8 | NA | NA | NA | NA |
160 | X |----------------|----------|----------|-----------|----------|-----------|----------|
161 | / | Interrupt | Fpclk/4 | Fpclk/16 | NA | NA | NA | NA |
162 | R |----------------|----------|----------|-----------|----------|-----------|----------|
163 | X | DMA | Fpclk/2 | Fpclk/2 | NA | NA | NA | NA |
164 |=========|================|==========|==========|===========|==========|===========|==========|
165 | | Polling | Fpclk/4 | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 |
166 | |----------------|----------|----------|-----------|----------|-----------|----------|
167 | R | Interrupt | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | Fpclk/4 |
168 | X |----------------|----------|----------|-----------|----------|-----------|----------|
169 | | DMA | Fpclk/4 | Fpclk/2 | Fpclk/2 | Fpclk/16 | Fpclk/2 | Fpclk/16 |
170 |=========|================|==========|==========|===========|==========|===========|==========|
171 | | Polling | Fpclk/8 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/8 |
172 | |----------------|----------|----------|-----------|----------|-----------|----------|
173 | T | Interrupt | Fpclk/2 | Fpclk/4 | NA | NA | Fpclk/16 | Fpclk/8 |
174 | X |----------------|----------|----------|-----------|----------|-----------|----------|
175 | | DMA | Fpclk/2 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/16 |
176 +----------------------------------------------------------------------------------------------+
177 @note The max SPI frequency depend on SPI data size (4bits, 5bits,..., 8bits,...15bits, 16bits),
178 SPI mode(2 Lines fullduplex, 2 lines RxOnly, 1 line TX/RX) and Process mode (Polling, IT, DMA).
180 (#) TX/RX processes are HAL_SPI_TransmitReceive(), HAL_SPI_TransmitReceive_IT() and HAL_SPI_TransmitReceive_DMA()
181 (#) RX processes are HAL_SPI_Receive(), HAL_SPI_Receive_IT() and HAL_SPI_Receive_DMA()
182 (#) TX processes are HAL_SPI_Transmit(), HAL_SPI_Transmit_IT() and HAL_SPI_Transmit_DMA()
184 ******************************************************************************
187 * <h2><center>© Copyright (c) 2017 STMicroelectronics.
188 * All rights reserved.</center></h2>
190 * This software component is licensed by ST under BSD 3-Clause license,
191 * the "License"; You may not use this file except in compliance with the
192 * License. You may obtain a copy of the License at:
193 * opensource.org/licenses/BSD-3-Clause
195 ******************************************************************************
198 /* Includes ------------------------------------------------------------------*/
199 #include "stm32f7xx_hal.h"
201 /** @addtogroup STM32F7xx_HAL_Driver
205 /** @defgroup SPI SPI
206 * @brief SPI HAL module driver
209 #ifdef HAL_SPI_MODULE_ENABLED
211 /* Private typedef -----------------------------------------------------------*/
212 /* Private defines -----------------------------------------------------------*/
213 /** @defgroup SPI_Private_Constants SPI Private Constants
216 #define SPI_DEFAULT_TIMEOUT 100U
221 /* Private macros ------------------------------------------------------------*/
222 /* Private variables ---------------------------------------------------------*/
223 /* Private function prototypes -----------------------------------------------*/
224 /** @defgroup SPI_Private_Functions SPI Private Functions
227 static void SPI_DMATransmitCplt(DMA_HandleTypeDef
*hdma
);
228 static void SPI_DMAReceiveCplt(DMA_HandleTypeDef
*hdma
);
229 static void SPI_DMATransmitReceiveCplt(DMA_HandleTypeDef
*hdma
);
230 static void SPI_DMAHalfTransmitCplt(DMA_HandleTypeDef
*hdma
);
231 static void SPI_DMAHalfReceiveCplt(DMA_HandleTypeDef
*hdma
);
232 static void SPI_DMAHalfTransmitReceiveCplt(DMA_HandleTypeDef
*hdma
);
233 static void SPI_DMAError(DMA_HandleTypeDef
*hdma
);
234 static void SPI_DMAAbortOnError(DMA_HandleTypeDef
*hdma
);
235 static void SPI_DMATxAbortCallback(DMA_HandleTypeDef
*hdma
);
236 static void SPI_DMARxAbortCallback(DMA_HandleTypeDef
*hdma
);
237 static HAL_StatusTypeDef
SPI_WaitFlagStateUntilTimeout(SPI_HandleTypeDef
*hspi
, uint32_t Flag
, FlagStatus State
,
238 uint32_t Timeout
, uint32_t Tickstart
);
239 static HAL_StatusTypeDef
SPI_WaitFifoStateUntilTimeout(SPI_HandleTypeDef
*hspi
, uint32_t Fifo
, uint32_t State
,
240 uint32_t Timeout
, uint32_t Tickstart
);
241 static void SPI_TxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
);
242 static void SPI_TxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
);
243 static void SPI_RxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
);
244 static void SPI_RxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
);
245 static void SPI_2linesRxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
);
246 static void SPI_2linesTxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
);
247 static void SPI_2linesTxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
);
248 static void SPI_2linesRxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
);
249 #if (USE_SPI_CRC != 0U)
250 static void SPI_RxISR_8BITCRC(struct __SPI_HandleTypeDef
*hspi
);
251 static void SPI_RxISR_16BITCRC(struct __SPI_HandleTypeDef
*hspi
);
252 static void SPI_2linesRxISR_8BITCRC(struct __SPI_HandleTypeDef
*hspi
);
253 static void SPI_2linesRxISR_16BITCRC(struct __SPI_HandleTypeDef
*hspi
);
254 #endif /* USE_SPI_CRC */
255 static void SPI_AbortRx_ISR(SPI_HandleTypeDef
*hspi
);
256 static void SPI_AbortTx_ISR(SPI_HandleTypeDef
*hspi
);
257 static void SPI_CloseRxTx_ISR(SPI_HandleTypeDef
*hspi
);
258 static void SPI_CloseRx_ISR(SPI_HandleTypeDef
*hspi
);
259 static void SPI_CloseTx_ISR(SPI_HandleTypeDef
*hspi
);
260 static HAL_StatusTypeDef
SPI_EndRxTransaction(SPI_HandleTypeDef
*hspi
, uint32_t Timeout
, uint32_t Tickstart
);
261 static HAL_StatusTypeDef
SPI_EndRxTxTransaction(SPI_HandleTypeDef
*hspi
, uint32_t Timeout
, uint32_t Tickstart
);
266 /* Exported functions --------------------------------------------------------*/
267 /** @defgroup SPI_Exported_Functions SPI Exported Functions
271 /** @defgroup SPI_Exported_Functions_Group1 Initialization and de-initialization functions
272 * @brief Initialization and Configuration functions
275 ===============================================================================
276 ##### Initialization and de-initialization functions #####
277 ===============================================================================
278 [..] This subsection provides a set of functions allowing to initialize and
279 de-initialize the SPIx peripheral:
281 (+) User must implement HAL_SPI_MspInit() function in which he configures
282 all related peripherals resources (CLOCK, GPIO, DMA, IT and NVIC ).
284 (+) Call the function HAL_SPI_Init() to configure the selected device with
285 the selected configuration:
289 (++) Clock Polarity and Phase
291 (++) BaudRate Prescaler
295 (++) CRC Polynomial if CRC enabled
296 (++) CRC Length, used only with Data8 and Data16
297 (++) FIFO reception threshold
299 (+) Call the function HAL_SPI_DeInit() to restore the default configuration
300 of the selected SPIx peripheral.
307 * @brief Initialize the SPI according to the specified parameters
308 * in the SPI_InitTypeDef and initialize the associated handle.
309 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
310 * the configuration information for SPI module.
313 HAL_StatusTypeDef
HAL_SPI_Init(SPI_HandleTypeDef
*hspi
)
317 /* Check the SPI handle allocation */
323 /* Check the parameters */
324 assert_param(IS_SPI_ALL_INSTANCE(hspi
->Instance
));
325 assert_param(IS_SPI_MODE(hspi
->Init
.Mode
));
326 assert_param(IS_SPI_DIRECTION(hspi
->Init
.Direction
));
327 assert_param(IS_SPI_DATASIZE(hspi
->Init
.DataSize
));
328 assert_param(IS_SPI_NSS(hspi
->Init
.NSS
));
329 assert_param(IS_SPI_NSSP(hspi
->Init
.NSSPMode
));
330 assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi
->Init
.BaudRatePrescaler
));
331 assert_param(IS_SPI_FIRST_BIT(hspi
->Init
.FirstBit
));
332 assert_param(IS_SPI_TIMODE(hspi
->Init
.TIMode
));
333 if (hspi
->Init
.TIMode
== SPI_TIMODE_DISABLE
)
335 assert_param(IS_SPI_CPOL(hspi
->Init
.CLKPolarity
));
336 assert_param(IS_SPI_CPHA(hspi
->Init
.CLKPhase
));
338 #if (USE_SPI_CRC != 0U)
339 assert_param(IS_SPI_CRC_CALCULATION(hspi
->Init
.CRCCalculation
));
340 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
342 assert_param(IS_SPI_CRC_POLYNOMIAL(hspi
->Init
.CRCPolynomial
));
343 assert_param(IS_SPI_CRC_LENGTH(hspi
->Init
.CRCLength
));
346 hspi
->Init
.CRCCalculation
= SPI_CRCCALCULATION_DISABLE
;
347 #endif /* USE_SPI_CRC */
349 if (hspi
->State
== HAL_SPI_STATE_RESET
)
351 /* Allocate lock resource and initialize it */
352 hspi
->Lock
= HAL_UNLOCKED
;
354 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
355 /* Init the SPI Callback settings */
356 hspi
->TxCpltCallback
= HAL_SPI_TxCpltCallback
; /* Legacy weak TxCpltCallback */
357 hspi
->RxCpltCallback
= HAL_SPI_RxCpltCallback
; /* Legacy weak RxCpltCallback */
358 hspi
->TxRxCpltCallback
= HAL_SPI_TxRxCpltCallback
; /* Legacy weak TxRxCpltCallback */
359 hspi
->TxHalfCpltCallback
= HAL_SPI_TxHalfCpltCallback
; /* Legacy weak TxHalfCpltCallback */
360 hspi
->RxHalfCpltCallback
= HAL_SPI_RxHalfCpltCallback
; /* Legacy weak RxHalfCpltCallback */
361 hspi
->TxRxHalfCpltCallback
= HAL_SPI_TxRxHalfCpltCallback
; /* Legacy weak TxRxHalfCpltCallback */
362 hspi
->ErrorCallback
= HAL_SPI_ErrorCallback
; /* Legacy weak ErrorCallback */
363 hspi
->AbortCpltCallback
= HAL_SPI_AbortCpltCallback
; /* Legacy weak AbortCpltCallback */
365 if (hspi
->MspInitCallback
== NULL
)
367 hspi
->MspInitCallback
= HAL_SPI_MspInit
; /* Legacy weak MspInit */
370 /* Init the low level hardware : GPIO, CLOCK, NVIC... */
371 hspi
->MspInitCallback(hspi
);
373 /* Init the low level hardware : GPIO, CLOCK, NVIC... */
374 HAL_SPI_MspInit(hspi
);
375 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
378 hspi
->State
= HAL_SPI_STATE_BUSY
;
380 /* Disable the selected SPI peripheral */
381 __HAL_SPI_DISABLE(hspi
);
383 /* Align by default the rs fifo threshold on the data size */
384 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
386 frxth
= SPI_RXFIFO_THRESHOLD_HF
;
390 frxth
= SPI_RXFIFO_THRESHOLD_QF
;
393 /* CRC calculation is valid only for 16Bit and 8 Bit */
394 if ((hspi
->Init
.DataSize
!= SPI_DATASIZE_16BIT
) && (hspi
->Init
.DataSize
!= SPI_DATASIZE_8BIT
))
396 /* CRC must be disabled */
397 hspi
->Init
.CRCCalculation
= SPI_CRCCALCULATION_DISABLE
;
400 /* Align the CRC Length on the data size */
401 if (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_DATASIZE
)
403 /* CRC Length aligned on the data size : value set by default */
404 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
406 hspi
->Init
.CRCLength
= SPI_CRC_LENGTH_16BIT
;
410 hspi
->Init
.CRCLength
= SPI_CRC_LENGTH_8BIT
;
414 /*----------------------- SPIx CR1 & CR2 Configuration ---------------------*/
415 /* Configure : SPI Mode, Communication Mode, Clock polarity and phase, NSS management,
416 Communication speed, First bit and CRC calculation state */
417 WRITE_REG(hspi
->Instance
->CR1
, (hspi
->Init
.Mode
| hspi
->Init
.Direction
|
418 hspi
->Init
.CLKPolarity
| hspi
->Init
.CLKPhase
| (hspi
->Init
.NSS
& SPI_CR1_SSM
) |
419 hspi
->Init
.BaudRatePrescaler
| hspi
->Init
.FirstBit
| hspi
->Init
.CRCCalculation
));
420 #if (USE_SPI_CRC != 0U)
421 /* Configure : CRC Length */
422 if (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
)
424 hspi
->Instance
->CR1
|= SPI_CR1_CRCL
;
426 #endif /* USE_SPI_CRC */
428 /* Configure : NSS management, TI Mode, NSS Pulse, Data size and Rx Fifo threshold */
429 WRITE_REG(hspi
->Instance
->CR2
, (((hspi
->Init
.NSS
>> 16U) & SPI_CR2_SSOE
) | hspi
->Init
.TIMode
|
430 hspi
->Init
.NSSPMode
| hspi
->Init
.DataSize
) | frxth
);
432 #if (USE_SPI_CRC != 0U)
433 /*---------------------------- SPIx CRCPOLY Configuration ------------------*/
434 /* Configure : CRC Polynomial */
435 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
437 WRITE_REG(hspi
->Instance
->CRCPR
, hspi
->Init
.CRCPolynomial
);
439 #endif /* USE_SPI_CRC */
441 #if defined(SPI_I2SCFGR_I2SMOD)
442 /* Activate the SPI mode (Make sure that I2SMOD bit in I2SCFGR register is reset) */
443 CLEAR_BIT(hspi
->Instance
->I2SCFGR
, SPI_I2SCFGR_I2SMOD
);
444 #endif /* SPI_I2SCFGR_I2SMOD */
446 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
447 hspi
->State
= HAL_SPI_STATE_READY
;
453 * @brief De-Initialize the SPI peripheral.
454 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
455 * the configuration information for SPI module.
458 HAL_StatusTypeDef
HAL_SPI_DeInit(SPI_HandleTypeDef
*hspi
)
460 /* Check the SPI handle allocation */
466 /* Check SPI Instance parameter */
467 assert_param(IS_SPI_ALL_INSTANCE(hspi
->Instance
));
469 hspi
->State
= HAL_SPI_STATE_BUSY
;
471 /* Disable the SPI Peripheral Clock */
472 __HAL_SPI_DISABLE(hspi
);
474 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
475 if (hspi
->MspDeInitCallback
== NULL
)
477 hspi
->MspDeInitCallback
= HAL_SPI_MspDeInit
; /* Legacy weak MspDeInit */
480 /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */
481 hspi
->MspDeInitCallback(hspi
);
483 /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */
484 HAL_SPI_MspDeInit(hspi
);
485 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
487 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
488 hspi
->State
= HAL_SPI_STATE_RESET
;
497 * @brief Initialize the SPI MSP.
498 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
499 * the configuration information for SPI module.
502 __weak
void HAL_SPI_MspInit(SPI_HandleTypeDef
*hspi
)
504 /* Prevent unused argument(s) compilation warning */
507 /* NOTE : This function should not be modified, when the callback is needed,
508 the HAL_SPI_MspInit should be implemented in the user file
513 * @brief De-Initialize the SPI MSP.
514 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
515 * the configuration information for SPI module.
518 __weak
void HAL_SPI_MspDeInit(SPI_HandleTypeDef
*hspi
)
520 /* Prevent unused argument(s) compilation warning */
523 /* NOTE : This function should not be modified, when the callback is needed,
524 the HAL_SPI_MspDeInit should be implemented in the user file
528 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
530 * @brief Register a User SPI Callback
531 * To be used instead of the weak predefined callback
532 * @param hspi Pointer to a SPI_HandleTypeDef structure that contains
533 * the configuration information for the specified SPI.
534 * @param CallbackID ID of the callback to be registered
535 * @param pCallback pointer to the Callback function
538 HAL_StatusTypeDef
HAL_SPI_RegisterCallback(SPI_HandleTypeDef
*hspi
, HAL_SPI_CallbackIDTypeDef CallbackID
, pSPI_CallbackTypeDef pCallback
)
540 HAL_StatusTypeDef status
= HAL_OK
;
542 if (pCallback
== NULL
)
544 /* Update the error code */
545 hspi
->ErrorCode
|= HAL_SPI_ERROR_INVALID_CALLBACK
;
552 if (HAL_SPI_STATE_READY
== hspi
->State
)
556 case HAL_SPI_TX_COMPLETE_CB_ID
:
557 hspi
->TxCpltCallback
= pCallback
;
560 case HAL_SPI_RX_COMPLETE_CB_ID
:
561 hspi
->RxCpltCallback
= pCallback
;
564 case HAL_SPI_TX_RX_COMPLETE_CB_ID
:
565 hspi
->TxRxCpltCallback
= pCallback
;
568 case HAL_SPI_TX_HALF_COMPLETE_CB_ID
:
569 hspi
->TxHalfCpltCallback
= pCallback
;
572 case HAL_SPI_RX_HALF_COMPLETE_CB_ID
:
573 hspi
->RxHalfCpltCallback
= pCallback
;
576 case HAL_SPI_TX_RX_HALF_COMPLETE_CB_ID
:
577 hspi
->TxRxHalfCpltCallback
= pCallback
;
580 case HAL_SPI_ERROR_CB_ID
:
581 hspi
->ErrorCallback
= pCallback
;
584 case HAL_SPI_ABORT_CB_ID
:
585 hspi
->AbortCpltCallback
= pCallback
;
588 case HAL_SPI_MSPINIT_CB_ID
:
589 hspi
->MspInitCallback
= pCallback
;
592 case HAL_SPI_MSPDEINIT_CB_ID
:
593 hspi
->MspDeInitCallback
= pCallback
;
597 /* Update the error code */
598 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
600 /* Return error status */
605 else if (HAL_SPI_STATE_RESET
== hspi
->State
)
609 case HAL_SPI_MSPINIT_CB_ID
:
610 hspi
->MspInitCallback
= pCallback
;
613 case HAL_SPI_MSPDEINIT_CB_ID
:
614 hspi
->MspDeInitCallback
= pCallback
;
618 /* Update the error code */
619 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
621 /* Return error status */
628 /* Update the error code */
629 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
631 /* Return error status */
641 * @brief Unregister an SPI Callback
642 * SPI callback is redirected to the weak predefined callback
643 * @param hspi Pointer to a SPI_HandleTypeDef structure that contains
644 * the configuration information for the specified SPI.
645 * @param CallbackID ID of the callback to be unregistered
648 HAL_StatusTypeDef
HAL_SPI_UnRegisterCallback(SPI_HandleTypeDef
*hspi
, HAL_SPI_CallbackIDTypeDef CallbackID
)
650 HAL_StatusTypeDef status
= HAL_OK
;
655 if (HAL_SPI_STATE_READY
== hspi
->State
)
659 case HAL_SPI_TX_COMPLETE_CB_ID
:
660 hspi
->TxCpltCallback
= HAL_SPI_TxCpltCallback
; /* Legacy weak TxCpltCallback */
663 case HAL_SPI_RX_COMPLETE_CB_ID
:
664 hspi
->RxCpltCallback
= HAL_SPI_RxCpltCallback
; /* Legacy weak RxCpltCallback */
667 case HAL_SPI_TX_RX_COMPLETE_CB_ID
:
668 hspi
->TxRxCpltCallback
= HAL_SPI_TxRxCpltCallback
; /* Legacy weak TxRxCpltCallback */
671 case HAL_SPI_TX_HALF_COMPLETE_CB_ID
:
672 hspi
->TxHalfCpltCallback
= HAL_SPI_TxHalfCpltCallback
; /* Legacy weak TxHalfCpltCallback */
675 case HAL_SPI_RX_HALF_COMPLETE_CB_ID
:
676 hspi
->RxHalfCpltCallback
= HAL_SPI_RxHalfCpltCallback
; /* Legacy weak RxHalfCpltCallback */
679 case HAL_SPI_TX_RX_HALF_COMPLETE_CB_ID
:
680 hspi
->TxRxHalfCpltCallback
= HAL_SPI_TxRxHalfCpltCallback
; /* Legacy weak TxRxHalfCpltCallback */
683 case HAL_SPI_ERROR_CB_ID
:
684 hspi
->ErrorCallback
= HAL_SPI_ErrorCallback
; /* Legacy weak ErrorCallback */
687 case HAL_SPI_ABORT_CB_ID
:
688 hspi
->AbortCpltCallback
= HAL_SPI_AbortCpltCallback
; /* Legacy weak AbortCpltCallback */
691 case HAL_SPI_MSPINIT_CB_ID
:
692 hspi
->MspInitCallback
= HAL_SPI_MspInit
; /* Legacy weak MspInit */
695 case HAL_SPI_MSPDEINIT_CB_ID
:
696 hspi
->MspDeInitCallback
= HAL_SPI_MspDeInit
; /* Legacy weak MspDeInit */
700 /* Update the error code */
701 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
703 /* Return error status */
708 else if (HAL_SPI_STATE_RESET
== hspi
->State
)
712 case HAL_SPI_MSPINIT_CB_ID
:
713 hspi
->MspInitCallback
= HAL_SPI_MspInit
; /* Legacy weak MspInit */
716 case HAL_SPI_MSPDEINIT_CB_ID
:
717 hspi
->MspDeInitCallback
= HAL_SPI_MspDeInit
; /* Legacy weak MspDeInit */
721 /* Update the error code */
722 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
724 /* Return error status */
731 /* Update the error code */
732 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_INVALID_CALLBACK
);
734 /* Return error status */
742 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
747 /** @defgroup SPI_Exported_Functions_Group2 IO operation functions
748 * @brief Data transfers functions
751 ==============================================================================
752 ##### IO operation functions #####
753 ===============================================================================
755 This subsection provides a set of functions allowing to manage the SPI
758 [..] The SPI supports master and slave mode :
760 (#) There are two modes of transfer:
761 (++) Blocking mode: The communication is performed in polling mode.
762 The HAL status of all data processing is returned by the same function
763 after finishing transfer.
764 (++) No-Blocking mode: The communication is performed using Interrupts
765 or DMA, These APIs return the HAL status.
766 The end of the data processing will be indicated through the
767 dedicated SPI IRQ when using Interrupt mode or the DMA IRQ when
769 The HAL_SPI_TxCpltCallback(), HAL_SPI_RxCpltCallback() and HAL_SPI_TxRxCpltCallback() user callbacks
770 will be executed respectively at the end of the transmit or Receive process
771 The HAL_SPI_ErrorCallback()user callback will be executed when a communication error is detected
773 (#) APIs provided for these 2 transfer modes (Blocking mode or Non blocking mode using either Interrupt or DMA)
774 exist for 1Line (simplex) and 2Lines (full duplex) modes.
781 * @brief Transmit an amount of data in blocking mode.
782 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
783 * the configuration information for SPI module.
784 * @param pData pointer to data buffer
785 * @param Size amount of data to be sent
786 * @param Timeout Timeout duration
789 HAL_StatusTypeDef
HAL_SPI_Transmit(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
, uint32_t Timeout
)
792 HAL_StatusTypeDef errorcode
= HAL_OK
;
793 uint16_t initial_TxXferCount
;
795 /* Check Direction parameter */
796 assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi
->Init
.Direction
));
801 /* Init tickstart for timeout management*/
802 tickstart
= HAL_GetTick();
803 initial_TxXferCount
= Size
;
805 if (hspi
->State
!= HAL_SPI_STATE_READY
)
807 errorcode
= HAL_BUSY
;
811 if ((pData
== NULL
) || (Size
== 0U))
813 errorcode
= HAL_ERROR
;
817 /* Set the transaction information */
818 hspi
->State
= HAL_SPI_STATE_BUSY_TX
;
819 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
820 hspi
->pTxBuffPtr
= (uint8_t *)pData
;
821 hspi
->TxXferSize
= Size
;
822 hspi
->TxXferCount
= Size
;
824 /*Init field not used in handle to zero */
825 hspi
->pRxBuffPtr
= (uint8_t *)NULL
;
826 hspi
->RxXferSize
= 0U;
827 hspi
->RxXferCount
= 0U;
831 /* Configure communication direction : 1Line */
832 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
837 #if (USE_SPI_CRC != 0U)
838 /* Reset CRC Calculation */
839 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
843 #endif /* USE_SPI_CRC */
845 /* Check if the SPI is already enabled */
846 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
848 /* Enable SPI peripheral */
849 __HAL_SPI_ENABLE(hspi
);
852 /* Transmit data in 16 Bit mode */
853 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
855 if ((hspi
->Init
.Mode
== SPI_MODE_SLAVE
) || (initial_TxXferCount
== 0x01U
))
857 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
858 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
861 /* Transmit data in 16 Bit mode */
862 while (hspi
->TxXferCount
> 0U)
864 /* Wait until TXE flag is set to send data */
865 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_TXE
))
867 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
868 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
873 /* Timeout management */
874 if ((((HAL_GetTick() - tickstart
) >= Timeout
) && (Timeout
!= HAL_MAX_DELAY
)) || (Timeout
== 0U))
876 errorcode
= HAL_TIMEOUT
;
882 /* Transmit data in 8 Bit mode */
885 if ((hspi
->Init
.Mode
== SPI_MODE_SLAVE
) || (initial_TxXferCount
== 0x01U
))
887 if (hspi
->TxXferCount
> 1U)
889 /* write on the data register in packing mode */
890 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
891 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
892 hspi
->TxXferCount
-= 2U;
896 *((__IO
uint8_t *)&hspi
->Instance
->DR
) = (*hspi
->pTxBuffPtr
);
901 while (hspi
->TxXferCount
> 0U)
903 /* Wait until TXE flag is set to send data */
904 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_TXE
))
906 if (hspi
->TxXferCount
> 1U)
908 /* write on the data register in packing mode */
909 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
910 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
911 hspi
->TxXferCount
-= 2U;
915 *((__IO
uint8_t *)&hspi
->Instance
->DR
) = (*hspi
->pTxBuffPtr
);
922 /* Timeout management */
923 if ((((HAL_GetTick() - tickstart
) >= Timeout
) && (Timeout
!= HAL_MAX_DELAY
)) || (Timeout
== 0U))
925 errorcode
= HAL_TIMEOUT
;
931 #if (USE_SPI_CRC != 0U)
932 /* Enable CRC Transmission */
933 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
935 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
937 #endif /* USE_SPI_CRC */
939 /* Check the end of the transaction */
940 if (SPI_EndRxTxTransaction(hspi
, Timeout
, tickstart
) != HAL_OK
)
942 hspi
->ErrorCode
= HAL_SPI_ERROR_FLAG
;
945 /* Clear overrun flag in 2 Lines communication mode because received is not read */
946 if (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
)
948 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
951 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
953 errorcode
= HAL_ERROR
;
957 hspi
->State
= HAL_SPI_STATE_READY
;
958 /* Process Unlocked */
964 * @brief Receive an amount of data in blocking mode.
965 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
966 * the configuration information for SPI module.
967 * @param pData pointer to data buffer
968 * @param Size amount of data to be received
969 * @param Timeout Timeout duration
972 HAL_StatusTypeDef
HAL_SPI_Receive(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
, uint32_t Timeout
)
975 HAL_StatusTypeDef errorcode
= HAL_OK
;
977 if ((hspi
->Init
.Mode
== SPI_MODE_MASTER
) && (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
))
979 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
980 /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */
981 return HAL_SPI_TransmitReceive(hspi
, pData
, pData
, Size
, Timeout
);
987 /* Init tickstart for timeout management*/
988 tickstart
= HAL_GetTick();
990 if (hspi
->State
!= HAL_SPI_STATE_READY
)
992 errorcode
= HAL_BUSY
;
996 if ((pData
== NULL
) || (Size
== 0U))
998 errorcode
= HAL_ERROR
;
1002 /* Set the transaction information */
1003 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
1004 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1005 hspi
->pRxBuffPtr
= (uint8_t *)pData
;
1006 hspi
->RxXferSize
= Size
;
1007 hspi
->RxXferCount
= Size
;
1009 /*Init field not used in handle to zero */
1010 hspi
->pTxBuffPtr
= (uint8_t *)NULL
;
1011 hspi
->TxXferSize
= 0U;
1012 hspi
->TxXferCount
= 0U;
1016 #if (USE_SPI_CRC != 0U)
1017 /* Reset CRC Calculation */
1018 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1020 SPI_RESET_CRC(hspi
);
1021 /* this is done to handle the CRCNEXT before the latest data */
1022 hspi
->RxXferCount
--;
1024 #endif /* USE_SPI_CRC */
1026 /* Set the Rx Fifo threshold */
1027 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1029 /* Set RX Fifo threshold according the reception data length: 16bit */
1030 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1034 /* Set RX Fifo threshold according the reception data length: 8bit */
1035 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1038 /* Configure communication direction: 1Line */
1039 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
1044 /* Check if the SPI is already enabled */
1045 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1047 /* Enable SPI peripheral */
1048 __HAL_SPI_ENABLE(hspi
);
1051 /* Receive data in 8 Bit mode */
1052 if (hspi
->Init
.DataSize
<= SPI_DATASIZE_8BIT
)
1055 while (hspi
->RxXferCount
> 0U)
1057 /* Check the RXNE flag */
1058 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_RXNE
))
1060 /* read the received data */
1061 (* (uint8_t *)hspi
->pRxBuffPtr
) = *(__IO
uint8_t *)&hspi
->Instance
->DR
;
1062 hspi
->pRxBuffPtr
+= sizeof(uint8_t);
1063 hspi
->RxXferCount
--;
1067 /* Timeout management */
1068 if ((((HAL_GetTick() - tickstart
) >= Timeout
) && (Timeout
!= HAL_MAX_DELAY
)) || (Timeout
== 0U))
1070 errorcode
= HAL_TIMEOUT
;
1079 while (hspi
->RxXferCount
> 0U)
1081 /* Check the RXNE flag */
1082 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_RXNE
))
1084 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)hspi
->Instance
->DR
;
1085 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
1086 hspi
->RxXferCount
--;
1090 /* Timeout management */
1091 if ((((HAL_GetTick() - tickstart
) >= Timeout
) && (Timeout
!= HAL_MAX_DELAY
)) || (Timeout
== 0U))
1093 errorcode
= HAL_TIMEOUT
;
1100 #if (USE_SPI_CRC != 0U)
1101 /* Handle the CRC Transmission */
1102 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1104 /* freeze the CRC before the latest data */
1105 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
1107 /* Read the latest data */
1108 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, Timeout
, tickstart
) != HAL_OK
)
1110 /* the latest data has not been received */
1111 errorcode
= HAL_TIMEOUT
;
1115 /* Receive last data in 16 Bit mode */
1116 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1118 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)hspi
->Instance
->DR
;
1120 /* Receive last data in 8 Bit mode */
1123 (*(uint8_t *)hspi
->pRxBuffPtr
) = *(__IO
uint8_t *)&hspi
->Instance
->DR
;
1126 /* Wait the CRC data */
1127 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, Timeout
, tickstart
) != HAL_OK
)
1129 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1130 errorcode
= HAL_TIMEOUT
;
1134 /* Read CRC to Flush DR and RXNE flag */
1135 if (hspi
->Init
.DataSize
== SPI_DATASIZE_16BIT
)
1137 /* Read 16bit CRC */
1138 READ_REG(hspi
->Instance
->DR
);
1143 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
1145 if ((hspi
->Init
.DataSize
== SPI_DATASIZE_8BIT
) && (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
))
1147 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, Timeout
, tickstart
) != HAL_OK
)
1149 /* Error on the CRC reception */
1150 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1151 errorcode
= HAL_TIMEOUT
;
1154 /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */
1155 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
1159 #endif /* USE_SPI_CRC */
1161 /* Check the end of the transaction */
1162 if (SPI_EndRxTransaction(hspi
, Timeout
, tickstart
) != HAL_OK
)
1164 hspi
->ErrorCode
= HAL_SPI_ERROR_FLAG
;
1167 #if (USE_SPI_CRC != 0U)
1168 /* Check if CRC error occurred */
1169 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
))
1171 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1172 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
1174 #endif /* USE_SPI_CRC */
1176 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
1178 errorcode
= HAL_ERROR
;
1182 hspi
->State
= HAL_SPI_STATE_READY
;
1188 * @brief Transmit and Receive an amount of data in blocking mode.
1189 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1190 * the configuration information for SPI module.
1191 * @param pTxData pointer to transmission data buffer
1192 * @param pRxData pointer to reception data buffer
1193 * @param Size amount of data to be sent and received
1194 * @param Timeout Timeout duration
1195 * @retval HAL status
1197 HAL_StatusTypeDef
HAL_SPI_TransmitReceive(SPI_HandleTypeDef
*hspi
, uint8_t *pTxData
, uint8_t *pRxData
, uint16_t Size
,
1200 uint16_t initial_TxXferCount
;
1201 uint16_t initial_RxXferCount
;
1203 HAL_SPI_StateTypeDef tmp_state
;
1205 #if (USE_SPI_CRC != 0U)
1208 #endif /* USE_SPI_CRC */
1210 /* Variable used to alternate Rx and Tx during transfer */
1211 uint32_t txallowed
= 1U;
1212 HAL_StatusTypeDef errorcode
= HAL_OK
;
1214 /* Check Direction parameter */
1215 assert_param(IS_SPI_DIRECTION_2LINES(hspi
->Init
.Direction
));
1217 /* Process Locked */
1220 /* Init tickstart for timeout management*/
1221 tickstart
= HAL_GetTick();
1223 /* Init temporary variables */
1224 tmp_state
= hspi
->State
;
1225 tmp_mode
= hspi
->Init
.Mode
;
1226 initial_TxXferCount
= Size
;
1227 initial_RxXferCount
= Size
;
1228 #if (USE_SPI_CRC != 0U)
1229 spi_cr1
= READ_REG(hspi
->Instance
->CR1
);
1230 spi_cr2
= READ_REG(hspi
->Instance
->CR2
);
1231 #endif /* USE_SPI_CRC */
1233 if (!((tmp_state
== HAL_SPI_STATE_READY
) || \
1234 ((tmp_mode
== SPI_MODE_MASTER
) && (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
) && (tmp_state
== HAL_SPI_STATE_BUSY_RX
))))
1236 errorcode
= HAL_BUSY
;
1240 if ((pTxData
== NULL
) || (pRxData
== NULL
) || (Size
== 0U))
1242 errorcode
= HAL_ERROR
;
1246 /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */
1247 if (hspi
->State
!= HAL_SPI_STATE_BUSY_RX
)
1249 hspi
->State
= HAL_SPI_STATE_BUSY_TX_RX
;
1252 /* Set the transaction information */
1253 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1254 hspi
->pRxBuffPtr
= (uint8_t *)pRxData
;
1255 hspi
->RxXferCount
= Size
;
1256 hspi
->RxXferSize
= Size
;
1257 hspi
->pTxBuffPtr
= (uint8_t *)pTxData
;
1258 hspi
->TxXferCount
= Size
;
1259 hspi
->TxXferSize
= Size
;
1261 /*Init field not used in handle to zero */
1265 #if (USE_SPI_CRC != 0U)
1266 /* Reset CRC Calculation */
1267 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1269 SPI_RESET_CRC(hspi
);
1271 #endif /* USE_SPI_CRC */
1273 /* Set the Rx Fifo threshold */
1274 if ((hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
) || (initial_RxXferCount
> 1U))
1276 /* Set fiforxthreshold according the reception data length: 16bit */
1277 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1281 /* Set fiforxthreshold according the reception data length: 8bit */
1282 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1285 /* Check if the SPI is already enabled */
1286 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1288 /* Enable SPI peripheral */
1289 __HAL_SPI_ENABLE(hspi
);
1292 /* Transmit and Receive data in 16 Bit mode */
1293 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1295 if ((hspi
->Init
.Mode
== SPI_MODE_SLAVE
) || (initial_TxXferCount
== 0x01U
))
1297 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
1298 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
1299 hspi
->TxXferCount
--;
1301 while ((hspi
->TxXferCount
> 0U) || (hspi
->RxXferCount
> 0U))
1303 /* Check TXE flag */
1304 if ((__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_TXE
)) && (hspi
->TxXferCount
> 0U) && (txallowed
== 1U))
1306 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
1307 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
1308 hspi
->TxXferCount
--;
1309 /* Next Data is a reception (Rx). Tx not allowed */
1312 #if (USE_SPI_CRC != 0U)
1313 /* Enable CRC Transmission */
1314 if ((hspi
->TxXferCount
== 0U) && (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
))
1316 /* Set NSS Soft to received correctly the CRC on slave mode with NSS pulse activated */
1317 if ((READ_BIT(spi_cr1
, SPI_CR1_MSTR
) == 0U) && (READ_BIT(spi_cr2
, SPI_CR2_NSSP
) == SPI_CR2_NSSP
))
1319 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_SSM
);
1321 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
1323 #endif /* USE_SPI_CRC */
1326 /* Check RXNE flag */
1327 if ((__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_RXNE
)) && (hspi
->RxXferCount
> 0U))
1329 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)hspi
->Instance
->DR
;
1330 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
1331 hspi
->RxXferCount
--;
1332 /* Next Data is a Transmission (Tx). Tx is allowed */
1335 if (((HAL_GetTick() - tickstart
) >= Timeout
) && (Timeout
!= HAL_MAX_DELAY
))
1337 errorcode
= HAL_TIMEOUT
;
1342 /* Transmit and Receive data in 8 Bit mode */
1345 if ((hspi
->Init
.Mode
== SPI_MODE_SLAVE
) || (initial_TxXferCount
== 0x01U
))
1347 if (hspi
->TxXferCount
> 1U)
1349 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
1350 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
1351 hspi
->TxXferCount
-= 2U;
1355 *(__IO
uint8_t *)&hspi
->Instance
->DR
= (*hspi
->pTxBuffPtr
);
1357 hspi
->TxXferCount
--;
1360 while ((hspi
->TxXferCount
> 0U) || (hspi
->RxXferCount
> 0U))
1362 /* Check TXE flag */
1363 if ((__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_TXE
)) && (hspi
->TxXferCount
> 0U) && (txallowed
== 1U))
1365 if (hspi
->TxXferCount
> 1U)
1367 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
1368 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
1369 hspi
->TxXferCount
-= 2U;
1373 *(__IO
uint8_t *)&hspi
->Instance
->DR
= (*hspi
->pTxBuffPtr
);
1375 hspi
->TxXferCount
--;
1377 /* Next Data is a reception (Rx). Tx not allowed */
1380 #if (USE_SPI_CRC != 0U)
1381 /* Enable CRC Transmission */
1382 if ((hspi
->TxXferCount
== 0U) && (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
))
1384 /* Set NSS Soft to received correctly the CRC on slave mode with NSS pulse activated */
1385 if ((READ_BIT(spi_cr1
, SPI_CR1_MSTR
) == 0U) && (READ_BIT(spi_cr2
, SPI_CR2_NSSP
) == SPI_CR2_NSSP
))
1387 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_SSM
);
1389 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
1391 #endif /* USE_SPI_CRC */
1394 /* Wait until RXNE flag is reset */
1395 if ((__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_RXNE
)) && (hspi
->RxXferCount
> 0U))
1397 if (hspi
->RxXferCount
> 1U)
1399 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)hspi
->Instance
->DR
;
1400 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
1401 hspi
->RxXferCount
-= 2U;
1402 if (hspi
->RxXferCount
<= 1U)
1404 /* Set RX Fifo threshold before to switch on 8 bit data size */
1405 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1410 (*(uint8_t *)hspi
->pRxBuffPtr
) = *(__IO
uint8_t *)&hspi
->Instance
->DR
;
1412 hspi
->RxXferCount
--;
1414 /* Next Data is a Transmission (Tx). Tx is allowed */
1417 if ((((HAL_GetTick() - tickstart
) >= Timeout
) && ((Timeout
!= HAL_MAX_DELAY
))) || (Timeout
== 0U))
1419 errorcode
= HAL_TIMEOUT
;
1425 #if (USE_SPI_CRC != 0U)
1426 /* Read CRC from DR to close CRC calculation process */
1427 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1429 /* Wait until TXE flag */
1430 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, Timeout
, tickstart
) != HAL_OK
)
1432 /* Error on the CRC reception */
1433 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1434 errorcode
= HAL_TIMEOUT
;
1438 if (hspi
->Init
.DataSize
== SPI_DATASIZE_16BIT
)
1440 /* Read 16bit CRC */
1441 READ_REG(hspi
->Instance
->DR
);
1446 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
1448 if (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
)
1450 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, Timeout
, tickstart
) != HAL_OK
)
1452 /* Error on the CRC reception */
1453 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1454 errorcode
= HAL_TIMEOUT
;
1457 /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */
1458 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
1463 /* Check if CRC error occurred */
1464 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
))
1466 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
1467 /* Clear CRC Flag */
1468 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
1470 errorcode
= HAL_ERROR
;
1472 #endif /* USE_SPI_CRC */
1474 /* Check the end of the transaction */
1475 if (SPI_EndRxTxTransaction(hspi
, Timeout
, tickstart
) != HAL_OK
)
1477 errorcode
= HAL_ERROR
;
1478 hspi
->ErrorCode
= HAL_SPI_ERROR_FLAG
;
1482 hspi
->State
= HAL_SPI_STATE_READY
;
1488 * @brief Transmit an amount of data in non-blocking mode with Interrupt.
1489 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1490 * the configuration information for SPI module.
1491 * @param pData pointer to data buffer
1492 * @param Size amount of data to be sent
1493 * @retval HAL status
1495 HAL_StatusTypeDef
HAL_SPI_Transmit_IT(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
)
1497 HAL_StatusTypeDef errorcode
= HAL_OK
;
1499 /* Check Direction parameter */
1500 assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi
->Init
.Direction
));
1502 /* Process Locked */
1505 if ((pData
== NULL
) || (Size
== 0U))
1507 errorcode
= HAL_ERROR
;
1511 if (hspi
->State
!= HAL_SPI_STATE_READY
)
1513 errorcode
= HAL_BUSY
;
1517 /* Set the transaction information */
1518 hspi
->State
= HAL_SPI_STATE_BUSY_TX
;
1519 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1520 hspi
->pTxBuffPtr
= (uint8_t *)pData
;
1521 hspi
->TxXferSize
= Size
;
1522 hspi
->TxXferCount
= Size
;
1524 /* Init field not used in handle to zero */
1525 hspi
->pRxBuffPtr
= (uint8_t *)NULL
;
1526 hspi
->RxXferSize
= 0U;
1527 hspi
->RxXferCount
= 0U;
1530 /* Set the function for IT treatment */
1531 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1533 hspi
->TxISR
= SPI_TxISR_16BIT
;
1537 hspi
->TxISR
= SPI_TxISR_8BIT
;
1540 /* Configure communication direction : 1Line */
1541 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
1546 #if (USE_SPI_CRC != 0U)
1547 /* Reset CRC Calculation */
1548 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1550 SPI_RESET_CRC(hspi
);
1552 #endif /* USE_SPI_CRC */
1554 /* Enable TXE and ERR interrupt */
1555 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_TXE
| SPI_IT_ERR
));
1558 /* Check if the SPI is already enabled */
1559 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1561 /* Enable SPI peripheral */
1562 __HAL_SPI_ENABLE(hspi
);
1571 * @brief Receive an amount of data in non-blocking mode with Interrupt.
1572 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1573 * the configuration information for SPI module.
1574 * @param pData pointer to data buffer
1575 * @param Size amount of data to be sent
1576 * @retval HAL status
1578 HAL_StatusTypeDef
HAL_SPI_Receive_IT(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
)
1580 HAL_StatusTypeDef errorcode
= HAL_OK
;
1582 if ((hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
) && (hspi
->Init
.Mode
== SPI_MODE_MASTER
))
1584 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
1585 /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */
1586 return HAL_SPI_TransmitReceive_IT(hspi
, pData
, pData
, Size
);
1589 /* Process Locked */
1592 if (hspi
->State
!= HAL_SPI_STATE_READY
)
1594 errorcode
= HAL_BUSY
;
1598 if ((pData
== NULL
) || (Size
== 0U))
1600 errorcode
= HAL_ERROR
;
1604 /* Set the transaction information */
1605 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
1606 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1607 hspi
->pRxBuffPtr
= (uint8_t *)pData
;
1608 hspi
->RxXferSize
= Size
;
1609 hspi
->RxXferCount
= Size
;
1611 /* Init field not used in handle to zero */
1612 hspi
->pTxBuffPtr
= (uint8_t *)NULL
;
1613 hspi
->TxXferSize
= 0U;
1614 hspi
->TxXferCount
= 0U;
1617 /* Check the data size to adapt Rx threshold and the set the function for IT treatment */
1618 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1620 /* Set RX Fifo threshold according the reception data length: 16 bit */
1621 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1622 hspi
->RxISR
= SPI_RxISR_16BIT
;
1626 /* Set RX Fifo threshold according the reception data length: 8 bit */
1627 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1628 hspi
->RxISR
= SPI_RxISR_8BIT
;
1631 /* Configure communication direction : 1Line */
1632 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
1637 #if (USE_SPI_CRC != 0U)
1638 /* Reset CRC Calculation */
1639 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1642 if ((hspi
->Init
.DataSize
<= SPI_DATASIZE_8BIT
) && (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
))
1646 SPI_RESET_CRC(hspi
);
1652 #endif /* USE_SPI_CRC */
1654 /* Enable TXE and ERR interrupt */
1655 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_RXNE
| SPI_IT_ERR
));
1657 /* Note : The SPI must be enabled after unlocking current process
1658 to avoid the risk of SPI interrupt handle execution before current
1661 /* Check if the SPI is already enabled */
1662 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1664 /* Enable SPI peripheral */
1665 __HAL_SPI_ENABLE(hspi
);
1669 /* Process Unlocked */
1675 * @brief Transmit and Receive an amount of data in non-blocking mode with Interrupt.
1676 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1677 * the configuration information for SPI module.
1678 * @param pTxData pointer to transmission data buffer
1679 * @param pRxData pointer to reception data buffer
1680 * @param Size amount of data to be sent and received
1681 * @retval HAL status
1683 HAL_StatusTypeDef
HAL_SPI_TransmitReceive_IT(SPI_HandleTypeDef
*hspi
, uint8_t *pTxData
, uint8_t *pRxData
, uint16_t Size
)
1686 HAL_SPI_StateTypeDef tmp_state
;
1687 HAL_StatusTypeDef errorcode
= HAL_OK
;
1689 /* Check Direction parameter */
1690 assert_param(IS_SPI_DIRECTION_2LINES(hspi
->Init
.Direction
));
1692 /* Process locked */
1695 /* Init temporary variables */
1696 tmp_state
= hspi
->State
;
1697 tmp_mode
= hspi
->Init
.Mode
;
1699 if (!((tmp_state
== HAL_SPI_STATE_READY
) || \
1700 ((tmp_mode
== SPI_MODE_MASTER
) && (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
) && (tmp_state
== HAL_SPI_STATE_BUSY_RX
))))
1702 errorcode
= HAL_BUSY
;
1706 if ((pTxData
== NULL
) || (pRxData
== NULL
) || (Size
== 0U))
1708 errorcode
= HAL_ERROR
;
1712 /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */
1713 if (hspi
->State
!= HAL_SPI_STATE_BUSY_RX
)
1715 hspi
->State
= HAL_SPI_STATE_BUSY_TX_RX
;
1718 /* Set the transaction information */
1719 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1720 hspi
->pTxBuffPtr
= (uint8_t *)pTxData
;
1721 hspi
->TxXferSize
= Size
;
1722 hspi
->TxXferCount
= Size
;
1723 hspi
->pRxBuffPtr
= (uint8_t *)pRxData
;
1724 hspi
->RxXferSize
= Size
;
1725 hspi
->RxXferCount
= Size
;
1727 /* Set the function for IT treatment */
1728 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1730 hspi
->RxISR
= SPI_2linesRxISR_16BIT
;
1731 hspi
->TxISR
= SPI_2linesTxISR_16BIT
;
1735 hspi
->RxISR
= SPI_2linesRxISR_8BIT
;
1736 hspi
->TxISR
= SPI_2linesTxISR_8BIT
;
1739 #if (USE_SPI_CRC != 0U)
1740 /* Reset CRC Calculation */
1741 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1744 if ((hspi
->Init
.DataSize
<= SPI_DATASIZE_8BIT
) && (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
))
1748 SPI_RESET_CRC(hspi
);
1754 #endif /* USE_SPI_CRC */
1756 /* Check if packing mode is enabled and if there is more than 2 data to receive */
1757 if ((hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
) || (Size
>= 2U))
1759 /* Set RX Fifo threshold according the reception data length: 16 bit */
1760 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1764 /* Set RX Fifo threshold according the reception data length: 8 bit */
1765 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1768 /* Enable TXE, RXNE and ERR interrupt */
1769 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_TXE
| SPI_IT_RXNE
| SPI_IT_ERR
));
1771 /* Check if the SPI is already enabled */
1772 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1774 /* Enable SPI peripheral */
1775 __HAL_SPI_ENABLE(hspi
);
1779 /* Process Unlocked */
1785 * @brief Transmit an amount of data in non-blocking mode with DMA.
1786 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1787 * the configuration information for SPI module.
1788 * @param pData pointer to data buffer
1789 * @param Size amount of data to be sent
1790 * @retval HAL status
1792 HAL_StatusTypeDef
HAL_SPI_Transmit_DMA(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
)
1794 HAL_StatusTypeDef errorcode
= HAL_OK
;
1796 /* Check tx dma handle */
1797 assert_param(IS_SPI_DMA_HANDLE(hspi
->hdmatx
));
1799 /* Check Direction parameter */
1800 assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi
->Init
.Direction
));
1802 /* Process Locked */
1805 if (hspi
->State
!= HAL_SPI_STATE_READY
)
1807 errorcode
= HAL_BUSY
;
1811 if ((pData
== NULL
) || (Size
== 0U))
1813 errorcode
= HAL_ERROR
;
1817 /* Set the transaction information */
1818 hspi
->State
= HAL_SPI_STATE_BUSY_TX
;
1819 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1820 hspi
->pTxBuffPtr
= (uint8_t *)pData
;
1821 hspi
->TxXferSize
= Size
;
1822 hspi
->TxXferCount
= Size
;
1824 /* Init field not used in handle to zero */
1825 hspi
->pRxBuffPtr
= (uint8_t *)NULL
;
1828 hspi
->RxXferSize
= 0U;
1829 hspi
->RxXferCount
= 0U;
1831 /* Configure communication direction : 1Line */
1832 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
1837 #if (USE_SPI_CRC != 0U)
1838 /* Reset CRC Calculation */
1839 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1841 SPI_RESET_CRC(hspi
);
1843 #endif /* USE_SPI_CRC */
1845 /* Set the SPI TxDMA Half transfer complete callback */
1846 hspi
->hdmatx
->XferHalfCpltCallback
= SPI_DMAHalfTransmitCplt
;
1848 /* Set the SPI TxDMA transfer complete callback */
1849 hspi
->hdmatx
->XferCpltCallback
= SPI_DMATransmitCplt
;
1851 /* Set the DMA error callback */
1852 hspi
->hdmatx
->XferErrorCallback
= SPI_DMAError
;
1854 /* Set the DMA AbortCpltCallback */
1855 hspi
->hdmatx
->XferAbortCallback
= NULL
;
1857 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
);
1858 /* Packing mode is enabled only if the DMA setting is HALWORD */
1859 if ((hspi
->Init
.DataSize
<= SPI_DATASIZE_8BIT
) && (hspi
->hdmatx
->Init
.MemDataAlignment
== DMA_MDATAALIGN_HALFWORD
))
1861 /* Check the even/odd of the data size + crc if enabled */
1862 if ((hspi
->TxXferCount
& 0x1U
) == 0U)
1864 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
);
1865 hspi
->TxXferCount
= (hspi
->TxXferCount
>> 1U);
1869 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
);
1870 hspi
->TxXferCount
= (hspi
->TxXferCount
>> 1U) + 1U;
1874 /* Enable the Tx DMA Stream/Channel */
1875 if (HAL_OK
!= HAL_DMA_Start_IT(hspi
->hdmatx
, (uint32_t)hspi
->pTxBuffPtr
, (uint32_t)&hspi
->Instance
->DR
, hspi
->TxXferCount
))
1877 /* Update SPI error code */
1878 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
1879 errorcode
= HAL_ERROR
;
1881 hspi
->State
= HAL_SPI_STATE_READY
;
1885 /* Check if the SPI is already enabled */
1886 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
1888 /* Enable SPI peripheral */
1889 __HAL_SPI_ENABLE(hspi
);
1892 /* Enable the SPI Error Interrupt Bit */
1893 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_ERR
));
1895 /* Enable Tx DMA Request */
1896 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
);
1899 /* Process Unlocked */
1905 * @brief Receive an amount of data in non-blocking mode with DMA.
1906 * @note In case of MASTER mode and SPI_DIRECTION_2LINES direction, hdmatx shall be defined.
1907 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
1908 * the configuration information for SPI module.
1909 * @param pData pointer to data buffer
1910 * @note When the CRC feature is enabled the pData Length must be Size + 1.
1911 * @param Size amount of data to be sent
1912 * @retval HAL status
1914 HAL_StatusTypeDef
HAL_SPI_Receive_DMA(SPI_HandleTypeDef
*hspi
, uint8_t *pData
, uint16_t Size
)
1916 HAL_StatusTypeDef errorcode
= HAL_OK
;
1918 /* Check rx dma handle */
1919 assert_param(IS_SPI_DMA_HANDLE(hspi
->hdmarx
));
1921 if ((hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
) && (hspi
->Init
.Mode
== SPI_MODE_MASTER
))
1923 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
1925 /* Check tx dma handle */
1926 assert_param(IS_SPI_DMA_HANDLE(hspi
->hdmatx
));
1928 /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */
1929 return HAL_SPI_TransmitReceive_DMA(hspi
, pData
, pData
, Size
);
1932 /* Process Locked */
1935 if (hspi
->State
!= HAL_SPI_STATE_READY
)
1937 errorcode
= HAL_BUSY
;
1941 if ((pData
== NULL
) || (Size
== 0U))
1943 errorcode
= HAL_ERROR
;
1947 /* Set the transaction information */
1948 hspi
->State
= HAL_SPI_STATE_BUSY_RX
;
1949 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
1950 hspi
->pRxBuffPtr
= (uint8_t *)pData
;
1951 hspi
->RxXferSize
= Size
;
1952 hspi
->RxXferCount
= Size
;
1954 /*Init field not used in handle to zero */
1957 hspi
->TxXferSize
= 0U;
1958 hspi
->TxXferCount
= 0U;
1960 /* Configure communication direction : 1Line */
1961 if (hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
1966 #if (USE_SPI_CRC != 0U)
1967 /* Reset CRC Calculation */
1968 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
1970 SPI_RESET_CRC(hspi
);
1972 #endif /* USE_SPI_CRC */
1975 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMARX
);
1976 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
1978 /* Set RX Fifo threshold according the reception data length: 16bit */
1979 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1983 /* Set RX Fifo threshold according the reception data length: 8bit */
1984 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1986 if (hspi
->hdmarx
->Init
.MemDataAlignment
== DMA_MDATAALIGN_HALFWORD
)
1988 /* Set RX Fifo threshold according the reception data length: 16bit */
1989 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
1991 if ((hspi
->RxXferCount
& 0x1U
) == 0x0U
)
1993 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMARX
);
1994 hspi
->RxXferCount
= hspi
->RxXferCount
>> 1U;
1998 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMARX
);
1999 hspi
->RxXferCount
= (hspi
->RxXferCount
>> 1U) + 1U;
2004 /* Set the SPI RxDMA Half transfer complete callback */
2005 hspi
->hdmarx
->XferHalfCpltCallback
= SPI_DMAHalfReceiveCplt
;
2007 /* Set the SPI Rx DMA transfer complete callback */
2008 hspi
->hdmarx
->XferCpltCallback
= SPI_DMAReceiveCplt
;
2010 /* Set the DMA error callback */
2011 hspi
->hdmarx
->XferErrorCallback
= SPI_DMAError
;
2013 /* Set the DMA AbortCpltCallback */
2014 hspi
->hdmarx
->XferAbortCallback
= NULL
;
2016 /* Enable the Rx DMA Stream/Channel */
2017 if (HAL_OK
!= HAL_DMA_Start_IT(hspi
->hdmarx
, (uint32_t)&hspi
->Instance
->DR
, (uint32_t)hspi
->pRxBuffPtr
, hspi
->RxXferCount
))
2019 /* Update SPI error code */
2020 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
2021 errorcode
= HAL_ERROR
;
2023 hspi
->State
= HAL_SPI_STATE_READY
;
2027 /* Check if the SPI is already enabled */
2028 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
2030 /* Enable SPI peripheral */
2031 __HAL_SPI_ENABLE(hspi
);
2034 /* Enable the SPI Error Interrupt Bit */
2035 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_ERR
));
2037 /* Enable Rx DMA Request */
2038 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
);
2041 /* Process Unlocked */
2047 * @brief Transmit and Receive an amount of data in non-blocking mode with DMA.
2048 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2049 * the configuration information for SPI module.
2050 * @param pTxData pointer to transmission data buffer
2051 * @param pRxData pointer to reception data buffer
2052 * @note When the CRC feature is enabled the pRxData Length must be Size + 1
2053 * @param Size amount of data to be sent
2054 * @retval HAL status
2056 HAL_StatusTypeDef
HAL_SPI_TransmitReceive_DMA(SPI_HandleTypeDef
*hspi
, uint8_t *pTxData
, uint8_t *pRxData
,
2060 HAL_SPI_StateTypeDef tmp_state
;
2061 HAL_StatusTypeDef errorcode
= HAL_OK
;
2063 /* Check rx & tx dma handles */
2064 assert_param(IS_SPI_DMA_HANDLE(hspi
->hdmarx
));
2065 assert_param(IS_SPI_DMA_HANDLE(hspi
->hdmatx
));
2067 /* Check Direction parameter */
2068 assert_param(IS_SPI_DIRECTION_2LINES(hspi
->Init
.Direction
));
2070 /* Process locked */
2073 /* Init temporary variables */
2074 tmp_state
= hspi
->State
;
2075 tmp_mode
= hspi
->Init
.Mode
;
2077 if (!((tmp_state
== HAL_SPI_STATE_READY
) ||
2078 ((tmp_mode
== SPI_MODE_MASTER
) && (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
) && (tmp_state
== HAL_SPI_STATE_BUSY_RX
))))
2080 errorcode
= HAL_BUSY
;
2084 if ((pTxData
== NULL
) || (pRxData
== NULL
) || (Size
== 0U))
2086 errorcode
= HAL_ERROR
;
2090 /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */
2091 if (hspi
->State
!= HAL_SPI_STATE_BUSY_RX
)
2093 hspi
->State
= HAL_SPI_STATE_BUSY_TX_RX
;
2096 /* Set the transaction information */
2097 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
2098 hspi
->pTxBuffPtr
= (uint8_t *)pTxData
;
2099 hspi
->TxXferSize
= Size
;
2100 hspi
->TxXferCount
= Size
;
2101 hspi
->pRxBuffPtr
= (uint8_t *)pRxData
;
2102 hspi
->RxXferSize
= Size
;
2103 hspi
->RxXferCount
= Size
;
2105 /* Init field not used in handle to zero */
2109 #if (USE_SPI_CRC != 0U)
2110 /* Reset CRC Calculation */
2111 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
2113 SPI_RESET_CRC(hspi
);
2115 #endif /* USE_SPI_CRC */
2117 /* Reset the threshold bit */
2118 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
| SPI_CR2_LDMARX
);
2120 /* The packing mode management is enabled by the DMA settings according the spi data size */
2121 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
2123 /* Set fiforxthreshold according the reception data length: 16bit */
2124 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
2128 /* Set RX Fifo threshold according the reception data length: 8bit */
2129 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
2131 if (hspi
->hdmatx
->Init
.MemDataAlignment
== DMA_MDATAALIGN_HALFWORD
)
2133 if ((hspi
->TxXferSize
& 0x1U
) == 0x0U
)
2135 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
);
2136 hspi
->TxXferCount
= hspi
->TxXferCount
>> 1U;
2140 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMATX
);
2141 hspi
->TxXferCount
= (hspi
->TxXferCount
>> 1U) + 1U;
2145 if (hspi
->hdmarx
->Init
.MemDataAlignment
== DMA_MDATAALIGN_HALFWORD
)
2147 /* Set RX Fifo threshold according the reception data length: 16bit */
2148 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
2150 if ((hspi
->RxXferCount
& 0x1U
) == 0x0U
)
2152 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMARX
);
2153 hspi
->RxXferCount
= hspi
->RxXferCount
>> 1U;
2157 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_LDMARX
);
2158 hspi
->RxXferCount
= (hspi
->RxXferCount
>> 1U) + 1U;
2163 /* Check if we are in Rx only or in Rx/Tx Mode and configure the DMA transfer complete callback */
2164 if (hspi
->State
== HAL_SPI_STATE_BUSY_RX
)
2166 /* Set the SPI Rx DMA Half transfer complete callback */
2167 hspi
->hdmarx
->XferHalfCpltCallback
= SPI_DMAHalfReceiveCplt
;
2168 hspi
->hdmarx
->XferCpltCallback
= SPI_DMAReceiveCplt
;
2172 /* Set the SPI Tx/Rx DMA Half transfer complete callback */
2173 hspi
->hdmarx
->XferHalfCpltCallback
= SPI_DMAHalfTransmitReceiveCplt
;
2174 hspi
->hdmarx
->XferCpltCallback
= SPI_DMATransmitReceiveCplt
;
2177 /* Set the DMA error callback */
2178 hspi
->hdmarx
->XferErrorCallback
= SPI_DMAError
;
2180 /* Set the DMA AbortCpltCallback */
2181 hspi
->hdmarx
->XferAbortCallback
= NULL
;
2183 /* Enable the Rx DMA Stream/Channel */
2184 if (HAL_OK
!= HAL_DMA_Start_IT(hspi
->hdmarx
, (uint32_t)&hspi
->Instance
->DR
, (uint32_t)hspi
->pRxBuffPtr
, hspi
->RxXferCount
))
2186 /* Update SPI error code */
2187 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
2188 errorcode
= HAL_ERROR
;
2190 hspi
->State
= HAL_SPI_STATE_READY
;
2194 /* Enable Rx DMA Request */
2195 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
);
2197 /* Set the SPI Tx DMA transfer complete callback as NULL because the communication closing
2198 is performed in DMA reception complete callback */
2199 hspi
->hdmatx
->XferHalfCpltCallback
= NULL
;
2200 hspi
->hdmatx
->XferCpltCallback
= NULL
;
2201 hspi
->hdmatx
->XferErrorCallback
= NULL
;
2202 hspi
->hdmatx
->XferAbortCallback
= NULL
;
2204 /* Enable the Tx DMA Stream/Channel */
2205 if (HAL_OK
!= HAL_DMA_Start_IT(hspi
->hdmatx
, (uint32_t)hspi
->pTxBuffPtr
, (uint32_t)&hspi
->Instance
->DR
, hspi
->TxXferCount
))
2207 /* Update SPI error code */
2208 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
2209 errorcode
= HAL_ERROR
;
2211 hspi
->State
= HAL_SPI_STATE_READY
;
2215 /* Check if the SPI is already enabled */
2216 if ((hspi
->Instance
->CR1
& SPI_CR1_SPE
) != SPI_CR1_SPE
)
2218 /* Enable SPI peripheral */
2219 __HAL_SPI_ENABLE(hspi
);
2221 /* Enable the SPI Error Interrupt Bit */
2222 __HAL_SPI_ENABLE_IT(hspi
, (SPI_IT_ERR
));
2224 /* Enable Tx DMA Request */
2225 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
);
2228 /* Process Unlocked */
2234 * @brief Abort ongoing transfer (blocking mode).
2235 * @param hspi SPI handle.
2236 * @note This procedure could be used for aborting any ongoing transfer (Tx and Rx),
2237 * started in Interrupt or DMA mode.
2238 * This procedure performs following operations :
2239 * - Disable SPI Interrupts (depending of transfer direction)
2240 * - Disable the DMA transfer in the peripheral register (if enabled)
2241 * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode)
2242 * - Set handle State to READY
2243 * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed.
2244 * @retval HAL status
2246 HAL_StatusTypeDef
HAL_SPI_Abort(SPI_HandleTypeDef
*hspi
)
2248 HAL_StatusTypeDef errorcode
;
2249 __IO
uint32_t count
, resetcount
;
2251 /* Initialized local variable */
2253 resetcount
= SPI_DEFAULT_TIMEOUT
* (SystemCoreClock
/ 24U / 1000U);
2256 /* Clear ERRIE interrupt to avoid error interrupts generation during Abort procedure */
2257 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_ERRIE
);
2259 /* Disable TXEIE, RXNEIE and ERRIE(mode fault event, overrun error, TI frame error) interrupts */
2260 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXEIE
))
2262 hspi
->TxISR
= SPI_AbortTx_ISR
;
2263 /* Wait HAL_SPI_STATE_ABORT state */
2268 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2273 while (hspi
->State
!= HAL_SPI_STATE_ABORT
);
2274 /* Reset Timeout Counter */
2278 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXNEIE
))
2280 hspi
->RxISR
= SPI_AbortRx_ISR
;
2281 /* Wait HAL_SPI_STATE_ABORT state */
2286 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2291 while (hspi
->State
!= HAL_SPI_STATE_ABORT
);
2292 /* Reset Timeout Counter */
2296 /* Disable the SPI DMA Tx request if enabled */
2297 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
))
2299 /* Abort the SPI DMA Tx Stream/Channel : use blocking DMA Abort API (no callback) */
2300 if (hspi
->hdmatx
!= NULL
)
2302 /* Set the SPI DMA Abort callback :
2303 will lead to call HAL_SPI_AbortCpltCallback() at end of DMA abort procedure */
2304 hspi
->hdmatx
->XferAbortCallback
= NULL
;
2306 /* Abort DMA Tx Handle linked to SPI Peripheral */
2307 if (HAL_DMA_Abort(hspi
->hdmatx
) != HAL_OK
)
2309 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2312 /* Disable Tx DMA Request */
2313 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_TXDMAEN
));
2315 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
2317 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2320 /* Disable SPI Peripheral */
2321 __HAL_SPI_DISABLE(hspi
);
2323 /* Empty the FRLVL fifo */
2324 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
2326 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2331 /* Disable the SPI DMA Rx request if enabled */
2332 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
))
2334 /* Abort the SPI DMA Rx Stream/Channel : use blocking DMA Abort API (no callback) */
2335 if (hspi
->hdmarx
!= NULL
)
2337 /* Set the SPI DMA Abort callback :
2338 will lead to call HAL_SPI_AbortCpltCallback() at end of DMA abort procedure */
2339 hspi
->hdmarx
->XferAbortCallback
= NULL
;
2341 /* Abort DMA Rx Handle linked to SPI Peripheral */
2342 if (HAL_DMA_Abort(hspi
->hdmarx
) != HAL_OK
)
2344 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2347 /* Disable peripheral */
2348 __HAL_SPI_DISABLE(hspi
);
2350 /* Control the BSY flag */
2351 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
2353 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2356 /* Empty the FRLVL fifo */
2357 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
2359 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2362 /* Disable Rx DMA Request */
2363 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_RXDMAEN
));
2366 /* Reset Tx and Rx transfer counters */
2367 hspi
->RxXferCount
= 0U;
2368 hspi
->TxXferCount
= 0U;
2370 /* Check error during Abort procedure */
2371 if (hspi
->ErrorCode
== HAL_SPI_ERROR_ABORT
)
2373 /* return HAL_Error in case of error during Abort procedure */
2374 errorcode
= HAL_ERROR
;
2378 /* Reset errorCode */
2379 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
2382 /* Clear the Error flags in the SR register */
2383 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
2384 __HAL_SPI_CLEAR_FREFLAG(hspi
);
2386 /* Restore hspi->state to ready */
2387 hspi
->State
= HAL_SPI_STATE_READY
;
2393 * @brief Abort ongoing transfer (Interrupt mode).
2394 * @param hspi SPI handle.
2395 * @note This procedure could be used for aborting any ongoing transfer (Tx and Rx),
2396 * started in Interrupt or DMA mode.
2397 * This procedure performs following operations :
2398 * - Disable SPI Interrupts (depending of transfer direction)
2399 * - Disable the DMA transfer in the peripheral register (if enabled)
2400 * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode)
2401 * - Set handle State to READY
2402 * - At abort completion, call user abort complete callback
2403 * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be
2404 * considered as completed only when user abort complete callback is executed (not when exiting function).
2405 * @retval HAL status
2407 HAL_StatusTypeDef
HAL_SPI_Abort_IT(SPI_HandleTypeDef
*hspi
)
2409 HAL_StatusTypeDef errorcode
;
2410 uint32_t abortcplt
;
2411 __IO
uint32_t count
, resetcount
;
2413 /* Initialized local variable */
2416 resetcount
= SPI_DEFAULT_TIMEOUT
* (SystemCoreClock
/ 24U / 1000U);
2419 /* Clear ERRIE interrupt to avoid error interrupts generation during Abort procedure */
2420 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_ERRIE
);
2422 /* Change Rx and Tx Irq Handler to Disable TXEIE, RXNEIE and ERRIE interrupts */
2423 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXEIE
))
2425 hspi
->TxISR
= SPI_AbortTx_ISR
;
2426 /* Wait HAL_SPI_STATE_ABORT state */
2431 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2436 while (hspi
->State
!= HAL_SPI_STATE_ABORT
);
2437 /* Reset Timeout Counter */
2441 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXNEIE
))
2443 hspi
->RxISR
= SPI_AbortRx_ISR
;
2444 /* Wait HAL_SPI_STATE_ABORT state */
2449 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2454 while (hspi
->State
!= HAL_SPI_STATE_ABORT
);
2455 /* Reset Timeout Counter */
2459 /* If DMA Tx and/or DMA Rx Handles are associated to SPI Handle, DMA Abort complete callbacks should be initialised
2460 before any call to DMA Abort functions */
2461 /* DMA Tx Handle is valid */
2462 if (hspi
->hdmatx
!= NULL
)
2464 /* Set DMA Abort Complete callback if UART DMA Tx request if enabled.
2465 Otherwise, set it to NULL */
2466 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
))
2468 hspi
->hdmatx
->XferAbortCallback
= SPI_DMATxAbortCallback
;
2472 hspi
->hdmatx
->XferAbortCallback
= NULL
;
2475 /* DMA Rx Handle is valid */
2476 if (hspi
->hdmarx
!= NULL
)
2478 /* Set DMA Abort Complete callback if UART DMA Rx request if enabled.
2479 Otherwise, set it to NULL */
2480 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
))
2482 hspi
->hdmarx
->XferAbortCallback
= SPI_DMARxAbortCallback
;
2486 hspi
->hdmarx
->XferAbortCallback
= NULL
;
2490 /* Disable the SPI DMA Tx request if enabled */
2491 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
))
2493 /* Abort the SPI DMA Tx Stream/Channel */
2494 if (hspi
->hdmatx
!= NULL
)
2496 /* Abort DMA Tx Handle linked to SPI Peripheral */
2497 if (HAL_DMA_Abort_IT(hspi
->hdmatx
) != HAL_OK
)
2499 hspi
->hdmatx
->XferAbortCallback
= NULL
;
2500 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2508 /* Disable the SPI DMA Rx request if enabled */
2509 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
))
2511 /* Abort the SPI DMA Rx Stream/Channel */
2512 if (hspi
->hdmarx
!= NULL
)
2514 /* Abort DMA Rx Handle linked to SPI Peripheral */
2515 if (HAL_DMA_Abort_IT(hspi
->hdmarx
) != HAL_OK
)
2517 hspi
->hdmarx
->XferAbortCallback
= NULL
;
2518 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
2527 if (abortcplt
== 1U)
2529 /* Reset Tx and Rx transfer counters */
2530 hspi
->RxXferCount
= 0U;
2531 hspi
->TxXferCount
= 0U;
2533 /* Check error during Abort procedure */
2534 if (hspi
->ErrorCode
== HAL_SPI_ERROR_ABORT
)
2536 /* return HAL_Error in case of error during Abort procedure */
2537 errorcode
= HAL_ERROR
;
2541 /* Reset errorCode */
2542 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
2545 /* Clear the Error flags in the SR register */
2546 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
2547 __HAL_SPI_CLEAR_FREFLAG(hspi
);
2549 /* Restore hspi->State to Ready */
2550 hspi
->State
= HAL_SPI_STATE_READY
;
2552 /* As no DMA to be aborted, call directly user Abort complete callback */
2553 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
2554 hspi
->AbortCpltCallback(hspi
);
2556 HAL_SPI_AbortCpltCallback(hspi
);
2557 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
2564 * @brief Pause the DMA Transfer.
2565 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2566 * the configuration information for the specified SPI module.
2567 * @retval HAL status
2569 HAL_StatusTypeDef
HAL_SPI_DMAPause(SPI_HandleTypeDef
*hspi
)
2571 /* Process Locked */
2574 /* Disable the SPI DMA Tx & Rx requests */
2575 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
2577 /* Process Unlocked */
2584 * @brief Resume the DMA Transfer.
2585 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2586 * the configuration information for the specified SPI module.
2587 * @retval HAL status
2589 HAL_StatusTypeDef
HAL_SPI_DMAResume(SPI_HandleTypeDef
*hspi
)
2591 /* Process Locked */
2594 /* Enable the SPI DMA Tx & Rx requests */
2595 SET_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
2597 /* Process Unlocked */
2604 * @brief Stop the DMA Transfer.
2605 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2606 * the configuration information for the specified SPI module.
2607 * @retval HAL status
2609 HAL_StatusTypeDef
HAL_SPI_DMAStop(SPI_HandleTypeDef
*hspi
)
2611 HAL_StatusTypeDef errorcode
= HAL_OK
;
2612 /* The Lock is not implemented on this API to allow the user application
2613 to call the HAL SPI API under callbacks HAL_SPI_TxCpltCallback() or HAL_SPI_RxCpltCallback() or HAL_SPI_TxRxCpltCallback():
2614 when calling HAL_DMA_Abort() API the DMA TX/RX Transfer complete interrupt is generated
2615 and the correspond call back is executed HAL_SPI_TxCpltCallback() or HAL_SPI_RxCpltCallback() or HAL_SPI_TxRxCpltCallback()
2618 /* Abort the SPI DMA tx Stream/Channel */
2619 if (hspi
->hdmatx
!= NULL
)
2621 if (HAL_OK
!= HAL_DMA_Abort(hspi
->hdmatx
))
2623 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
2624 errorcode
= HAL_ERROR
;
2627 /* Abort the SPI DMA rx Stream/Channel */
2628 if (hspi
->hdmarx
!= NULL
)
2630 if (HAL_OK
!= HAL_DMA_Abort(hspi
->hdmarx
))
2632 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
2633 errorcode
= HAL_ERROR
;
2637 /* Disable the SPI DMA Tx & Rx requests */
2638 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
2639 hspi
->State
= HAL_SPI_STATE_READY
;
2644 * @brief Handle SPI interrupt request.
2645 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2646 * the configuration information for the specified SPI module.
2649 void HAL_SPI_IRQHandler(SPI_HandleTypeDef
*hspi
)
2651 uint32_t itsource
= hspi
->Instance
->CR2
;
2652 uint32_t itflag
= hspi
->Instance
->SR
;
2654 /* SPI in mode Receiver ----------------------------------------------------*/
2655 if ((SPI_CHECK_FLAG(itflag
, SPI_FLAG_OVR
) == RESET
) &&
2656 (SPI_CHECK_FLAG(itflag
, SPI_FLAG_RXNE
) != RESET
) && (SPI_CHECK_IT_SOURCE(itsource
, SPI_IT_RXNE
) != RESET
))
2662 /* SPI in mode Transmitter -------------------------------------------------*/
2663 if ((SPI_CHECK_FLAG(itflag
, SPI_FLAG_TXE
) != RESET
) && (SPI_CHECK_IT_SOURCE(itsource
, SPI_IT_TXE
) != RESET
))
2669 /* SPI in Error Treatment --------------------------------------------------*/
2670 if (((SPI_CHECK_FLAG(itflag
, SPI_FLAG_MODF
) != RESET
) || (SPI_CHECK_FLAG(itflag
, SPI_FLAG_OVR
) != RESET
) || (SPI_CHECK_FLAG(itflag
, SPI_FLAG_FRE
) != RESET
)) && (SPI_CHECK_IT_SOURCE(itsource
, SPI_IT_ERR
) != RESET
))
2672 /* SPI Overrun error interrupt occurred ----------------------------------*/
2673 if (SPI_CHECK_FLAG(itflag
, SPI_FLAG_OVR
) != RESET
)
2675 if (hspi
->State
!= HAL_SPI_STATE_BUSY_TX
)
2677 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_OVR
);
2678 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
2682 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
2687 /* SPI Mode Fault error interrupt occurred -------------------------------*/
2688 if (SPI_CHECK_FLAG(itflag
, SPI_FLAG_MODF
) != RESET
)
2690 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_MODF
);
2691 __HAL_SPI_CLEAR_MODFFLAG(hspi
);
2694 /* SPI Frame error interrupt occurred ------------------------------------*/
2695 if (SPI_CHECK_FLAG(itflag
, SPI_FLAG_FRE
) != RESET
)
2697 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FRE
);
2698 __HAL_SPI_CLEAR_FREFLAG(hspi
);
2701 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
2703 /* Disable all interrupts */
2704 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_RXNE
| SPI_IT_TXE
| SPI_IT_ERR
);
2706 hspi
->State
= HAL_SPI_STATE_READY
;
2707 /* Disable the SPI DMA requests if enabled */
2708 if ((HAL_IS_BIT_SET(itsource
, SPI_CR2_TXDMAEN
)) || (HAL_IS_BIT_SET(itsource
, SPI_CR2_RXDMAEN
)))
2710 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
));
2712 /* Abort the SPI DMA Rx channel */
2713 if (hspi
->hdmarx
!= NULL
)
2715 /* Set the SPI DMA Abort callback :
2716 will lead to call HAL_SPI_ErrorCallback() at end of DMA abort procedure */
2717 hspi
->hdmarx
->XferAbortCallback
= SPI_DMAAbortOnError
;
2718 if (HAL_OK
!= HAL_DMA_Abort_IT(hspi
->hdmarx
))
2720 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2723 /* Abort the SPI DMA Tx channel */
2724 if (hspi
->hdmatx
!= NULL
)
2726 /* Set the SPI DMA Abort callback :
2727 will lead to call HAL_SPI_ErrorCallback() at end of DMA abort procedure */
2728 hspi
->hdmatx
->XferAbortCallback
= SPI_DMAAbortOnError
;
2729 if (HAL_OK
!= HAL_DMA_Abort_IT(hspi
->hdmatx
))
2731 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
2737 /* Call user error callback */
2738 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
2739 hspi
->ErrorCallback(hspi
);
2741 HAL_SPI_ErrorCallback(hspi
);
2742 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
2750 * @brief Tx Transfer completed callback.
2751 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2752 * the configuration information for SPI module.
2755 __weak
void HAL_SPI_TxCpltCallback(SPI_HandleTypeDef
*hspi
)
2757 /* Prevent unused argument(s) compilation warning */
2760 /* NOTE : This function should not be modified, when the callback is needed,
2761 the HAL_SPI_TxCpltCallback should be implemented in the user file
2766 * @brief Rx Transfer completed callback.
2767 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2768 * the configuration information for SPI module.
2771 __weak
void HAL_SPI_RxCpltCallback(SPI_HandleTypeDef
*hspi
)
2773 /* Prevent unused argument(s) compilation warning */
2776 /* NOTE : This function should not be modified, when the callback is needed,
2777 the HAL_SPI_RxCpltCallback should be implemented in the user file
2782 * @brief Tx and Rx Transfer completed callback.
2783 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2784 * the configuration information for SPI module.
2787 __weak
void HAL_SPI_TxRxCpltCallback(SPI_HandleTypeDef
*hspi
)
2789 /* Prevent unused argument(s) compilation warning */
2792 /* NOTE : This function should not be modified, when the callback is needed,
2793 the HAL_SPI_TxRxCpltCallback should be implemented in the user file
2798 * @brief Tx Half Transfer completed callback.
2799 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2800 * the configuration information for SPI module.
2803 __weak
void HAL_SPI_TxHalfCpltCallback(SPI_HandleTypeDef
*hspi
)
2805 /* Prevent unused argument(s) compilation warning */
2808 /* NOTE : This function should not be modified, when the callback is needed,
2809 the HAL_SPI_TxHalfCpltCallback should be implemented in the user file
2814 * @brief Rx Half Transfer completed callback.
2815 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2816 * the configuration information for SPI module.
2819 __weak
void HAL_SPI_RxHalfCpltCallback(SPI_HandleTypeDef
*hspi
)
2821 /* Prevent unused argument(s) compilation warning */
2824 /* NOTE : This function should not be modified, when the callback is needed,
2825 the HAL_SPI_RxHalfCpltCallback() should be implemented in the user file
2830 * @brief Tx and Rx Half Transfer callback.
2831 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2832 * the configuration information for SPI module.
2835 __weak
void HAL_SPI_TxRxHalfCpltCallback(SPI_HandleTypeDef
*hspi
)
2837 /* Prevent unused argument(s) compilation warning */
2840 /* NOTE : This function should not be modified, when the callback is needed,
2841 the HAL_SPI_TxRxHalfCpltCallback() should be implemented in the user file
2846 * @brief SPI error callback.
2847 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2848 * the configuration information for SPI module.
2851 __weak
void HAL_SPI_ErrorCallback(SPI_HandleTypeDef
*hspi
)
2853 /* Prevent unused argument(s) compilation warning */
2856 /* NOTE : This function should not be modified, when the callback is needed,
2857 the HAL_SPI_ErrorCallback should be implemented in the user file
2859 /* NOTE : The ErrorCode parameter in the hspi handle is updated by the SPI processes
2860 and user can use HAL_SPI_GetError() API to check the latest error occurred
2865 * @brief SPI Abort Complete callback.
2866 * @param hspi SPI handle.
2869 __weak
void HAL_SPI_AbortCpltCallback(SPI_HandleTypeDef
*hspi
)
2871 /* Prevent unused argument(s) compilation warning */
2874 /* NOTE : This function should not be modified, when the callback is needed,
2875 the HAL_SPI_AbortCpltCallback can be implemented in the user file.
2883 /** @defgroup SPI_Exported_Functions_Group3 Peripheral State and Errors functions
2884 * @brief SPI control functions
2887 ===============================================================================
2888 ##### Peripheral State and Errors functions #####
2889 ===============================================================================
2891 This subsection provides a set of functions allowing to control the SPI.
2892 (+) HAL_SPI_GetState() API can be helpful to check in run-time the state of the SPI peripheral
2893 (+) HAL_SPI_GetError() check in run-time Errors occurring during communication
2899 * @brief Return the SPI handle state.
2900 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2901 * the configuration information for SPI module.
2904 HAL_SPI_StateTypeDef
HAL_SPI_GetState(SPI_HandleTypeDef
*hspi
)
2906 /* Return SPI handle state */
2911 * @brief Return the SPI error code.
2912 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
2913 * the configuration information for SPI module.
2914 * @retval SPI error code in bitmap format
2916 uint32_t HAL_SPI_GetError(SPI_HandleTypeDef
*hspi
)
2918 /* Return SPI ErrorCode */
2919 return hspi
->ErrorCode
;
2930 /** @addtogroup SPI_Private_Functions
2931 * @brief Private functions
2936 * @brief DMA SPI transmit process complete callback.
2937 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
2938 * the configuration information for the specified DMA module.
2941 static void SPI_DMATransmitCplt(DMA_HandleTypeDef
*hdma
)
2943 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
2946 /* Init tickstart for timeout management*/
2947 tickstart
= HAL_GetTick();
2949 /* DMA Normal Mode */
2950 if ((hdma
->Instance
->CR
& DMA_SxCR_CIRC
) != DMA_SxCR_CIRC
)
2952 /* Disable ERR interrupt */
2953 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_ERR
);
2955 /* Disable Tx DMA Request */
2956 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
);
2958 /* Check the end of the transaction */
2959 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
2961 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
2964 /* Clear overrun flag in 2 Lines communication mode because received data is not read */
2965 if (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
)
2967 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
2970 hspi
->TxXferCount
= 0U;
2971 hspi
->State
= HAL_SPI_STATE_READY
;
2973 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
2975 /* Call user error callback */
2976 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
2977 hspi
->ErrorCallback(hspi
);
2979 HAL_SPI_ErrorCallback(hspi
);
2980 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
2984 /* Call user Tx complete callback */
2985 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
2986 hspi
->TxCpltCallback(hspi
);
2988 HAL_SPI_TxCpltCallback(hspi
);
2989 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
2993 * @brief DMA SPI receive process complete callback.
2994 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
2995 * the configuration information for the specified DMA module.
2998 static void SPI_DMAReceiveCplt(DMA_HandleTypeDef
*hdma
)
3000 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3003 /* Init tickstart for timeout management*/
3004 tickstart
= HAL_GetTick();
3006 /* DMA Normal Mode */
3007 if ((hdma
->Instance
->CR
& DMA_SxCR_CIRC
) != DMA_SxCR_CIRC
)
3009 /* Disable ERR interrupt */
3010 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_ERR
);
3012 #if (USE_SPI_CRC != 0U)
3014 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3016 /* Wait until RXNE flag */
3017 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3019 /* Error on the CRC reception */
3020 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3023 if (hspi
->Init
.DataSize
> SPI_DATASIZE_8BIT
)
3025 /* Read 16bit CRC */
3026 READ_REG(hspi
->Instance
->DR
);
3031 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3033 if (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_16BIT
)
3035 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_RXNE
, SET
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3037 /* Error on the CRC reception */
3038 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3040 /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */
3041 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3045 #endif /* USE_SPI_CRC */
3047 /* Disable Rx/Tx DMA Request (done by default to handle the case master rx direction 2 lines) */
3048 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
3050 /* Check the end of the transaction */
3051 if (SPI_EndRxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3053 hspi
->ErrorCode
= HAL_SPI_ERROR_FLAG
;
3056 hspi
->RxXferCount
= 0U;
3057 hspi
->State
= HAL_SPI_STATE_READY
;
3059 #if (USE_SPI_CRC != 0U)
3060 /* Check if CRC error occurred */
3061 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
))
3063 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3064 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
3066 #endif /* USE_SPI_CRC */
3068 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
3070 /* Call user error callback */
3071 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3072 hspi
->ErrorCallback(hspi
);
3074 HAL_SPI_ErrorCallback(hspi
);
3075 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3079 /* Call user Rx complete callback */
3080 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3081 hspi
->RxCpltCallback(hspi
);
3083 HAL_SPI_RxCpltCallback(hspi
);
3084 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3088 * @brief DMA SPI transmit receive process complete callback.
3089 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
3090 * the configuration information for the specified DMA module.
3093 static void SPI_DMATransmitReceiveCplt(DMA_HandleTypeDef
*hdma
)
3095 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3098 /* Init tickstart for timeout management*/
3099 tickstart
= HAL_GetTick();
3101 /* DMA Normal Mode */
3102 if ((hdma
->Instance
->CR
& DMA_SxCR_CIRC
) != DMA_SxCR_CIRC
)
3104 /* Disable ERR interrupt */
3105 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_ERR
);
3107 #if (USE_SPI_CRC != 0U)
3109 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3111 if ((hspi
->Init
.DataSize
== SPI_DATASIZE_8BIT
) && (hspi
->Init
.CRCLength
== SPI_CRC_LENGTH_8BIT
))
3113 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_QUARTER_FULL
, SPI_DEFAULT_TIMEOUT
,
3114 tickstart
) != HAL_OK
)
3116 /* Error on the CRC reception */
3117 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3119 /* Read CRC to Flush DR and RXNE flag */
3120 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3124 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_HALF_FULL
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3126 /* Error on the CRC reception */
3127 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3129 /* Read CRC to Flush DR and RXNE flag */
3130 READ_REG(hspi
->Instance
->DR
);
3133 #endif /* USE_SPI_CRC */
3135 /* Check the end of the transaction */
3136 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3138 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3141 /* Disable Rx/Tx DMA Request */
3142 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
3144 hspi
->TxXferCount
= 0U;
3145 hspi
->RxXferCount
= 0U;
3146 hspi
->State
= HAL_SPI_STATE_READY
;
3148 #if (USE_SPI_CRC != 0U)
3149 /* Check if CRC error occurred */
3150 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
))
3152 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3153 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
3155 #endif /* USE_SPI_CRC */
3157 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
3159 /* Call user error callback */
3160 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3161 hspi
->ErrorCallback(hspi
);
3163 HAL_SPI_ErrorCallback(hspi
);
3164 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3168 /* Call user TxRx complete callback */
3169 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3170 hspi
->TxRxCpltCallback(hspi
);
3172 HAL_SPI_TxRxCpltCallback(hspi
);
3173 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3177 * @brief DMA SPI half transmit process complete callback.
3178 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
3179 * the configuration information for the specified DMA module.
3182 static void SPI_DMAHalfTransmitCplt(DMA_HandleTypeDef
*hdma
)
3184 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3186 /* Call user Tx half complete callback */
3187 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3188 hspi
->TxHalfCpltCallback(hspi
);
3190 HAL_SPI_TxHalfCpltCallback(hspi
);
3191 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3195 * @brief DMA SPI half receive process complete callback
3196 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
3197 * the configuration information for the specified DMA module.
3200 static void SPI_DMAHalfReceiveCplt(DMA_HandleTypeDef
*hdma
)
3202 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3204 /* Call user Rx half complete callback */
3205 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3206 hspi
->RxHalfCpltCallback(hspi
);
3208 HAL_SPI_RxHalfCpltCallback(hspi
);
3209 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3213 * @brief DMA SPI half transmit receive process complete callback.
3214 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
3215 * the configuration information for the specified DMA module.
3218 static void SPI_DMAHalfTransmitReceiveCplt(DMA_HandleTypeDef
*hdma
)
3220 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3222 /* Call user TxRx half complete callback */
3223 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3224 hspi
->TxRxHalfCpltCallback(hspi
);
3226 HAL_SPI_TxRxHalfCpltCallback(hspi
);
3227 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3231 * @brief DMA SPI communication error callback.
3232 * @param hdma pointer to a DMA_HandleTypeDef structure that contains
3233 * the configuration information for the specified DMA module.
3236 static void SPI_DMAError(DMA_HandleTypeDef
*hdma
)
3238 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3240 /* Stop the disable DMA transfer on SPI side */
3241 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
| SPI_CR2_RXDMAEN
);
3243 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_DMA
);
3244 hspi
->State
= HAL_SPI_STATE_READY
;
3245 /* Call user error callback */
3246 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3247 hspi
->ErrorCallback(hspi
);
3249 HAL_SPI_ErrorCallback(hspi
);
3250 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3254 * @brief DMA SPI communication abort callback, when initiated by HAL services on Error
3255 * (To be called at end of DMA Abort procedure following error occurrence).
3256 * @param hdma DMA handle.
3259 static void SPI_DMAAbortOnError(DMA_HandleTypeDef
*hdma
)
3261 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3262 hspi
->RxXferCount
= 0U;
3263 hspi
->TxXferCount
= 0U;
3265 /* Call user error callback */
3266 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3267 hspi
->ErrorCallback(hspi
);
3269 HAL_SPI_ErrorCallback(hspi
);
3270 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3274 * @brief DMA SPI Tx communication abort callback, when initiated by user
3275 * (To be called at end of DMA Tx Abort procedure following user abort request).
3276 * @note When this callback is executed, User Abort complete call back is called only if no
3277 * Abort still ongoing for Rx DMA Handle.
3278 * @param hdma DMA handle.
3281 static void SPI_DMATxAbortCallback(DMA_HandleTypeDef
*hdma
)
3283 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3285 hspi
->hdmatx
->XferAbortCallback
= NULL
;
3287 /* Disable Tx DMA Request */
3288 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_TXDMAEN
);
3290 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
3292 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
3295 /* Disable SPI Peripheral */
3296 __HAL_SPI_DISABLE(hspi
);
3298 /* Empty the FRLVL fifo */
3299 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
3301 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
3304 /* Check if an Abort process is still ongoing */
3305 if (hspi
->hdmarx
!= NULL
)
3307 if (hspi
->hdmarx
->XferAbortCallback
!= NULL
)
3313 /* No Abort process still ongoing : All DMA Stream/Channel are aborted, call user Abort Complete callback */
3314 hspi
->RxXferCount
= 0U;
3315 hspi
->TxXferCount
= 0U;
3317 /* Check no error during Abort procedure */
3318 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_ABORT
)
3320 /* Reset errorCode */
3321 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
3324 /* Clear the Error flags in the SR register */
3325 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
3326 __HAL_SPI_CLEAR_FREFLAG(hspi
);
3328 /* Restore hspi->State to Ready */
3329 hspi
->State
= HAL_SPI_STATE_READY
;
3331 /* Call user Abort complete callback */
3332 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3333 hspi
->AbortCpltCallback(hspi
);
3335 HAL_SPI_AbortCpltCallback(hspi
);
3336 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3340 * @brief DMA SPI Rx communication abort callback, when initiated by user
3341 * (To be called at end of DMA Rx Abort procedure following user abort request).
3342 * @note When this callback is executed, User Abort complete call back is called only if no
3343 * Abort still ongoing for Tx DMA Handle.
3344 * @param hdma DMA handle.
3347 static void SPI_DMARxAbortCallback(DMA_HandleTypeDef
*hdma
)
3349 SPI_HandleTypeDef
*hspi
= (SPI_HandleTypeDef
*)(((DMA_HandleTypeDef
*)hdma
)->Parent
); /* Derogation MISRAC2012-Rule-11.5 */
3351 /* Disable SPI Peripheral */
3352 __HAL_SPI_DISABLE(hspi
);
3354 hspi
->hdmarx
->XferAbortCallback
= NULL
;
3356 /* Disable Rx DMA Request */
3357 CLEAR_BIT(hspi
->Instance
->CR2
, SPI_CR2_RXDMAEN
);
3359 /* Control the BSY flag */
3360 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
3362 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
3365 /* Empty the FRLVL fifo */
3366 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
3368 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
3371 /* Check if an Abort process is still ongoing */
3372 if (hspi
->hdmatx
!= NULL
)
3374 if (hspi
->hdmatx
->XferAbortCallback
!= NULL
)
3380 /* No Abort process still ongoing : All DMA Stream/Channel are aborted, call user Abort Complete callback */
3381 hspi
->RxXferCount
= 0U;
3382 hspi
->TxXferCount
= 0U;
3384 /* Check no error during Abort procedure */
3385 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_ABORT
)
3387 /* Reset errorCode */
3388 hspi
->ErrorCode
= HAL_SPI_ERROR_NONE
;
3391 /* Clear the Error flags in the SR register */
3392 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
3393 __HAL_SPI_CLEAR_FREFLAG(hspi
);
3395 /* Restore hspi->State to Ready */
3396 hspi
->State
= HAL_SPI_STATE_READY
;
3398 /* Call user Abort complete callback */
3399 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3400 hspi
->AbortCpltCallback(hspi
);
3402 HAL_SPI_AbortCpltCallback(hspi
);
3403 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3407 * @brief Rx 8-bit handler for Transmit and Receive in Interrupt mode.
3408 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3409 * the configuration information for SPI module.
3412 static void SPI_2linesRxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
)
3414 /* Receive data in packing mode */
3415 if (hspi
->RxXferCount
> 1U)
3417 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)(hspi
->Instance
->DR
);
3418 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
3419 hspi
->RxXferCount
-= 2U;
3420 if (hspi
->RxXferCount
== 1U)
3422 /* Set RX Fifo threshold according the reception data length: 8bit */
3423 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
3426 /* Receive data in 8 Bit mode */
3429 *hspi
->pRxBuffPtr
= *((__IO
uint8_t *)&hspi
->Instance
->DR
);
3431 hspi
->RxXferCount
--;
3434 /* Check end of the reception */
3435 if (hspi
->RxXferCount
== 0U)
3437 #if (USE_SPI_CRC != 0U)
3438 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3440 SET_BIT(hspi
->Instance
->CR2
, SPI_RXFIFO_THRESHOLD
);
3441 hspi
->RxISR
= SPI_2linesRxISR_8BITCRC
;
3444 #endif /* USE_SPI_CRC */
3446 /* Disable RXNE and ERR interrupt */
3447 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_RXNE
| SPI_IT_ERR
));
3449 if (hspi
->TxXferCount
== 0U)
3451 SPI_CloseRxTx_ISR(hspi
);
3456 #if (USE_SPI_CRC != 0U)
3458 * @brief Rx 8-bit handler for Transmit and Receive in Interrupt mode.
3459 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3460 * the configuration information for SPI module.
3463 static void SPI_2linesRxISR_8BITCRC(struct __SPI_HandleTypeDef
*hspi
)
3465 /* Read 8bit CRC to flush Data Regsiter */
3466 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3470 /* Check end of the reception */
3471 if (hspi
->CRCSize
== 0U)
3473 /* Disable RXNE and ERR interrupt */
3474 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_RXNE
| SPI_IT_ERR
));
3476 if (hspi
->TxXferCount
== 0U)
3478 SPI_CloseRxTx_ISR(hspi
);
3482 #endif /* USE_SPI_CRC */
3485 * @brief Tx 8-bit handler for Transmit and Receive in Interrupt mode.
3486 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3487 * the configuration information for SPI module.
3490 static void SPI_2linesTxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
)
3492 /* Transmit data in packing Bit mode */
3493 if (hspi
->TxXferCount
>= 2U)
3495 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
3496 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
3497 hspi
->TxXferCount
-= 2U;
3499 /* Transmit data in 8 Bit mode */
3502 *(__IO
uint8_t *)&hspi
->Instance
->DR
= (*hspi
->pTxBuffPtr
);
3504 hspi
->TxXferCount
--;
3507 /* Check the end of the transmission */
3508 if (hspi
->TxXferCount
== 0U)
3510 #if (USE_SPI_CRC != 0U)
3511 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3513 /* Set CRC Next Bit to send CRC */
3514 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3515 /* Disable TXE interrupt */
3516 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_TXE
);
3519 #endif /* USE_SPI_CRC */
3521 /* Disable TXE interrupt */
3522 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_TXE
);
3524 if (hspi
->RxXferCount
== 0U)
3526 SPI_CloseRxTx_ISR(hspi
);
3532 * @brief Rx 16-bit handler for Transmit and Receive in Interrupt mode.
3533 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3534 * the configuration information for SPI module.
3537 static void SPI_2linesRxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
)
3539 /* Receive data in 16 Bit mode */
3540 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)(hspi
->Instance
->DR
);
3541 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
3542 hspi
->RxXferCount
--;
3544 if (hspi
->RxXferCount
== 0U)
3546 #if (USE_SPI_CRC != 0U)
3547 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3549 hspi
->RxISR
= SPI_2linesRxISR_16BITCRC
;
3552 #endif /* USE_SPI_CRC */
3554 /* Disable RXNE interrupt */
3555 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_RXNE
);
3557 if (hspi
->TxXferCount
== 0U)
3559 SPI_CloseRxTx_ISR(hspi
);
3564 #if (USE_SPI_CRC != 0U)
3566 * @brief Manage the CRC 16-bit receive for Transmit and Receive in Interrupt mode.
3567 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3568 * the configuration information for SPI module.
3571 static void SPI_2linesRxISR_16BITCRC(struct __SPI_HandleTypeDef
*hspi
)
3573 /* Read 16bit CRC to flush Data Regsiter */
3574 READ_REG(hspi
->Instance
->DR
);
3576 /* Disable RXNE interrupt */
3577 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_RXNE
);
3579 SPI_CloseRxTx_ISR(hspi
);
3581 #endif /* USE_SPI_CRC */
3584 * @brief Tx 16-bit handler for Transmit and Receive in Interrupt mode.
3585 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3586 * the configuration information for SPI module.
3589 static void SPI_2linesTxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
)
3591 /* Transmit data in 16 Bit mode */
3592 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
3593 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
3594 hspi
->TxXferCount
--;
3596 /* Enable CRC Transmission */
3597 if (hspi
->TxXferCount
== 0U)
3599 #if (USE_SPI_CRC != 0U)
3600 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3602 /* Set CRC Next Bit to send CRC */
3603 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3604 /* Disable TXE interrupt */
3605 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_TXE
);
3608 #endif /* USE_SPI_CRC */
3610 /* Disable TXE interrupt */
3611 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_TXE
);
3613 if (hspi
->RxXferCount
== 0U)
3615 SPI_CloseRxTx_ISR(hspi
);
3620 #if (USE_SPI_CRC != 0U)
3622 * @brief Manage the CRC 8-bit receive in Interrupt context.
3623 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3624 * the configuration information for SPI module.
3627 static void SPI_RxISR_8BITCRC(struct __SPI_HandleTypeDef
*hspi
)
3629 /* Read 8bit CRC to flush Data Register */
3630 READ_REG(*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3634 if (hspi
->CRCSize
== 0U)
3636 SPI_CloseRx_ISR(hspi
);
3639 #endif /* USE_SPI_CRC */
3642 * @brief Manage the receive 8-bit in Interrupt context.
3643 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3644 * the configuration information for SPI module.
3647 static void SPI_RxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
)
3649 *hspi
->pRxBuffPtr
= (*(__IO
uint8_t *)&hspi
->Instance
->DR
);
3651 hspi
->RxXferCount
--;
3653 #if (USE_SPI_CRC != 0U)
3654 /* Enable CRC Transmission */
3655 if ((hspi
->RxXferCount
== 1U) && (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
))
3657 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3659 #endif /* USE_SPI_CRC */
3661 if (hspi
->RxXferCount
== 0U)
3663 #if (USE_SPI_CRC != 0U)
3664 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3666 hspi
->RxISR
= SPI_RxISR_8BITCRC
;
3669 #endif /* USE_SPI_CRC */
3670 SPI_CloseRx_ISR(hspi
);
3674 #if (USE_SPI_CRC != 0U)
3676 * @brief Manage the CRC 16-bit receive in Interrupt context.
3677 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3678 * the configuration information for SPI module.
3681 static void SPI_RxISR_16BITCRC(struct __SPI_HandleTypeDef
*hspi
)
3683 /* Read 16bit CRC to flush Data Register */
3684 READ_REG(hspi
->Instance
->DR
);
3686 /* Disable RXNE and ERR interrupt */
3687 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_RXNE
| SPI_IT_ERR
));
3689 SPI_CloseRx_ISR(hspi
);
3691 #endif /* USE_SPI_CRC */
3694 * @brief Manage the 16-bit receive in Interrupt context.
3695 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3696 * the configuration information for SPI module.
3699 static void SPI_RxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
)
3701 *((uint16_t *)hspi
->pRxBuffPtr
) = (uint16_t)(hspi
->Instance
->DR
);
3702 hspi
->pRxBuffPtr
+= sizeof(uint16_t);
3703 hspi
->RxXferCount
--;
3705 #if (USE_SPI_CRC != 0U)
3706 /* Enable CRC Transmission */
3707 if ((hspi
->RxXferCount
== 1U) && (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
))
3709 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3711 #endif /* USE_SPI_CRC */
3713 if (hspi
->RxXferCount
== 0U)
3715 #if (USE_SPI_CRC != 0U)
3716 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3718 hspi
->RxISR
= SPI_RxISR_16BITCRC
;
3721 #endif /* USE_SPI_CRC */
3722 SPI_CloseRx_ISR(hspi
);
3727 * @brief Handle the data 8-bit transmit in Interrupt mode.
3728 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3729 * the configuration information for SPI module.
3732 static void SPI_TxISR_8BIT(struct __SPI_HandleTypeDef
*hspi
)
3734 *(__IO
uint8_t *)&hspi
->Instance
->DR
= (*hspi
->pTxBuffPtr
);
3736 hspi
->TxXferCount
--;
3738 if (hspi
->TxXferCount
== 0U)
3740 #if (USE_SPI_CRC != 0U)
3741 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3743 /* Enable CRC Transmission */
3744 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3746 #endif /* USE_SPI_CRC */
3747 SPI_CloseTx_ISR(hspi
);
3752 * @brief Handle the data 16-bit transmit in Interrupt mode.
3753 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3754 * the configuration information for SPI module.
3757 static void SPI_TxISR_16BIT(struct __SPI_HandleTypeDef
*hspi
)
3759 /* Transmit data in 16 Bit mode */
3760 hspi
->Instance
->DR
= *((uint16_t *)hspi
->pTxBuffPtr
);
3761 hspi
->pTxBuffPtr
+= sizeof(uint16_t);
3762 hspi
->TxXferCount
--;
3764 if (hspi
->TxXferCount
== 0U)
3766 #if (USE_SPI_CRC != 0U)
3767 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3769 /* Enable CRC Transmission */
3770 SET_BIT(hspi
->Instance
->CR1
, SPI_CR1_CRCNEXT
);
3772 #endif /* USE_SPI_CRC */
3773 SPI_CloseTx_ISR(hspi
);
3778 * @brief Handle SPI Communication Timeout.
3779 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3780 * the configuration information for SPI module.
3781 * @param Flag SPI flag to check
3782 * @param State flag state to check
3783 * @param Timeout Timeout duration
3784 * @param Tickstart tick start value
3785 * @retval HAL status
3787 static HAL_StatusTypeDef
SPI_WaitFlagStateUntilTimeout(SPI_HandleTypeDef
*hspi
, uint32_t Flag
, FlagStatus State
,
3788 uint32_t Timeout
, uint32_t Tickstart
)
3790 while ((__HAL_SPI_GET_FLAG(hspi
, Flag
) ? SET
: RESET
) != State
)
3792 if (Timeout
!= HAL_MAX_DELAY
)
3794 if (((HAL_GetTick() - Tickstart
) >= Timeout
) || (Timeout
== 0U))
3796 /* Disable the SPI and reset the CRC: the CRC value should be cleared
3797 on both master and slave sides in order to resynchronize the master
3798 and slave for their respective CRC calculation */
3800 /* Disable TXE, RXNE and ERR interrupts for the interrupt process */
3801 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_TXE
| SPI_IT_RXNE
| SPI_IT_ERR
));
3803 if ((hspi
->Init
.Mode
== SPI_MODE_MASTER
) && ((hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
3804 || (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES_RXONLY
)))
3806 /* Disable SPI peripheral */
3807 __HAL_SPI_DISABLE(hspi
);
3810 /* Reset CRC Calculation */
3811 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3813 SPI_RESET_CRC(hspi
);
3816 hspi
->State
= HAL_SPI_STATE_READY
;
3818 /* Process Unlocked */
3830 * @brief Handle SPI FIFO Communication Timeout.
3831 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3832 * the configuration information for SPI module.
3833 * @param Fifo Fifo to check
3834 * @param State Fifo state to check
3835 * @param Timeout Timeout duration
3836 * @param Tickstart tick start value
3837 * @retval HAL status
3839 static HAL_StatusTypeDef
SPI_WaitFifoStateUntilTimeout(SPI_HandleTypeDef
*hspi
, uint32_t Fifo
, uint32_t State
,
3840 uint32_t Timeout
, uint32_t Tickstart
)
3842 while ((hspi
->Instance
->SR
& Fifo
) != State
)
3844 if ((Fifo
== SPI_SR_FRLVL
) && (State
== SPI_FRLVL_EMPTY
))
3846 /* Read 8bit CRC to flush Data Register */
3847 READ_REG(*((__IO
uint8_t *)&hspi
->Instance
->DR
));
3850 if (Timeout
!= HAL_MAX_DELAY
)
3852 if (((HAL_GetTick() - Tickstart
) >= Timeout
) || (Timeout
== 0U))
3854 /* Disable the SPI and reset the CRC: the CRC value should be cleared
3855 on both master and slave sides in order to resynchronize the master
3856 and slave for their respective CRC calculation */
3858 /* Disable TXE, RXNE and ERR interrupts for the interrupt process */
3859 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_TXE
| SPI_IT_RXNE
| SPI_IT_ERR
));
3861 if ((hspi
->Init
.Mode
== SPI_MODE_MASTER
) && ((hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
3862 || (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES_RXONLY
)))
3864 /* Disable SPI peripheral */
3865 __HAL_SPI_DISABLE(hspi
);
3868 /* Reset CRC Calculation */
3869 if (hspi
->Init
.CRCCalculation
== SPI_CRCCALCULATION_ENABLE
)
3871 SPI_RESET_CRC(hspi
);
3874 hspi
->State
= HAL_SPI_STATE_READY
;
3876 /* Process Unlocked */
3888 * @brief Handle the check of the RX transaction complete.
3889 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3890 * the configuration information for SPI module.
3891 * @param Timeout Timeout duration
3892 * @param Tickstart tick start value
3893 * @retval HAL status
3895 static HAL_StatusTypeDef
SPI_EndRxTransaction(SPI_HandleTypeDef
*hspi
, uint32_t Timeout
, uint32_t Tickstart
)
3897 if ((hspi
->Init
.Mode
== SPI_MODE_MASTER
) && ((hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
3898 || (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES_RXONLY
)))
3900 /* Disable SPI peripheral */
3901 __HAL_SPI_DISABLE(hspi
);
3904 /* Control the BSY flag */
3905 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, Timeout
, Tickstart
) != HAL_OK
)
3907 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3911 if ((hspi
->Init
.Mode
== SPI_MODE_MASTER
) && ((hspi
->Init
.Direction
== SPI_DIRECTION_1LINE
)
3912 || (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES_RXONLY
)))
3914 /* Empty the FRLVL fifo */
3915 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, Timeout
, Tickstart
) != HAL_OK
)
3917 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3925 * @brief Handle the check of the RXTX or TX transaction complete.
3926 * @param hspi SPI handle
3927 * @param Timeout Timeout duration
3928 * @param Tickstart tick start value
3929 * @retval HAL status
3931 static HAL_StatusTypeDef
SPI_EndRxTxTransaction(SPI_HandleTypeDef
*hspi
, uint32_t Timeout
, uint32_t Tickstart
)
3933 /* Control if the TX fifo is empty */
3934 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FTLVL
, SPI_FTLVL_EMPTY
, Timeout
, Tickstart
) != HAL_OK
)
3936 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3940 /* Control the BSY flag */
3941 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, Timeout
, Tickstart
) != HAL_OK
)
3943 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3947 /* Control if the RX fifo is empty */
3948 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, Timeout
, Tickstart
) != HAL_OK
)
3950 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3958 * @brief Handle the end of the RXTX transaction.
3959 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
3960 * the configuration information for SPI module.
3963 static void SPI_CloseRxTx_ISR(SPI_HandleTypeDef
*hspi
)
3967 /* Init tickstart for timeout managment*/
3968 tickstart
= HAL_GetTick();
3970 /* Disable ERR interrupt */
3971 __HAL_SPI_DISABLE_IT(hspi
, SPI_IT_ERR
);
3973 /* Check the end of the transaction */
3974 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
3976 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
3979 #if (USE_SPI_CRC != 0U)
3980 /* Check if CRC error occurred */
3981 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
) != RESET
)
3983 hspi
->State
= HAL_SPI_STATE_READY
;
3984 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
3985 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
3986 /* Call user error callback */
3987 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
3988 hspi
->ErrorCallback(hspi
);
3990 HAL_SPI_ErrorCallback(hspi
);
3991 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
3995 #endif /* USE_SPI_CRC */
3996 if (hspi
->ErrorCode
== HAL_SPI_ERROR_NONE
)
3998 if (hspi
->State
== HAL_SPI_STATE_BUSY_RX
)
4000 hspi
->State
= HAL_SPI_STATE_READY
;
4001 /* Call user Rx complete callback */
4002 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4003 hspi
->RxCpltCallback(hspi
);
4005 HAL_SPI_RxCpltCallback(hspi
);
4006 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4010 hspi
->State
= HAL_SPI_STATE_READY
;
4011 /* Call user TxRx complete callback */
4012 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4013 hspi
->TxRxCpltCallback(hspi
);
4015 HAL_SPI_TxRxCpltCallback(hspi
);
4016 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4021 hspi
->State
= HAL_SPI_STATE_READY
;
4022 /* Call user error callback */
4023 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4024 hspi
->ErrorCallback(hspi
);
4026 HAL_SPI_ErrorCallback(hspi
);
4027 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4029 #if (USE_SPI_CRC != 0U)
4031 #endif /* USE_SPI_CRC */
4035 * @brief Handle the end of the RX transaction.
4036 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
4037 * the configuration information for SPI module.
4040 static void SPI_CloseRx_ISR(SPI_HandleTypeDef
*hspi
)
4042 /* Disable RXNE and ERR interrupt */
4043 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_RXNE
| SPI_IT_ERR
));
4045 /* Check the end of the transaction */
4046 if (SPI_EndRxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4048 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
4050 hspi
->State
= HAL_SPI_STATE_READY
;
4052 #if (USE_SPI_CRC != 0U)
4053 /* Check if CRC error occurred */
4054 if (__HAL_SPI_GET_FLAG(hspi
, SPI_FLAG_CRCERR
) != RESET
)
4056 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_CRC
);
4057 __HAL_SPI_CLEAR_CRCERRFLAG(hspi
);
4058 /* Call user error callback */
4059 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4060 hspi
->ErrorCallback(hspi
);
4062 HAL_SPI_ErrorCallback(hspi
);
4063 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4067 #endif /* USE_SPI_CRC */
4068 if (hspi
->ErrorCode
== HAL_SPI_ERROR_NONE
)
4070 /* Call user Rx complete callback */
4071 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4072 hspi
->RxCpltCallback(hspi
);
4074 HAL_SPI_RxCpltCallback(hspi
);
4075 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4079 /* Call user error callback */
4080 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4081 hspi
->ErrorCallback(hspi
);
4083 HAL_SPI_ErrorCallback(hspi
);
4084 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4086 #if (USE_SPI_CRC != 0U)
4088 #endif /* USE_SPI_CRC */
4092 * @brief Handle the end of the TX transaction.
4093 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
4094 * the configuration information for SPI module.
4097 static void SPI_CloseTx_ISR(SPI_HandleTypeDef
*hspi
)
4101 /* Init tickstart for timeout management*/
4102 tickstart
= HAL_GetTick();
4104 /* Disable TXE and ERR interrupt */
4105 __HAL_SPI_DISABLE_IT(hspi
, (SPI_IT_TXE
| SPI_IT_ERR
));
4107 /* Check the end of the transaction */
4108 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, tickstart
) != HAL_OK
)
4110 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_FLAG
);
4113 /* Clear overrun flag in 2 Lines communication mode because received is not read */
4114 if (hspi
->Init
.Direction
== SPI_DIRECTION_2LINES
)
4116 __HAL_SPI_CLEAR_OVRFLAG(hspi
);
4119 hspi
->State
= HAL_SPI_STATE_READY
;
4120 if (hspi
->ErrorCode
!= HAL_SPI_ERROR_NONE
)
4122 /* Call user error callback */
4123 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4124 hspi
->ErrorCallback(hspi
);
4126 HAL_SPI_ErrorCallback(hspi
);
4127 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4131 /* Call user Rx complete callback */
4132 #if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U)
4133 hspi
->TxCpltCallback(hspi
);
4135 HAL_SPI_TxCpltCallback(hspi
);
4136 #endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
4141 * @brief Handle abort a Rx transaction.
4142 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
4143 * the configuration information for SPI module.
4146 static void SPI_AbortRx_ISR(SPI_HandleTypeDef
*hspi
)
4148 __IO
uint32_t count
;
4150 /* Disable SPI Peripheral */
4151 __HAL_SPI_DISABLE(hspi
);
4153 count
= SPI_DEFAULT_TIMEOUT
* (SystemCoreClock
/ 24U / 1000U);
4155 /* Disable RXNEIE interrupt */
4156 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_RXNEIE
));
4158 /* Check RXNEIE is disabled */
4163 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
4168 while (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXNEIE
));
4170 /* Control the BSY flag */
4171 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4173 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4176 /* Empty the FRLVL fifo */
4177 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4179 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4182 hspi
->State
= HAL_SPI_STATE_ABORT
;
4186 * @brief Handle abort a Tx or Rx/Tx transaction.
4187 * @param hspi pointer to a SPI_HandleTypeDef structure that contains
4188 * the configuration information for SPI module.
4191 static void SPI_AbortTx_ISR(SPI_HandleTypeDef
*hspi
)
4193 __IO
uint32_t count
;
4195 count
= SPI_DEFAULT_TIMEOUT
* (SystemCoreClock
/ 24U / 1000U);
4197 /* Disable TXEIE interrupt */
4198 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_TXEIE
));
4200 /* Check TXEIE is disabled */
4205 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
4210 while (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_TXEIE
));
4212 if (SPI_EndRxTxTransaction(hspi
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4214 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4217 /* Disable SPI Peripheral */
4218 __HAL_SPI_DISABLE(hspi
);
4220 /* Empty the FRLVL fifo */
4221 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4223 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4226 /* Check case of Full-Duplex Mode and disable directly RXNEIE interrupt */
4227 if (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXNEIE
))
4229 /* Disable RXNEIE interrupt */
4230 CLEAR_BIT(hspi
->Instance
->CR2
, (SPI_CR2_RXNEIE
));
4232 /* Check RXNEIE is disabled */
4237 SET_BIT(hspi
->ErrorCode
, HAL_SPI_ERROR_ABORT
);
4242 while (HAL_IS_BIT_SET(hspi
->Instance
->CR2
, SPI_CR2_RXNEIE
));
4244 /* Control the BSY flag */
4245 if (SPI_WaitFlagStateUntilTimeout(hspi
, SPI_FLAG_BSY
, RESET
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4247 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4250 /* Empty the FRLVL fifo */
4251 if (SPI_WaitFifoStateUntilTimeout(hspi
, SPI_FLAG_FRLVL
, SPI_FRLVL_EMPTY
, SPI_DEFAULT_TIMEOUT
, HAL_GetTick()) != HAL_OK
)
4253 hspi
->ErrorCode
= HAL_SPI_ERROR_ABORT
;
4256 hspi
->State
= HAL_SPI_STATE_ABORT
;
4263 #endif /* HAL_SPI_MODULE_ENABLED */
4273 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/