Merge maintenance-8.x.x fixes into master
[inav.git] / lib / main / STM32H7 / Drivers / STM32H7xx_HAL_Driver / Src / stm32h7xx_hal_smartcard.c
blobd8742f742b5c5bade32c311ba662360694af61e7
1 /**
2 ******************************************************************************
3 * @file stm32h7xx_hal_smartcard.c
4 * @author MCD Application Team
5 * @brief SMARTCARD HAL module driver.
6 * This file provides firmware functions to manage the following
7 * functionalities of the SMARTCARD peripheral:
8 * + Initialization and de-initialization functions
9 * + IO operation functions
10 * + Peripheral Control functions
11 * + Peripheral State and Error functions
13 ******************************************************************************
14 * @attention
16 * Copyright (c) 2017 STMicroelectronics.
17 * All rights reserved.
19 * This software is licensed under terms that can be found in the LICENSE file
20 * in the root directory of this software component.
21 * If no LICENSE file comes with this software, it is provided AS-IS.
23 ******************************************************************************
24 @verbatim
25 ==============================================================================
26 ##### How to use this driver #####
27 ==============================================================================
28 [..]
29 The SMARTCARD HAL driver can be used as follows:
31 (#) Declare a SMARTCARD_HandleTypeDef handle structure (eg. SMARTCARD_HandleTypeDef hsmartcard).
32 (#) Associate a USART to the SMARTCARD handle hsmartcard.
33 (#) Initialize the SMARTCARD low level resources by implementing the HAL_SMARTCARD_MspInit() API:
34 (++) Enable the USARTx interface clock.
35 (++) USART pins configuration:
36 (+++) Enable the clock for the USART GPIOs.
37 (+++) Configure the USART pins (TX as alternate function pull-up, RX as alternate function Input).
38 (++) NVIC configuration if you need to use interrupt process (HAL_SMARTCARD_Transmit_IT()
39 and HAL_SMARTCARD_Receive_IT() APIs):
40 (+++) Configure the USARTx interrupt priority.
41 (+++) Enable the NVIC USART IRQ handle.
42 (++) DMA Configuration if you need to use DMA process (HAL_SMARTCARD_Transmit_DMA()
43 and HAL_SMARTCARD_Receive_DMA() APIs):
44 (+++) Declare a DMA handle structure for the Tx/Rx channel.
45 (+++) Enable the DMAx interface clock.
46 (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters.
47 (+++) Configure the DMA Tx/Rx channel.
48 (+++) Associate the initialized DMA handle to the SMARTCARD DMA Tx/Rx handle.
49 (+++) Configure the priority and enable the NVIC for the transfer complete
50 interrupt on the DMA Tx/Rx channel.
52 (#) Program the Baud Rate, Parity, Mode(Receiver/Transmitter), clock enabling/disabling and accordingly,
53 the clock parameters (parity, phase, last bit), prescaler value, guard time and NACK on transmission
54 error enabling or disabling in the hsmartcard handle Init structure.
56 (#) If required, program SMARTCARD advanced features (TX/RX pins swap, TimeOut, auto-retry counter,...)
57 in the hsmartcard handle AdvancedInit structure.
59 (#) Initialize the SMARTCARD registers by calling the HAL_SMARTCARD_Init() API:
60 (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc)
61 by calling the customized HAL_SMARTCARD_MspInit() API.
62 [..]
63 (@) The specific SMARTCARD interrupts (Transmission complete interrupt,
64 RXNE interrupt and Error Interrupts) will be managed using the macros
65 __HAL_SMARTCARD_ENABLE_IT() and __HAL_SMARTCARD_DISABLE_IT() inside the transmit and receive process.
67 [..]
68 [..] Three operation modes are available within this driver :
70 *** Polling mode IO operation ***
71 =================================
72 [..]
73 (+) Send an amount of data in blocking mode using HAL_SMARTCARD_Transmit()
74 (+) Receive an amount of data in blocking mode using HAL_SMARTCARD_Receive()
76 *** Interrupt mode IO operation ***
77 ===================================
78 [..]
79 (+) Send an amount of data in non-blocking mode using HAL_SMARTCARD_Transmit_IT()
80 (+) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback() is executed and user can
81 add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback()
82 (+) Receive an amount of data in non-blocking mode using HAL_SMARTCARD_Receive_IT()
83 (+) At reception end of transfer HAL_SMARTCARD_RxCpltCallback() is executed and user can
84 add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback()
85 (+) In case of transfer Error, HAL_SMARTCARD_ErrorCallback() function is executed and user can
86 add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback()
88 *** DMA mode IO operation ***
89 ==============================
90 [..]
91 (+) Send an amount of data in non-blocking mode (DMA) using HAL_SMARTCARD_Transmit_DMA()
92 (+) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback() is executed and user can
93 add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback()
94 (+) Receive an amount of data in non-blocking mode (DMA) using HAL_SMARTCARD_Receive_DMA()
95 (+) At reception end of transfer HAL_SMARTCARD_RxCpltCallback() is executed and user can
96 add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback()
97 (+) In case of transfer Error, HAL_SMARTCARD_ErrorCallback() function is executed and user can
98 add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback()
100 *** SMARTCARD HAL driver macros list ***
101 ========================================
102 [..]
103 Below the list of most used macros in SMARTCARD HAL driver.
105 (+) __HAL_SMARTCARD_GET_FLAG : Check whether or not the specified SMARTCARD flag is set
106 (+) __HAL_SMARTCARD_CLEAR_FLAG : Clear the specified SMARTCARD pending flag
107 (+) __HAL_SMARTCARD_ENABLE_IT: Enable the specified SMARTCARD interrupt
108 (+) __HAL_SMARTCARD_DISABLE_IT: Disable the specified SMARTCARD interrupt
109 (+) __HAL_SMARTCARD_GET_IT_SOURCE: Check whether or not the specified SMARTCARD interrupt is enabled
111 [..]
112 (@) You can refer to the SMARTCARD HAL driver header file for more useful macros
114 ##### Callback registration #####
115 ==================================
117 [..]
118 The compilation define USE_HAL_SMARTCARD_REGISTER_CALLBACKS when set to 1
119 allows the user to configure dynamically the driver callbacks.
121 [..]
122 Use Function HAL_SMARTCARD_RegisterCallback() to register a user callback.
123 Function HAL_SMARTCARD_RegisterCallback() allows to register following callbacks:
124 (+) TxCpltCallback : Tx Complete Callback.
125 (+) RxCpltCallback : Rx Complete Callback.
126 (+) ErrorCallback : Error Callback.
127 (+) AbortCpltCallback : Abort Complete Callback.
128 (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback.
129 (+) AbortReceiveCpltCallback : Abort Receive Complete Callback.
130 (+) RxFifoFullCallback : Rx Fifo Full Callback.
131 (+) TxFifoEmptyCallback : Tx Fifo Empty Callback.
132 (+) MspInitCallback : SMARTCARD MspInit.
133 (+) MspDeInitCallback : SMARTCARD MspDeInit.
134 This function takes as parameters the HAL peripheral handle, the Callback ID
135 and a pointer to the user callback function.
137 [..]
138 Use function HAL_SMARTCARD_UnRegisterCallback() to reset a callback to the default
139 weak function.
140 HAL_SMARTCARD_UnRegisterCallback() takes as parameters the HAL peripheral handle,
141 and the Callback ID.
142 This function allows to reset following callbacks:
143 (+) TxCpltCallback : Tx Complete Callback.
144 (+) RxCpltCallback : Rx Complete Callback.
145 (+) ErrorCallback : Error Callback.
146 (+) AbortCpltCallback : Abort Complete Callback.
147 (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback.
148 (+) AbortReceiveCpltCallback : Abort Receive Complete Callback.
149 (+) RxFifoFullCallback : Rx Fifo Full Callback.
150 (+) TxFifoEmptyCallback : Tx Fifo Empty Callback.
151 (+) MspInitCallback : SMARTCARD MspInit.
152 (+) MspDeInitCallback : SMARTCARD MspDeInit.
154 [..]
155 By default, after the HAL_SMARTCARD_Init() and when the state is HAL_SMARTCARD_STATE_RESET
156 all callbacks are set to the corresponding weak functions:
157 examples HAL_SMARTCARD_TxCpltCallback(), HAL_SMARTCARD_RxCpltCallback().
158 Exception done for MspInit and MspDeInit functions that are respectively
159 reset to the legacy weak functions in the HAL_SMARTCARD_Init()
160 and HAL_SMARTCARD_DeInit() only when these callbacks are null (not registered beforehand).
161 If not, MspInit or MspDeInit are not null, the HAL_SMARTCARD_Init() and HAL_SMARTCARD_DeInit()
162 keep and use the user MspInit/MspDeInit callbacks (registered beforehand).
164 [..]
165 Callbacks can be registered/unregistered in HAL_SMARTCARD_STATE_READY state only.
166 Exception done MspInit/MspDeInit that can be registered/unregistered
167 in HAL_SMARTCARD_STATE_READY or HAL_SMARTCARD_STATE_RESET state, thus registered (user)
168 MspInit/DeInit callbacks can be used during the Init/DeInit.
169 In that case first register the MspInit/MspDeInit user callbacks
170 using HAL_SMARTCARD_RegisterCallback() before calling HAL_SMARTCARD_DeInit()
171 or HAL_SMARTCARD_Init() function.
173 [..]
174 When The compilation define USE_HAL_SMARTCARD_REGISTER_CALLBACKS is set to 0 or
175 not defined, the callback registration feature is not available
176 and weak callbacks are used.
179 @endverbatim
180 ******************************************************************************
183 /* Includes ------------------------------------------------------------------*/
184 #include "stm32h7xx_hal.h"
186 /** @addtogroup STM32H7xx_HAL_Driver
187 * @{
190 /** @defgroup SMARTCARD SMARTCARD
191 * @brief HAL SMARTCARD module driver
192 * @{
195 #ifdef HAL_SMARTCARD_MODULE_ENABLED
197 /* Private typedef -----------------------------------------------------------*/
198 /* Private define ------------------------------------------------------------*/
199 /** @defgroup SMARTCARD_Private_Constants SMARTCARD Private Constants
200 * @{
202 #define SMARTCARD_TEACK_REACK_TIMEOUT 1000U /*!< SMARTCARD TX or RX enable acknowledge time-out value */
204 #define USART_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | USART_CR1_TE | \
205 USART_CR1_RE | USART_CR1_OVER8| \
206 USART_CR1_FIFOEN)) /*!< USART CR1 fields of parameters set by SMARTCARD_SetConfig API */
208 #define USART_CR2_CLK_FIELDS ((uint32_t)(USART_CR2_CLKEN | USART_CR2_CPOL | \
209 USART_CR2_CPHA | USART_CR2_LBCL)) /*!< SMARTCARD clock-related USART CR2 fields of parameters */
211 #define USART_CR2_FIELDS ((uint32_t)(USART_CR2_RTOEN | USART_CR2_CLK_FIELDS | \
212 USART_CR2_STOP)) /*!< USART CR2 fields of parameters set by SMARTCARD_SetConfig API */
214 #define USART_CR3_FIELDS ((uint32_t)(USART_CR3_ONEBIT | USART_CR3_NACK | USART_CR3_SCARCNT | \
215 USART_CR3_TXFTCFG | USART_CR3_RXFTCFG )) /*!< USART CR3 fields of parameters set by SMARTCARD_SetConfig API */
217 #define USART_BRR_MIN 0x10U /*!< USART BRR minimum authorized value */
219 #define USART_BRR_MAX 0x0000FFFFU /*!< USART BRR maximum authorized value */
221 * @}
224 /* Private macros ------------------------------------------------------------*/
225 /* Private variables ---------------------------------------------------------*/
226 /* Private function prototypes -----------------------------------------------*/
227 /** @addtogroup SMARTCARD_Private_Functions
228 * @{
230 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
231 void SMARTCARD_InitCallbacksToDefault(SMARTCARD_HandleTypeDef *hsmartcard);
232 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */
233 static HAL_StatusTypeDef SMARTCARD_SetConfig(SMARTCARD_HandleTypeDef *hsmartcard);
234 static void SMARTCARD_AdvFeatureConfig(SMARTCARD_HandleTypeDef *hsmartcard);
235 static HAL_StatusTypeDef SMARTCARD_CheckIdleState(SMARTCARD_HandleTypeDef *hsmartcard);
236 static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t Flag,
237 FlagStatus Status, uint32_t Tickstart, uint32_t Timeout);
238 static void SMARTCARD_EndTxTransfer(SMARTCARD_HandleTypeDef *hsmartcard);
239 static void SMARTCARD_EndRxTransfer(SMARTCARD_HandleTypeDef *hsmartcard);
240 static void SMARTCARD_DMATransmitCplt(DMA_HandleTypeDef *hdma);
241 static void SMARTCARD_DMAReceiveCplt(DMA_HandleTypeDef *hdma);
242 static void SMARTCARD_DMAError(DMA_HandleTypeDef *hdma);
243 static void SMARTCARD_DMAAbortOnError(DMA_HandleTypeDef *hdma);
244 static void SMARTCARD_DMATxAbortCallback(DMA_HandleTypeDef *hdma);
245 static void SMARTCARD_DMARxAbortCallback(DMA_HandleTypeDef *hdma);
246 static void SMARTCARD_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma);
247 static void SMARTCARD_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma);
248 static void SMARTCARD_TxISR(SMARTCARD_HandleTypeDef *hsmartcard);
249 static void SMARTCARD_TxISR_FIFOEN(SMARTCARD_HandleTypeDef *hsmartcard);
250 static void SMARTCARD_EndTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard);
251 static void SMARTCARD_RxISR(SMARTCARD_HandleTypeDef *hsmartcard);
252 static void SMARTCARD_RxISR_FIFOEN(SMARTCARD_HandleTypeDef *hsmartcard);
254 * @}
257 /* Exported functions --------------------------------------------------------*/
259 /** @defgroup SMARTCARD_Exported_Functions SMARTCARD Exported Functions
260 * @{
263 /** @defgroup SMARTCARD_Exported_Functions_Group1 Initialization and de-initialization functions
264 * @brief Initialization and Configuration functions
266 @verbatim
267 ==============================================================================
268 ##### Initialization and Configuration functions #####
269 ==============================================================================
270 [..]
271 This subsection provides a set of functions allowing to initialize the USARTx
272 associated to the SmartCard.
273 (+) These parameters can be configured:
274 (++) Baud Rate
275 (++) Parity: parity should be enabled, frame Length is fixed to 8 bits plus parity
276 (++) Receiver/transmitter modes
277 (++) Synchronous mode (and if enabled, phase, polarity and last bit parameters)
278 (++) Prescaler value
279 (++) Guard bit time
280 (++) NACK enabling or disabling on transmission error
282 (+) The following advanced features can be configured as well:
283 (++) TX and/or RX pin level inversion
284 (++) data logical level inversion
285 (++) RX and TX pins swap
286 (++) RX overrun detection disabling
287 (++) DMA disabling on RX error
288 (++) MSB first on communication line
289 (++) Time out enabling (and if activated, timeout value)
290 (++) Block length
291 (++) Auto-retry counter
292 [..]
293 The HAL_SMARTCARD_Init() API follows the USART synchronous configuration procedures
294 (details for the procedures are available in reference manual).
296 @endverbatim
298 The USART frame format is given in the following table:
300 Table 1. USART frame format.
301 +---------------------------------------------------------------+
302 | M1M0 bits | PCE bit | USART frame |
303 |-----------------------|---------------------------------------|
304 | 01 | 1 | | SB | 8 bit data | PB | STB | |
305 +---------------------------------------------------------------+
308 * @{
312 * @brief Initialize the SMARTCARD mode according to the specified
313 * parameters in the SMARTCARD_HandleTypeDef and initialize the associated handle.
314 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
315 * the configuration information for the specified SMARTCARD module.
316 * @retval HAL status
318 HAL_StatusTypeDef HAL_SMARTCARD_Init(SMARTCARD_HandleTypeDef *hsmartcard)
320 /* Check the SMARTCARD handle allocation */
321 if (hsmartcard == NULL)
323 return HAL_ERROR;
326 /* Check the USART associated to the SMARTCARD handle */
327 assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance));
329 if (hsmartcard->gState == HAL_SMARTCARD_STATE_RESET)
331 /* Allocate lock resource and initialize it */
332 hsmartcard->Lock = HAL_UNLOCKED;
334 #if USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1
335 SMARTCARD_InitCallbacksToDefault(hsmartcard);
337 if (hsmartcard->MspInitCallback == NULL)
339 hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit;
342 /* Init the low level hardware */
343 hsmartcard->MspInitCallback(hsmartcard);
344 #else
345 /* Init the low level hardware : GPIO, CLOCK */
346 HAL_SMARTCARD_MspInit(hsmartcard);
347 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */
350 hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY;
352 /* Disable the Peripheral to set smartcard mode */
353 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
355 /* In SmartCard mode, the following bits must be kept cleared:
356 - LINEN in the USART_CR2 register,
357 - HDSEL and IREN bits in the USART_CR3 register.*/
358 CLEAR_BIT(hsmartcard->Instance->CR2, USART_CR2_LINEN);
359 CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_HDSEL | USART_CR3_IREN));
361 /* set the USART in SMARTCARD mode */
362 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_SCEN);
364 /* Set the SMARTCARD Communication parameters */
365 if (SMARTCARD_SetConfig(hsmartcard) == HAL_ERROR)
367 return HAL_ERROR;
370 /* Set the SMARTCARD transmission completion indication */
371 SMARTCARD_TRANSMISSION_COMPLETION_SETTING(hsmartcard);
373 if (hsmartcard->AdvancedInit.AdvFeatureInit != SMARTCARD_ADVFEATURE_NO_INIT)
375 SMARTCARD_AdvFeatureConfig(hsmartcard);
378 /* Enable the Peripheral */
379 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
381 /* TEACK and/or REACK to check before moving hsmartcard->gState and hsmartcard->RxState to Ready */
382 return (SMARTCARD_CheckIdleState(hsmartcard));
386 * @brief DeInitialize the SMARTCARD peripheral.
387 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
388 * the configuration information for the specified SMARTCARD module.
389 * @retval HAL status
391 HAL_StatusTypeDef HAL_SMARTCARD_DeInit(SMARTCARD_HandleTypeDef *hsmartcard)
393 /* Check the SMARTCARD handle allocation */
394 if (hsmartcard == NULL)
396 return HAL_ERROR;
399 /* Check the USART/UART associated to the SMARTCARD handle */
400 assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance));
402 hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY;
404 /* Disable the Peripheral */
405 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
407 WRITE_REG(hsmartcard->Instance->CR1, 0x0U);
408 WRITE_REG(hsmartcard->Instance->CR2, 0x0U);
409 WRITE_REG(hsmartcard->Instance->CR3, 0x0U);
410 WRITE_REG(hsmartcard->Instance->RTOR, 0x0U);
411 WRITE_REG(hsmartcard->Instance->GTPR, 0x0U);
413 /* DeInit the low level hardware */
414 #if USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1
415 if (hsmartcard->MspDeInitCallback == NULL)
417 hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit;
419 /* DeInit the low level hardware */
420 hsmartcard->MspDeInitCallback(hsmartcard);
421 #else
422 HAL_SMARTCARD_MspDeInit(hsmartcard);
423 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */
425 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
426 hsmartcard->gState = HAL_SMARTCARD_STATE_RESET;
427 hsmartcard->RxState = HAL_SMARTCARD_STATE_RESET;
429 /* Process Unlock */
430 __HAL_UNLOCK(hsmartcard);
432 return HAL_OK;
436 * @brief Initialize the SMARTCARD MSP.
437 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
438 * the configuration information for the specified SMARTCARD module.
439 * @retval None
441 __weak void HAL_SMARTCARD_MspInit(SMARTCARD_HandleTypeDef *hsmartcard)
443 /* Prevent unused argument(s) compilation warning */
444 UNUSED(hsmartcard);
446 /* NOTE : This function should not be modified, when the callback is needed,
447 the HAL_SMARTCARD_MspInit can be implemented in the user file
452 * @brief DeInitialize the SMARTCARD MSP.
453 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
454 * the configuration information for the specified SMARTCARD module.
455 * @retval None
457 __weak void HAL_SMARTCARD_MspDeInit(SMARTCARD_HandleTypeDef *hsmartcard)
459 /* Prevent unused argument(s) compilation warning */
460 UNUSED(hsmartcard);
462 /* NOTE : This function should not be modified, when the callback is needed,
463 the HAL_SMARTCARD_MspDeInit can be implemented in the user file
467 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
469 * @brief Register a User SMARTCARD Callback
470 * To be used to override the weak predefined callback
471 * @note The HAL_SMARTCARD_RegisterCallback() may be called before HAL_SMARTCARD_Init()
472 * in HAL_SMARTCARD_STATE_RESET to register callbacks for HAL_SMARTCARD_MSPINIT_CB_ID
473 * and HAL_SMARTCARD_MSPDEINIT_CB_ID
474 * @param hsmartcard smartcard handle
475 * @param CallbackID ID of the callback to be registered
476 * This parameter can be one of the following values:
477 * @arg @ref HAL_SMARTCARD_TX_COMPLETE_CB_ID Tx Complete Callback ID
478 * @arg @ref HAL_SMARTCARD_RX_COMPLETE_CB_ID Rx Complete Callback ID
479 * @arg @ref HAL_SMARTCARD_ERROR_CB_ID Error Callback ID
480 * @arg @ref HAL_SMARTCARD_ABORT_COMPLETE_CB_ID Abort Complete Callback ID
481 * @arg @ref HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID
482 * @arg @ref HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID
483 * @arg @ref HAL_SMARTCARD_RX_FIFO_FULL_CB_ID Rx Fifo Full Callback ID
484 * @arg @ref HAL_SMARTCARD_TX_FIFO_EMPTY_CB_ID Tx Fifo Empty Callback ID
485 * @arg @ref HAL_SMARTCARD_MSPINIT_CB_ID MspInit Callback ID
486 * @arg @ref HAL_SMARTCARD_MSPDEINIT_CB_ID MspDeInit Callback ID
487 * @param pCallback pointer to the Callback function
488 * @retval HAL status
490 HAL_StatusTypeDef HAL_SMARTCARD_RegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard,
491 HAL_SMARTCARD_CallbackIDTypeDef CallbackID,
492 pSMARTCARD_CallbackTypeDef pCallback)
494 HAL_StatusTypeDef status = HAL_OK;
496 if (pCallback == NULL)
498 /* Update the error code */
499 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
501 return HAL_ERROR;
504 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
506 switch (CallbackID)
509 case HAL_SMARTCARD_TX_COMPLETE_CB_ID :
510 hsmartcard->TxCpltCallback = pCallback;
511 break;
513 case HAL_SMARTCARD_RX_COMPLETE_CB_ID :
514 hsmartcard->RxCpltCallback = pCallback;
515 break;
517 case HAL_SMARTCARD_ERROR_CB_ID :
518 hsmartcard->ErrorCallback = pCallback;
519 break;
521 case HAL_SMARTCARD_ABORT_COMPLETE_CB_ID :
522 hsmartcard->AbortCpltCallback = pCallback;
523 break;
525 case HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID :
526 hsmartcard->AbortTransmitCpltCallback = pCallback;
527 break;
529 case HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID :
530 hsmartcard->AbortReceiveCpltCallback = pCallback;
531 break;
533 case HAL_SMARTCARD_RX_FIFO_FULL_CB_ID :
534 hsmartcard->RxFifoFullCallback = pCallback;
535 break;
537 case HAL_SMARTCARD_TX_FIFO_EMPTY_CB_ID :
538 hsmartcard->TxFifoEmptyCallback = pCallback;
539 break;
541 case HAL_SMARTCARD_MSPINIT_CB_ID :
542 hsmartcard->MspInitCallback = pCallback;
543 break;
545 case HAL_SMARTCARD_MSPDEINIT_CB_ID :
546 hsmartcard->MspDeInitCallback = pCallback;
547 break;
549 default :
550 /* Update the error code */
551 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
553 /* Return error status */
554 status = HAL_ERROR;
555 break;
558 else if (hsmartcard->gState == HAL_SMARTCARD_STATE_RESET)
560 switch (CallbackID)
562 case HAL_SMARTCARD_MSPINIT_CB_ID :
563 hsmartcard->MspInitCallback = pCallback;
564 break;
566 case HAL_SMARTCARD_MSPDEINIT_CB_ID :
567 hsmartcard->MspDeInitCallback = pCallback;
568 break;
570 default :
571 /* Update the error code */
572 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
574 /* Return error status */
575 status = HAL_ERROR;
576 break;
579 else
581 /* Update the error code */
582 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
584 /* Return error status */
585 status = HAL_ERROR;
588 return status;
592 * @brief Unregister an SMARTCARD callback
593 * SMARTCARD callback is redirected to the weak predefined callback
594 * @note The HAL_SMARTCARD_UnRegisterCallback() may be called before HAL_SMARTCARD_Init()
595 * in HAL_SMARTCARD_STATE_RESET to un-register callbacks for HAL_SMARTCARD_MSPINIT_CB_ID
596 * and HAL_SMARTCARD_MSPDEINIT_CB_ID
597 * @param hsmartcard smartcard handle
598 * @param CallbackID ID of the callback to be unregistered
599 * This parameter can be one of the following values:
600 * @arg @ref HAL_SMARTCARD_TX_COMPLETE_CB_ID Tx Complete Callback ID
601 * @arg @ref HAL_SMARTCARD_RX_COMPLETE_CB_ID Rx Complete Callback ID
602 * @arg @ref HAL_SMARTCARD_ERROR_CB_ID Error Callback ID
603 * @arg @ref HAL_SMARTCARD_ABORT_COMPLETE_CB_ID Abort Complete Callback ID
604 * @arg @ref HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID
605 * @arg @ref HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID
606 * @arg @ref HAL_SMARTCARD_RX_FIFO_FULL_CB_ID Rx Fifo Full Callback ID
607 * @arg @ref HAL_SMARTCARD_TX_FIFO_EMPTY_CB_ID Tx Fifo Empty Callback ID
608 * @arg @ref HAL_SMARTCARD_MSPINIT_CB_ID MspInit Callback ID
609 * @arg @ref HAL_SMARTCARD_MSPDEINIT_CB_ID MspDeInit Callback ID
610 * @retval HAL status
612 HAL_StatusTypeDef HAL_SMARTCARD_UnRegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard,
613 HAL_SMARTCARD_CallbackIDTypeDef CallbackID)
615 HAL_StatusTypeDef status = HAL_OK;
617 if (HAL_SMARTCARD_STATE_READY == hsmartcard->gState)
619 switch (CallbackID)
621 case HAL_SMARTCARD_TX_COMPLETE_CB_ID :
622 hsmartcard->TxCpltCallback = HAL_SMARTCARD_TxCpltCallback; /* Legacy weak TxCpltCallback */
623 break;
625 case HAL_SMARTCARD_RX_COMPLETE_CB_ID :
626 hsmartcard->RxCpltCallback = HAL_SMARTCARD_RxCpltCallback; /* Legacy weak RxCpltCallback */
627 break;
629 case HAL_SMARTCARD_ERROR_CB_ID :
630 hsmartcard->ErrorCallback = HAL_SMARTCARD_ErrorCallback; /* Legacy weak ErrorCallback */
631 break;
633 case HAL_SMARTCARD_ABORT_COMPLETE_CB_ID :
634 hsmartcard->AbortCpltCallback = HAL_SMARTCARD_AbortCpltCallback; /* Legacy weak AbortCpltCallback */
635 break;
637 case HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID :
638 hsmartcard->AbortTransmitCpltCallback = HAL_SMARTCARD_AbortTransmitCpltCallback; /* Legacy weak
639 AbortTransmitCpltCallback*/
640 break;
642 case HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID :
643 hsmartcard->AbortReceiveCpltCallback = HAL_SMARTCARD_AbortReceiveCpltCallback; /* Legacy weak
644 AbortReceiveCpltCallback */
645 break;
647 case HAL_SMARTCARD_RX_FIFO_FULL_CB_ID :
648 hsmartcard->RxFifoFullCallback = HAL_SMARTCARDEx_RxFifoFullCallback; /* Legacy weak RxFifoFullCallback */
649 break;
651 case HAL_SMARTCARD_TX_FIFO_EMPTY_CB_ID :
652 hsmartcard->TxFifoEmptyCallback = HAL_SMARTCARDEx_TxFifoEmptyCallback; /* Legacy weak TxFifoEmptyCallback */
653 break;
655 case HAL_SMARTCARD_MSPINIT_CB_ID :
656 hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit; /* Legacy weak MspInitCallback */
657 break;
659 case HAL_SMARTCARD_MSPDEINIT_CB_ID :
660 hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit; /* Legacy weak MspDeInitCallback */
661 break;
663 default :
664 /* Update the error code */
665 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
667 /* Return error status */
668 status = HAL_ERROR;
669 break;
672 else if (HAL_SMARTCARD_STATE_RESET == hsmartcard->gState)
674 switch (CallbackID)
676 case HAL_SMARTCARD_MSPINIT_CB_ID :
677 hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit;
678 break;
680 case HAL_SMARTCARD_MSPDEINIT_CB_ID :
681 hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit;
682 break;
684 default :
685 /* Update the error code */
686 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
688 /* Return error status */
689 status = HAL_ERROR;
690 break;
693 else
695 /* Update the error code */
696 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK;
698 /* Return error status */
699 status = HAL_ERROR;
702 return status;
704 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */
707 * @}
710 /** @defgroup SMARTCARD_Exported_Functions_Group2 IO operation functions
711 * @brief SMARTCARD Transmit and Receive functions
713 @verbatim
714 ==============================================================================
715 ##### IO operation functions #####
716 ==============================================================================
717 [..]
718 This subsection provides a set of functions allowing to manage the SMARTCARD data transfers.
720 [..]
721 Smartcard is a single wire half duplex communication protocol.
722 The Smartcard interface is designed to support asynchronous protocol Smartcards as
723 defined in the ISO 7816-3 standard. The USART should be configured as:
724 (+) 8 bits plus parity: where M=1 and PCE=1 in the USART_CR1 register
725 (+) 1.5 stop bits when transmitting and receiving: where STOP=11 in the USART_CR2 register.
727 [..]
728 (#) There are two modes of transfer:
729 (##) Blocking mode: The communication is performed in polling mode.
730 The HAL status of all data processing is returned by the same function
731 after finishing transfer.
732 (##) Non-Blocking mode: The communication is performed using Interrupts
733 or DMA, the relevant API's return the HAL status.
734 The end of the data processing will be indicated through the
735 dedicated SMARTCARD IRQ when using Interrupt mode or the DMA IRQ when
736 using DMA mode.
737 (##) The HAL_SMARTCARD_TxCpltCallback(), HAL_SMARTCARD_RxCpltCallback() user callbacks
738 will be executed respectively at the end of the Transmit or Receive process
739 The HAL_SMARTCARD_ErrorCallback() user callback will be executed when a communication
740 error is detected.
742 (#) Blocking mode APIs are :
743 (##) HAL_SMARTCARD_Transmit()
744 (##) HAL_SMARTCARD_Receive()
746 (#) Non Blocking mode APIs with Interrupt are :
747 (##) HAL_SMARTCARD_Transmit_IT()
748 (##) HAL_SMARTCARD_Receive_IT()
749 (##) HAL_SMARTCARD_IRQHandler()
751 (#) Non Blocking mode functions with DMA are :
752 (##) HAL_SMARTCARD_Transmit_DMA()
753 (##) HAL_SMARTCARD_Receive_DMA()
755 (#) A set of Transfer Complete Callbacks are provided in non Blocking mode:
756 (##) HAL_SMARTCARD_TxCpltCallback()
757 (##) HAL_SMARTCARD_RxCpltCallback()
758 (##) HAL_SMARTCARD_ErrorCallback()
760 [..]
761 (#) Non-Blocking mode transfers could be aborted using Abort API's :
762 (##) HAL_SMARTCARD_Abort()
763 (##) HAL_SMARTCARD_AbortTransmit()
764 (##) HAL_SMARTCARD_AbortReceive()
765 (##) HAL_SMARTCARD_Abort_IT()
766 (##) HAL_SMARTCARD_AbortTransmit_IT()
767 (##) HAL_SMARTCARD_AbortReceive_IT()
769 (#) For Abort services based on interrupts (HAL_SMARTCARD_Abortxxx_IT),
770 a set of Abort Complete Callbacks are provided:
771 (##) HAL_SMARTCARD_AbortCpltCallback()
772 (##) HAL_SMARTCARD_AbortTransmitCpltCallback()
773 (##) HAL_SMARTCARD_AbortReceiveCpltCallback()
775 (#) In Non-Blocking mode transfers, possible errors are split into 2 categories.
776 Errors are handled as follows :
777 (##) Error is considered as Recoverable and non blocking : Transfer could go till end, but error severity is
778 to be evaluated by user : this concerns Frame Error,
779 Parity Error or Noise Error in Interrupt mode reception .
780 Received character is then retrieved and stored in Rx buffer,
781 Error code is set to allow user to identify error type,
782 and HAL_SMARTCARD_ErrorCallback() user callback is executed. Transfer is kept ongoing on SMARTCARD side.
783 If user wants to abort it, Abort services should be called by user.
784 (##) Error is considered as Blocking : Transfer could not be completed properly and is aborted.
785 This concerns Frame Error in Interrupt mode transmission, Overrun Error in Interrupt
786 mode reception and all errors in DMA mode.
787 Error code is set to allow user to identify error type,
788 and HAL_SMARTCARD_ErrorCallback() user callback is executed.
790 @endverbatim
791 * @{
795 * @brief Send an amount of data in blocking mode.
796 * @note When FIFO mode is enabled, writing a data in the TDR register adds one
797 * data to the TXFIFO. Write operations to the TDR register are performed
798 * when TXFNF flag is set. From hardware perspective, TXFNF flag and
799 * TXE are mapped on the same bit-field.
800 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
801 * the configuration information for the specified SMARTCARD module.
802 * @param pData pointer to data buffer.
803 * @param Size amount of data to be sent.
804 * @param Timeout Timeout duration.
805 * @retval HAL status
807 HAL_StatusTypeDef HAL_SMARTCARD_Transmit(SMARTCARD_HandleTypeDef *hsmartcard, const uint8_t *pData, uint16_t Size,
808 uint32_t Timeout)
810 uint32_t tickstart;
811 const uint8_t *ptmpdata = pData;
813 /* Check that a Tx process is not already ongoing */
814 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
816 if ((ptmpdata == NULL) || (Size == 0U))
818 return HAL_ERROR;
821 /* Process Locked */
822 __HAL_LOCK(hsmartcard);
824 hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX;
826 /* Init tickstart for timeout management */
827 tickstart = HAL_GetTick();
829 /* Disable the Peripheral first to update mode for TX master */
830 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
832 /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor
833 the bidirectional line to detect a NACK signal in case of parity error.
834 Therefore, the receiver block must be enabled as well (RE bit must be set). */
835 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX)
836 && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
838 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE);
840 /* Enable Tx */
841 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE);
843 /* Enable the Peripheral */
844 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
846 /* Perform a TX/RX FIFO Flush */
847 __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard);
849 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
850 hsmartcard->TxXferSize = Size;
851 hsmartcard->TxXferCount = Size;
853 while (hsmartcard->TxXferCount > 0U)
855 hsmartcard->TxXferCount--;
856 if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK)
858 return HAL_TIMEOUT;
860 hsmartcard->Instance->TDR = (uint8_t)(*ptmpdata & 0xFFU);
861 ptmpdata++;
863 if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_TRANSMISSION_COMPLETION_FLAG(hsmartcard), RESET,
864 tickstart, Timeout) != HAL_OK)
866 return HAL_TIMEOUT;
869 /* Disable the Peripheral first to update mode */
870 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
871 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX)
872 && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
874 /* In case of TX only mode, if NACK is enabled, receiver block has been enabled
875 for Transmit phase. Disable this receiver block. */
876 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RE);
878 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX_RX)
879 || (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
881 /* Perform a TX FIFO Flush at end of Tx phase, as all sent bytes are appearing in Rx Data register */
882 __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard);
884 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
886 /* At end of Tx process, restore hsmartcard->gState to Ready */
887 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
889 /* Process Unlocked */
890 __HAL_UNLOCK(hsmartcard);
892 return HAL_OK;
894 else
896 return HAL_BUSY;
901 * @brief Receive an amount of data in blocking mode.
902 * @note When FIFO mode is enabled, the RXFNE flag is set as long as the RXFIFO
903 * is not empty. Read operations from the RDR register are performed when
904 * RXFNE flag is set. From hardware perspective, RXFNE flag and
905 * RXNE are mapped on the same bit-field.
906 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
907 * the configuration information for the specified SMARTCARD module.
908 * @param pData pointer to data buffer.
909 * @param Size amount of data to be received.
910 * @param Timeout Timeout duration.
911 * @retval HAL status
913 HAL_StatusTypeDef HAL_SMARTCARD_Receive(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size,
914 uint32_t Timeout)
916 uint32_t tickstart;
917 uint8_t *ptmpdata = pData;
919 /* Check that a Rx process is not already ongoing */
920 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
922 if ((ptmpdata == NULL) || (Size == 0U))
924 return HAL_ERROR;
927 /* Process Locked */
928 __HAL_LOCK(hsmartcard);
930 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
931 hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX;
933 /* Init tickstart for timeout management */
934 tickstart = HAL_GetTick();
936 hsmartcard->RxXferSize = Size;
937 hsmartcard->RxXferCount = Size;
939 /* Check the remain data to be received */
940 while (hsmartcard->RxXferCount > 0U)
942 hsmartcard->RxXferCount--;
944 if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK)
946 return HAL_TIMEOUT;
948 *ptmpdata = (uint8_t)(hsmartcard->Instance->RDR & (uint8_t)0x00FF);
949 ptmpdata++;
952 /* At end of Rx process, restore hsmartcard->RxState to Ready */
953 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
955 /* Process Unlocked */
956 __HAL_UNLOCK(hsmartcard);
958 return HAL_OK;
960 else
962 return HAL_BUSY;
967 * @brief Send an amount of data in interrupt mode.
968 * @note When FIFO mode is disabled, USART interrupt is generated whenever
969 * USART_TDR register is empty, i.e one interrupt per data to transmit.
970 * @note When FIFO mode is enabled, USART interrupt is generated whenever
971 * TXFIFO threshold reached. In that case the interrupt rate depends on
972 * TXFIFO threshold configuration.
973 * @note This function sets the hsmartcard->TxIsr function pointer according to
974 * the FIFO mode (data transmission processing depends on FIFO mode).
975 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
976 * the configuration information for the specified SMARTCARD module.
977 * @param pData pointer to data buffer.
978 * @param Size amount of data to be sent.
979 * @retval HAL status
981 HAL_StatusTypeDef HAL_SMARTCARD_Transmit_IT(SMARTCARD_HandleTypeDef *hsmartcard, const uint8_t *pData, uint16_t Size)
983 /* Check that a Tx process is not already ongoing */
984 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
986 if ((pData == NULL) || (Size == 0U))
988 return HAL_ERROR;
991 /* Process Locked */
992 __HAL_LOCK(hsmartcard);
994 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
995 hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX;
997 hsmartcard->pTxBuffPtr = pData;
998 hsmartcard->TxXferSize = Size;
999 hsmartcard->TxXferCount = Size;
1000 hsmartcard->TxISR = NULL;
1002 /* Disable the Peripheral first to update mode for TX master */
1003 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
1005 /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor
1006 the bidirectional line to detect a NACK signal in case of parity error.
1007 Therefore, the receiver block must be enabled as well (RE bit must be set). */
1008 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX)
1009 && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
1011 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE);
1013 /* Enable Tx */
1014 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE);
1016 /* Enable the Peripheral */
1017 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
1019 /* Perform a TX/RX FIFO Flush */
1020 __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard);
1022 /* Configure Tx interrupt processing */
1023 if (hsmartcard->FifoMode == SMARTCARD_FIFOMODE_ENABLE)
1025 /* Set the Tx ISR function pointer */
1026 hsmartcard->TxISR = SMARTCARD_TxISR_FIFOEN;
1028 /* Process Unlocked */
1029 __HAL_UNLOCK(hsmartcard);
1031 /* Enable the SMARTCARD Error Interrupt: (Frame error) */
1032 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1034 /* Enable the TX FIFO threshold interrupt */
1035 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_TXFTIE);
1037 else
1039 /* Set the Tx ISR function pointer */
1040 hsmartcard->TxISR = SMARTCARD_TxISR;
1042 /* Process Unlocked */
1043 __HAL_UNLOCK(hsmartcard);
1045 /* Enable the SMARTCARD Error Interrupt: (Frame error) */
1046 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1048 /* Enable the SMARTCARD Transmit Data Register Empty Interrupt */
1049 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TXEIE_TXFNFIE);
1052 return HAL_OK;
1054 else
1056 return HAL_BUSY;
1061 * @brief Receive an amount of data in interrupt mode.
1062 * @note When FIFO mode is disabled, USART interrupt is generated whenever
1063 * USART_RDR register can be read, i.e one interrupt per data to receive.
1064 * @note When FIFO mode is enabled, USART interrupt is generated whenever
1065 * RXFIFO threshold reached. In that case the interrupt rate depends on
1066 * RXFIFO threshold configuration.
1067 * @note This function sets the hsmartcard->RxIsr function pointer according to
1068 * the FIFO mode (data reception processing depends on FIFO mode).
1069 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1070 * the configuration information for the specified SMARTCARD module.
1071 * @param pData pointer to data buffer.
1072 * @param Size amount of data to be received.
1073 * @retval HAL status
1075 HAL_StatusTypeDef HAL_SMARTCARD_Receive_IT(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size)
1077 /* Check that a Rx process is not already ongoing */
1078 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
1080 if ((pData == NULL) || (Size == 0U))
1082 return HAL_ERROR;
1085 /* Process Locked */
1086 __HAL_LOCK(hsmartcard);
1088 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
1089 hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX;
1091 hsmartcard->pRxBuffPtr = pData;
1092 hsmartcard->RxXferSize = Size;
1093 hsmartcard->RxXferCount = Size;
1095 /* Configure Rx interrupt processing */
1096 if ((hsmartcard->FifoMode == SMARTCARD_FIFOMODE_ENABLE) && (Size >= hsmartcard->NbRxDataToProcess))
1098 /* Set the Rx ISR function pointer */
1099 hsmartcard->RxISR = SMARTCARD_RxISR_FIFOEN;
1101 /* Process Unlocked */
1102 __HAL_UNLOCK(hsmartcard);
1104 /* Enable the SMARTCART Parity Error interrupt and RX FIFO Threshold interrupt */
1105 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE);
1106 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_RXFTIE);
1108 else
1110 /* Set the Rx ISR function pointer */
1111 hsmartcard->RxISR = SMARTCARD_RxISR;
1113 /* Process Unlocked */
1114 __HAL_UNLOCK(hsmartcard);
1116 /* Enable the SMARTCARD Parity Error and Data Register not empty Interrupts */
1117 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE_RXFNEIE);
1120 /* Enable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
1121 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1123 return HAL_OK;
1125 else
1127 return HAL_BUSY;
1132 * @brief Send an amount of data in DMA mode.
1133 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1134 * the configuration information for the specified SMARTCARD module.
1135 * @param pData pointer to data buffer.
1136 * @param Size amount of data to be sent.
1137 * @retval HAL status
1139 HAL_StatusTypeDef HAL_SMARTCARD_Transmit_DMA(SMARTCARD_HandleTypeDef *hsmartcard, const uint8_t *pData, uint16_t Size)
1141 /* Check that a Tx process is not already ongoing */
1142 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
1144 if ((pData == NULL) || (Size == 0U))
1146 return HAL_ERROR;
1149 /* Process Locked */
1150 __HAL_LOCK(hsmartcard);
1152 hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX;
1154 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
1155 hsmartcard->pTxBuffPtr = pData;
1156 hsmartcard->TxXferSize = Size;
1157 hsmartcard->TxXferCount = Size;
1159 /* Disable the Peripheral first to update mode for TX master */
1160 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
1162 /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor
1163 the bidirectional line to detect a NACK signal in case of parity error.
1164 Therefore, the receiver block must be enabled as well (RE bit must be set). */
1165 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX)
1166 && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
1168 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE);
1170 /* Enable Tx */
1171 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE);
1173 /* Enable the Peripheral */
1174 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
1176 /* Perform a TX/RX FIFO Flush */
1177 __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard);
1179 /* Set the SMARTCARD DMA transfer complete callback */
1180 hsmartcard->hdmatx->XferCpltCallback = SMARTCARD_DMATransmitCplt;
1182 /* Set the SMARTCARD error callback */
1183 hsmartcard->hdmatx->XferErrorCallback = SMARTCARD_DMAError;
1185 /* Set the DMA abort callback */
1186 hsmartcard->hdmatx->XferAbortCallback = NULL;
1188 /* Enable the SMARTCARD transmit DMA channel */
1189 if (HAL_DMA_Start_IT(hsmartcard->hdmatx, (uint32_t)hsmartcard->pTxBuffPtr, (uint32_t)&hsmartcard->Instance->TDR,
1190 Size) == HAL_OK)
1192 /* Clear the TC flag in the ICR register */
1193 CLEAR_BIT(hsmartcard->Instance->ICR, USART_ICR_TCCF);
1195 /* Process Unlocked */
1196 __HAL_UNLOCK(hsmartcard);
1198 /* Enable the UART Error Interrupt: (Frame error) */
1199 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1201 /* Enable the DMA transfer for transmit request by setting the DMAT bit
1202 in the SMARTCARD associated USART CR3 register */
1203 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
1205 return HAL_OK;
1207 else
1209 /* Set error code to DMA */
1210 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1212 /* Process Unlocked */
1213 __HAL_UNLOCK(hsmartcard);
1215 /* Restore hsmartcard->State to ready */
1216 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1218 return HAL_ERROR;
1221 else
1223 return HAL_BUSY;
1228 * @brief Receive an amount of data in DMA mode.
1229 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1230 * the configuration information for the specified SMARTCARD module.
1231 * @param pData pointer to data buffer.
1232 * @param Size amount of data to be received.
1233 * @note The SMARTCARD-associated USART parity is enabled (PCE = 1),
1234 * the received data contain the parity bit (MSB position).
1235 * @retval HAL status
1237 HAL_StatusTypeDef HAL_SMARTCARD_Receive_DMA(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size)
1239 /* Check that a Rx process is not already ongoing */
1240 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
1242 if ((pData == NULL) || (Size == 0U))
1244 return HAL_ERROR;
1247 /* Process Locked */
1248 __HAL_LOCK(hsmartcard);
1250 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
1251 hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX;
1253 hsmartcard->pRxBuffPtr = pData;
1254 hsmartcard->RxXferSize = Size;
1256 /* Set the SMARTCARD DMA transfer complete callback */
1257 hsmartcard->hdmarx->XferCpltCallback = SMARTCARD_DMAReceiveCplt;
1259 /* Set the SMARTCARD DMA error callback */
1260 hsmartcard->hdmarx->XferErrorCallback = SMARTCARD_DMAError;
1262 /* Set the DMA abort callback */
1263 hsmartcard->hdmarx->XferAbortCallback = NULL;
1265 /* Enable the DMA channel */
1266 if (HAL_DMA_Start_IT(hsmartcard->hdmarx, (uint32_t)&hsmartcard->Instance->RDR, (uint32_t)hsmartcard->pRxBuffPtr,
1267 Size) == HAL_OK)
1269 /* Process Unlocked */
1270 __HAL_UNLOCK(hsmartcard);
1272 /* Enable the SMARTCARD Parity Error Interrupt */
1273 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE);
1275 /* Enable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
1276 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1278 /* Enable the DMA transfer for the receiver request by setting the DMAR bit
1279 in the SMARTCARD associated USART CR3 register */
1280 SET_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1282 return HAL_OK;
1284 else
1286 /* Set error code to DMA */
1287 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1289 /* Process Unlocked */
1290 __HAL_UNLOCK(hsmartcard);
1292 /* Restore hsmartcard->State to ready */
1293 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1295 return HAL_ERROR;
1298 else
1300 return HAL_BUSY;
1305 * @brief Abort ongoing transfers (blocking mode).
1306 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1307 * the configuration information for the specified SMARTCARD module.
1308 * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode.
1309 * This procedure performs following operations :
1310 * - Disable SMARTCARD Interrupts (Tx and Rx)
1311 * - Disable the DMA transfer in the peripheral register (if enabled)
1312 * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode)
1313 * - Set handle State to READY
1314 * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed.
1315 * @retval HAL status
1317 HAL_StatusTypeDef HAL_SMARTCARD_Abort(SMARTCARD_HandleTypeDef *hsmartcard)
1319 /* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE, RXFT, TXFT and
1320 ERR (Frame error, noise error, overrun error) interrupts */
1321 CLEAR_BIT(hsmartcard->Instance->CR1,
1322 (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE | USART_CR1_TXEIE_TXFNFIE | USART_CR1_TCIE | USART_CR1_RTOIE |
1323 USART_CR1_EOBIE));
1324 CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_EIE | USART_CR3_RXFTIE | USART_CR3_TXFTIE));
1326 /* Disable the SMARTCARD DMA Tx request if enabled */
1327 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
1329 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
1331 /* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */
1332 if (hsmartcard->hdmatx != NULL)
1334 /* Set the SMARTCARD DMA Abort callback to Null.
1335 No call back execution at end of DMA abort procedure */
1336 hsmartcard->hdmatx->XferAbortCallback = NULL;
1338 if (HAL_DMA_Abort(hsmartcard->hdmatx) != HAL_OK)
1340 if (HAL_DMA_GetError(hsmartcard->hdmatx) == HAL_DMA_ERROR_TIMEOUT)
1342 /* Set error code to DMA */
1343 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1345 return HAL_TIMEOUT;
1351 /* Disable the SMARTCARD DMA Rx request if enabled */
1352 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1354 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1356 /* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */
1357 if (hsmartcard->hdmarx != NULL)
1359 /* Set the SMARTCARD DMA Abort callback to Null.
1360 No call back execution at end of DMA abort procedure */
1361 hsmartcard->hdmarx->XferAbortCallback = NULL;
1363 if (HAL_DMA_Abort(hsmartcard->hdmarx) != HAL_OK)
1365 if (HAL_DMA_GetError(hsmartcard->hdmarx) == HAL_DMA_ERROR_TIMEOUT)
1367 /* Set error code to DMA */
1368 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1370 return HAL_TIMEOUT;
1376 /* Reset Tx and Rx transfer counters */
1377 hsmartcard->TxXferCount = 0U;
1378 hsmartcard->RxXferCount = 0U;
1380 /* Clear the Error flags in the ICR register */
1381 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
1382 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF |
1383 SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
1385 /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
1386 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1387 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1389 /* Reset Handle ErrorCode to No Error */
1390 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
1392 return HAL_OK;
1396 * @brief Abort ongoing Transmit transfer (blocking mode).
1397 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1398 * the configuration information for the specified SMARTCARD module.
1399 * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode.
1400 * This procedure performs following operations :
1401 * - Disable SMARTCARD Interrupts (Tx)
1402 * - Disable the DMA transfer in the peripheral register (if enabled)
1403 * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode)
1404 * - Set handle State to READY
1405 * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed.
1406 * @retval HAL status
1408 HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit(SMARTCARD_HandleTypeDef *hsmartcard)
1410 /* Disable TCIE, TXEIE and TXFTIE interrupts */
1411 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE_TXFNFIE | USART_CR1_TCIE));
1412 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_TXFTIE);
1414 /* Check if a receive process is ongoing or not. If not disable ERR IT */
1415 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
1417 /* Disable the SMARTCARD Error Interrupt: (Frame error) */
1418 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1421 /* Disable the SMARTCARD DMA Tx request if enabled */
1422 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
1424 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
1426 /* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */
1427 if (hsmartcard->hdmatx != NULL)
1429 /* Set the SMARTCARD DMA Abort callback to Null.
1430 No call back execution at end of DMA abort procedure */
1431 hsmartcard->hdmatx->XferAbortCallback = NULL;
1433 if (HAL_DMA_Abort(hsmartcard->hdmatx) != HAL_OK)
1435 if (HAL_DMA_GetError(hsmartcard->hdmatx) == HAL_DMA_ERROR_TIMEOUT)
1437 /* Set error code to DMA */
1438 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1440 return HAL_TIMEOUT;
1446 /* Reset Tx transfer counter */
1447 hsmartcard->TxXferCount = 0U;
1449 /* Clear the Error flags in the ICR register */
1450 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF);
1452 /* Restore hsmartcard->gState to Ready */
1453 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1455 return HAL_OK;
1459 * @brief Abort ongoing Receive transfer (blocking mode).
1460 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1461 * the configuration information for the specified SMARTCARD module.
1462 * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode.
1463 * This procedure performs following operations :
1464 * - Disable SMARTCARD Interrupts (Rx)
1465 * - Disable the DMA transfer in the peripheral register (if enabled)
1466 * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode)
1467 * - Set handle State to READY
1468 * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed.
1469 * @retval HAL status
1471 HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive(SMARTCARD_HandleTypeDef *hsmartcard)
1473 /* Disable RTOIE, EOBIE, RXNE, PE, RXFT, TXFT and ERR (Frame error, noise error, overrun error) interrupts */
1474 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE | USART_CR1_RTOIE |
1475 USART_CR1_EOBIE));
1476 CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_EIE | USART_CR3_RXFTIE));
1478 /* Check if a Transmit process is ongoing or not. If not disable ERR IT */
1479 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
1481 /* Disable the SMARTCARD Error Interrupt: (Frame error) */
1482 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1485 /* Disable the SMARTCARD DMA Rx request if enabled */
1486 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1488 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1490 /* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */
1491 if (hsmartcard->hdmarx != NULL)
1493 /* Set the SMARTCARD DMA Abort callback to Null.
1494 No call back execution at end of DMA abort procedure */
1495 hsmartcard->hdmarx->XferAbortCallback = NULL;
1497 if (HAL_DMA_Abort(hsmartcard->hdmarx) != HAL_OK)
1499 if (HAL_DMA_GetError(hsmartcard->hdmarx) == HAL_DMA_ERROR_TIMEOUT)
1501 /* Set error code to DMA */
1502 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA;
1504 return HAL_TIMEOUT;
1510 /* Reset Rx transfer counter */
1511 hsmartcard->RxXferCount = 0U;
1513 /* Clear the Error flags in the ICR register */
1514 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
1515 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF |
1516 SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
1518 /* Restore hsmartcard->RxState to Ready */
1519 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1521 return HAL_OK;
1525 * @brief Abort ongoing transfers (Interrupt mode).
1526 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1527 * the configuration information for the specified SMARTCARD module.
1528 * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode.
1529 * This procedure performs following operations :
1530 * - Disable SMARTCARD Interrupts (Tx and Rx)
1531 * - Disable the DMA transfer in the peripheral register (if enabled)
1532 * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode)
1533 * - Set handle State to READY
1534 * - At abort completion, call user abort complete callback
1535 * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be
1536 * considered as completed only when user abort complete callback is executed (not when exiting function).
1537 * @retval HAL status
1539 HAL_StatusTypeDef HAL_SMARTCARD_Abort_IT(SMARTCARD_HandleTypeDef *hsmartcard)
1541 uint32_t abortcplt = 1U;
1543 /* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE, RXFT, TXFT and
1544 ERR (Frame error, noise error, overrun error) interrupts */
1545 CLEAR_BIT(hsmartcard->Instance->CR1,
1546 (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE | USART_CR1_TXEIE_TXFNFIE | USART_CR1_TCIE | USART_CR1_RTOIE |
1547 USART_CR1_EOBIE));
1548 CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_EIE | USART_CR3_RXFTIE | USART_CR3_TXFTIE));
1550 /* If DMA Tx and/or DMA Rx Handles are associated to SMARTCARD Handle,
1551 DMA Abort complete callbacks should be initialised before any call
1552 to DMA Abort functions */
1553 /* DMA Tx Handle is valid */
1554 if (hsmartcard->hdmatx != NULL)
1556 /* Set DMA Abort Complete callback if SMARTCARD DMA Tx request if enabled.
1557 Otherwise, set it to NULL */
1558 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
1560 hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMATxAbortCallback;
1562 else
1564 hsmartcard->hdmatx->XferAbortCallback = NULL;
1567 /* DMA Rx Handle is valid */
1568 if (hsmartcard->hdmarx != NULL)
1570 /* Set DMA Abort Complete callback if SMARTCARD DMA Rx request if enabled.
1571 Otherwise, set it to NULL */
1572 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1574 hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMARxAbortCallback;
1576 else
1578 hsmartcard->hdmarx->XferAbortCallback = NULL;
1582 /* Disable the SMARTCARD DMA Tx request if enabled */
1583 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
1585 /* Disable DMA Tx at UART level */
1586 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
1588 /* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */
1589 if (hsmartcard->hdmatx != NULL)
1591 /* SMARTCARD Tx DMA Abort callback has already been initialised :
1592 will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */
1594 /* Abort DMA TX */
1595 if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK)
1597 hsmartcard->hdmatx->XferAbortCallback = NULL;
1599 else
1601 abortcplt = 0U;
1606 /* Disable the SMARTCARD DMA Rx request if enabled */
1607 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1609 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1611 /* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */
1612 if (hsmartcard->hdmarx != NULL)
1614 /* SMARTCARD Rx DMA Abort callback has already been initialised :
1615 will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */
1617 /* Abort DMA RX */
1618 if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK)
1620 hsmartcard->hdmarx->XferAbortCallback = NULL;
1621 abortcplt = 1U;
1623 else
1625 abortcplt = 0U;
1630 /* if no DMA abort complete callback execution is required => call user Abort Complete callback */
1631 if (abortcplt == 1U)
1633 /* Reset Tx and Rx transfer counters */
1634 hsmartcard->TxXferCount = 0U;
1635 hsmartcard->RxXferCount = 0U;
1637 /* Clear ISR function pointers */
1638 hsmartcard->RxISR = NULL;
1639 hsmartcard->TxISR = NULL;
1641 /* Reset errorCode */
1642 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
1644 /* Clear the Error flags in the ICR register */
1645 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
1646 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF |
1647 SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
1649 /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
1650 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1651 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1653 /* As no DMA to be aborted, call directly user Abort complete callback */
1654 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1655 /* Call registered Abort complete callback */
1656 hsmartcard->AbortCpltCallback(hsmartcard);
1657 #else
1658 /* Call legacy weak Abort complete callback */
1659 HAL_SMARTCARD_AbortCpltCallback(hsmartcard);
1660 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
1663 return HAL_OK;
1667 * @brief Abort ongoing Transmit transfer (Interrupt mode).
1668 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1669 * the configuration information for the specified SMARTCARD module.
1670 * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode.
1671 * This procedure performs following operations :
1672 * - Disable SMARTCARD Interrupts (Tx)
1673 * - Disable the DMA transfer in the peripheral register (if enabled)
1674 * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode)
1675 * - Set handle State to READY
1676 * - At abort completion, call user abort complete callback
1677 * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be
1678 * considered as completed only when user abort complete callback is executed (not when exiting function).
1679 * @retval HAL status
1681 HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard)
1683 /* Disable TCIE, TXEIE and TXFTIE interrupts */
1684 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE_TXFNFIE | USART_CR1_TCIE));
1685 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_TXFTIE);
1687 /* Check if a receive process is ongoing or not. If not disable ERR IT */
1688 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
1690 /* Disable the SMARTCARD Error Interrupt: (Frame error) */
1691 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1694 /* Disable the SMARTCARD DMA Tx request if enabled */
1695 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
1697 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
1699 /* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */
1700 if (hsmartcard->hdmatx != NULL)
1702 /* Set the SMARTCARD DMA Abort callback :
1703 will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */
1704 hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMATxOnlyAbortCallback;
1706 /* Abort DMA TX */
1707 if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK)
1709 /* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */
1710 hsmartcard->hdmatx->XferAbortCallback(hsmartcard->hdmatx);
1713 else
1715 /* Reset Tx transfer counter */
1716 hsmartcard->TxXferCount = 0U;
1718 /* Clear TxISR function pointers */
1719 hsmartcard->TxISR = NULL;
1721 /* Restore hsmartcard->gState to Ready */
1722 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1724 /* As no DMA to be aborted, call directly user Abort complete callback */
1725 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1726 /* Call registered Abort Transmit Complete Callback */
1727 hsmartcard->AbortTransmitCpltCallback(hsmartcard);
1728 #else
1729 /* Call legacy weak Abort Transmit Complete Callback */
1730 HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard);
1731 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
1734 else
1736 /* Reset Tx transfer counter */
1737 hsmartcard->TxXferCount = 0U;
1739 /* Clear TxISR function pointers */
1740 hsmartcard->TxISR = NULL;
1742 /* Clear the Error flags in the ICR register */
1743 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF);
1745 /* Restore hsmartcard->gState to Ready */
1746 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
1748 /* As no DMA to be aborted, call directly user Abort complete callback */
1749 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1750 /* Call registered Abort Transmit Complete Callback */
1751 hsmartcard->AbortTransmitCpltCallback(hsmartcard);
1752 #else
1753 /* Call legacy weak Abort Transmit Complete Callback */
1754 HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard);
1755 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
1758 return HAL_OK;
1762 * @brief Abort ongoing Receive transfer (Interrupt mode).
1763 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1764 * the configuration information for the specified SMARTCARD module.
1765 * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode.
1766 * This procedure performs following operations :
1767 * - Disable SMARTCARD Interrupts (Rx)
1768 * - Disable the DMA transfer in the peripheral register (if enabled)
1769 * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode)
1770 * - Set handle State to READY
1771 * - At abort completion, call user abort complete callback
1772 * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be
1773 * considered as completed only when user abort complete callback is executed (not when exiting function).
1774 * @retval HAL status
1776 HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive_IT(SMARTCARD_HandleTypeDef *hsmartcard)
1778 /* Disable RTOIE, EOBIE, RXNE, PE, RXFT and ERR (Frame error, noise error, overrun error) interrupts */
1779 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE | USART_CR1_RTOIE |
1780 USART_CR1_EOBIE));
1781 CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_EIE | USART_CR3_RXFTIE));
1783 /* Check if a Transmit process is ongoing or not. If not disable ERR IT */
1784 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
1786 /* Disable the SMARTCARD Error Interrupt: (Frame error) */
1787 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
1790 /* Disable the SMARTCARD DMA Rx request if enabled */
1791 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1793 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1795 /* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */
1796 if (hsmartcard->hdmarx != NULL)
1798 /* Set the SMARTCARD DMA Abort callback :
1799 will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */
1800 hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMARxOnlyAbortCallback;
1802 /* Abort DMA RX */
1803 if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK)
1805 /* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */
1806 hsmartcard->hdmarx->XferAbortCallback(hsmartcard->hdmarx);
1809 else
1811 /* Reset Rx transfer counter */
1812 hsmartcard->RxXferCount = 0U;
1814 /* Clear RxISR function pointer */
1815 hsmartcard->RxISR = NULL;
1817 /* Clear the Error flags in the ICR register */
1818 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
1819 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF |
1820 SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
1822 /* Restore hsmartcard->RxState to Ready */
1823 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1825 /* As no DMA to be aborted, call directly user Abort complete callback */
1826 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1827 /* Call registered Abort Receive Complete Callback */
1828 hsmartcard->AbortReceiveCpltCallback(hsmartcard);
1829 #else
1830 /* Call legacy weak Abort Receive Complete Callback */
1831 HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard);
1832 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
1835 else
1837 /* Reset Rx transfer counter */
1838 hsmartcard->RxXferCount = 0U;
1840 /* Clear RxISR function pointer */
1841 hsmartcard->RxISR = NULL;
1843 /* Clear the Error flags in the ICR register */
1844 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
1845 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF |
1846 SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
1848 /* Restore hsmartcard->RxState to Ready */
1849 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
1851 /* As no DMA to be aborted, call directly user Abort complete callback */
1852 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1853 /* Call registered Abort Receive Complete Callback */
1854 hsmartcard->AbortReceiveCpltCallback(hsmartcard);
1855 #else
1856 /* Call legacy weak Abort Receive Complete Callback */
1857 HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard);
1858 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
1861 return HAL_OK;
1865 * @brief Handle SMARTCARD interrupt requests.
1866 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
1867 * the configuration information for the specified SMARTCARD module.
1868 * @retval None
1870 void HAL_SMARTCARD_IRQHandler(SMARTCARD_HandleTypeDef *hsmartcard)
1872 uint32_t isrflags = READ_REG(hsmartcard->Instance->ISR);
1873 uint32_t cr1its = READ_REG(hsmartcard->Instance->CR1);
1874 uint32_t cr3its = READ_REG(hsmartcard->Instance->CR3);
1875 uint32_t errorflags;
1876 uint32_t errorcode;
1878 /* If no error occurs */
1879 errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF));
1880 if (errorflags == 0U)
1882 /* SMARTCARD in mode Receiver ---------------------------------------------------*/
1883 if (((isrflags & USART_ISR_RXNE_RXFNE) != 0U)
1884 && (((cr1its & USART_CR1_RXNEIE_RXFNEIE) != 0U)
1885 || ((cr3its & USART_CR3_RXFTIE) != 0U)))
1887 if (hsmartcard->RxISR != NULL)
1889 hsmartcard->RxISR(hsmartcard);
1891 return;
1895 /* If some errors occur */
1896 if ((errorflags != 0U)
1897 && ((((cr3its & (USART_CR3_RXFTIE | USART_CR3_EIE)) != 0U)
1898 || ((cr1its & (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE)) != 0U))))
1900 /* SMARTCARD parity error interrupt occurred -------------------------------------*/
1901 if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U))
1903 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_PEF);
1905 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_PE;
1908 /* SMARTCARD frame error interrupt occurred --------------------------------------*/
1909 if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U))
1911 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_FEF);
1913 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_FE;
1916 /* SMARTCARD noise error interrupt occurred --------------------------------------*/
1917 if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U))
1919 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_NEF);
1921 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_NE;
1924 /* SMARTCARD Over-Run interrupt occurred -----------------------------------------*/
1925 if (((isrflags & USART_ISR_ORE) != 0U)
1926 && (((cr1its & USART_CR1_RXNEIE_RXFNEIE) != 0U)
1927 || ((cr3its & USART_CR3_RXFTIE) != 0U)
1928 || ((cr3its & USART_CR3_EIE) != 0U)))
1930 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_OREF);
1932 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_ORE;
1935 /* SMARTCARD receiver timeout interrupt occurred -----------------------------------------*/
1936 if (((isrflags & USART_ISR_RTOF) != 0U) && ((cr1its & USART_CR1_RTOIE) != 0U))
1938 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_RTOF);
1940 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_RTO;
1943 /* Call SMARTCARD Error Call back function if need be --------------------------*/
1944 if (hsmartcard->ErrorCode != HAL_SMARTCARD_ERROR_NONE)
1946 /* SMARTCARD in mode Receiver ---------------------------------------------------*/
1947 if (((isrflags & USART_ISR_RXNE_RXFNE) != 0U)
1948 && (((cr1its & USART_CR1_RXNEIE_RXFNEIE) != 0U)
1949 || ((cr3its & USART_CR3_RXFTIE) != 0U)))
1951 if (hsmartcard->RxISR != NULL)
1953 hsmartcard->RxISR(hsmartcard);
1957 /* If Error is to be considered as blocking :
1958 - Receiver Timeout error in Reception
1959 - Overrun error in Reception
1960 - any error occurs in DMA mode reception
1962 errorcode = hsmartcard->ErrorCode;
1963 if ((HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1964 || ((errorcode & (HAL_SMARTCARD_ERROR_RTO | HAL_SMARTCARD_ERROR_ORE)) != 0U))
1966 /* Blocking error : transfer is aborted
1967 Set the SMARTCARD state ready to be able to start again the process,
1968 Disable Rx Interrupts, and disable Rx DMA request, if ongoing */
1969 SMARTCARD_EndRxTransfer(hsmartcard);
1971 /* Disable the SMARTCARD DMA Rx request if enabled */
1972 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
1974 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
1976 /* Abort the SMARTCARD DMA Rx channel */
1977 if (hsmartcard->hdmarx != NULL)
1979 /* Set the SMARTCARD DMA Abort callback :
1980 will lead to call HAL_SMARTCARD_ErrorCallback() at end of DMA abort procedure */
1981 hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMAAbortOnError;
1983 /* Abort DMA RX */
1984 if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK)
1986 /* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */
1987 hsmartcard->hdmarx->XferAbortCallback(hsmartcard->hdmarx);
1990 else
1992 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
1993 /* Call registered user error callback */
1994 hsmartcard->ErrorCallback(hsmartcard);
1995 #else
1996 /* Call legacy weak user error callback */
1997 HAL_SMARTCARD_ErrorCallback(hsmartcard);
1998 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2001 else
2003 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2004 /* Call registered user error callback */
2005 hsmartcard->ErrorCallback(hsmartcard);
2006 #else
2007 /* Call legacy weak user error callback */
2008 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2009 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2012 /* other error type to be considered as blocking :
2013 - Frame error in Transmission
2015 else if ((hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX)
2016 && ((errorcode & HAL_SMARTCARD_ERROR_FE) != 0U))
2018 /* Blocking error : transfer is aborted
2019 Set the SMARTCARD state ready to be able to start again the process,
2020 Disable Tx Interrupts, and disable Tx DMA request, if ongoing */
2021 SMARTCARD_EndTxTransfer(hsmartcard);
2023 /* Disable the SMARTCARD DMA Tx request if enabled */
2024 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
2026 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
2028 /* Abort the SMARTCARD DMA Tx channel */
2029 if (hsmartcard->hdmatx != NULL)
2031 /* Set the SMARTCARD DMA Abort callback :
2032 will lead to call HAL_SMARTCARD_ErrorCallback() at end of DMA abort procedure */
2033 hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMAAbortOnError;
2035 /* Abort DMA TX */
2036 if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK)
2038 /* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */
2039 hsmartcard->hdmatx->XferAbortCallback(hsmartcard->hdmatx);
2042 else
2044 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2045 /* Call registered user error callback */
2046 hsmartcard->ErrorCallback(hsmartcard);
2047 #else
2048 /* Call legacy weak user error callback */
2049 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2050 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2053 else
2055 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2056 /* Call registered user error callback */
2057 hsmartcard->ErrorCallback(hsmartcard);
2058 #else
2059 /* Call legacy weak user error callback */
2060 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2061 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2064 else
2066 /* Non Blocking error : transfer could go on.
2067 Error is notified to user through user error callback */
2068 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2069 /* Call registered user error callback */
2070 hsmartcard->ErrorCallback(hsmartcard);
2071 #else
2072 /* Call legacy weak user error callback */
2073 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2074 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2075 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
2078 return;
2080 } /* End if some error occurs */
2082 /* SMARTCARD in mode Receiver, end of block interruption ------------------------*/
2083 if (((isrflags & USART_ISR_EOBF) != 0U) && ((cr1its & USART_CR1_EOBIE) != 0U))
2085 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2086 __HAL_UNLOCK(hsmartcard);
2087 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2088 /* Call registered Rx complete callback */
2089 hsmartcard->RxCpltCallback(hsmartcard);
2090 #else
2091 /* Call legacy weak Rx complete callback */
2092 HAL_SMARTCARD_RxCpltCallback(hsmartcard);
2093 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2094 /* Clear EOBF interrupt after HAL_SMARTCARD_RxCpltCallback() call for the End of Block information
2095 to be available during HAL_SMARTCARD_RxCpltCallback() processing */
2096 __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_EOBF);
2097 return;
2100 /* SMARTCARD in mode Transmitter ------------------------------------------------*/
2101 if (((isrflags & USART_ISR_TXE_TXFNF) != 0U)
2102 && (((cr1its & USART_CR1_TXEIE_TXFNFIE) != 0U)
2103 || ((cr3its & USART_CR3_TXFTIE) != 0U)))
2105 if (hsmartcard->TxISR != NULL)
2107 hsmartcard->TxISR(hsmartcard);
2109 return;
2112 /* SMARTCARD in mode Transmitter (transmission end) ------------------------*/
2113 if (__HAL_SMARTCARD_GET_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication) != RESET)
2115 if (__HAL_SMARTCARD_GET_IT_SOURCE(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication) != RESET)
2117 SMARTCARD_EndTransmit_IT(hsmartcard);
2118 return;
2122 /* SMARTCARD TX Fifo Empty occurred ----------------------------------------------*/
2123 if (((isrflags & USART_ISR_TXFE) != 0U) && ((cr1its & USART_CR1_TXFEIE) != 0U))
2125 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2126 /* Call registered Tx Fifo Empty Callback */
2127 hsmartcard->TxFifoEmptyCallback(hsmartcard);
2128 #else
2129 /* Call legacy weak Tx Fifo Empty Callback */
2130 HAL_SMARTCARDEx_TxFifoEmptyCallback(hsmartcard);
2131 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2132 return;
2135 /* SMARTCARD RX Fifo Full occurred ----------------------------------------------*/
2136 if (((isrflags & USART_ISR_RXFF) != 0U) && ((cr1its & USART_CR1_RXFFIE) != 0U))
2138 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2139 /* Call registered Rx Fifo Full Callback */
2140 hsmartcard->RxFifoFullCallback(hsmartcard);
2141 #else
2142 /* Call legacy weak Rx Fifo Full Callback */
2143 HAL_SMARTCARDEx_RxFifoFullCallback(hsmartcard);
2144 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2145 return;
2150 * @brief Tx Transfer completed callback.
2151 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2152 * the configuration information for the specified SMARTCARD module.
2153 * @retval None
2155 __weak void HAL_SMARTCARD_TxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2157 /* Prevent unused argument(s) compilation warning */
2158 UNUSED(hsmartcard);
2160 /* NOTE : This function should not be modified, when the callback is needed,
2161 the HAL_SMARTCARD_TxCpltCallback can be implemented in the user file.
2166 * @brief Rx Transfer completed callback.
2167 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2168 * the configuration information for the specified SMARTCARD module.
2169 * @retval None
2171 __weak void HAL_SMARTCARD_RxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2173 /* Prevent unused argument(s) compilation warning */
2174 UNUSED(hsmartcard);
2176 /* NOTE : This function should not be modified, when the callback is needed,
2177 the HAL_SMARTCARD_RxCpltCallback can be implemented in the user file.
2182 * @brief SMARTCARD error callback.
2183 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2184 * the configuration information for the specified SMARTCARD module.
2185 * @retval None
2187 __weak void HAL_SMARTCARD_ErrorCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2189 /* Prevent unused argument(s) compilation warning */
2190 UNUSED(hsmartcard);
2192 /* NOTE : This function should not be modified, when the callback is needed,
2193 the HAL_SMARTCARD_ErrorCallback can be implemented in the user file.
2198 * @brief SMARTCARD Abort Complete callback.
2199 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2200 * the configuration information for the specified SMARTCARD module.
2201 * @retval None
2203 __weak void HAL_SMARTCARD_AbortCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2205 /* Prevent unused argument(s) compilation warning */
2206 UNUSED(hsmartcard);
2208 /* NOTE : This function should not be modified, when the callback is needed,
2209 the HAL_SMARTCARD_AbortCpltCallback can be implemented in the user file.
2214 * @brief SMARTCARD Abort Complete callback.
2215 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2216 * the configuration information for the specified SMARTCARD module.
2217 * @retval None
2219 __weak void HAL_SMARTCARD_AbortTransmitCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2221 /* Prevent unused argument(s) compilation warning */
2222 UNUSED(hsmartcard);
2224 /* NOTE : This function should not be modified, when the callback is needed,
2225 the HAL_SMARTCARD_AbortTransmitCpltCallback can be implemented in the user file.
2230 * @brief SMARTCARD Abort Receive Complete callback.
2231 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2232 * the configuration information for the specified SMARTCARD module.
2233 * @retval None
2235 __weak void HAL_SMARTCARD_AbortReceiveCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard)
2237 /* Prevent unused argument(s) compilation warning */
2238 UNUSED(hsmartcard);
2240 /* NOTE : This function should not be modified, when the callback is needed,
2241 the HAL_SMARTCARD_AbortReceiveCpltCallback can be implemented in the user file.
2246 * @}
2249 /** @defgroup SMARTCARD_Exported_Functions_Group4 Peripheral State and Errors functions
2250 * @brief SMARTCARD State and Errors functions
2252 @verbatim
2253 ==============================================================================
2254 ##### Peripheral State and Errors functions #####
2255 ==============================================================================
2256 [..]
2257 This subsection provides a set of functions allowing to return the State of SmartCard
2258 handle and also return Peripheral Errors occurred during communication process
2259 (+) HAL_SMARTCARD_GetState() API can be helpful to check in run-time the state
2260 of the SMARTCARD peripheral.
2261 (+) HAL_SMARTCARD_GetError() checks in run-time errors that could occur during
2262 communication.
2264 @endverbatim
2265 * @{
2269 * @brief Return the SMARTCARD handle state.
2270 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2271 * the configuration information for the specified SMARTCARD module.
2272 * @retval SMARTCARD handle state
2274 HAL_SMARTCARD_StateTypeDef HAL_SMARTCARD_GetState(const SMARTCARD_HandleTypeDef *hsmartcard)
2276 /* Return SMARTCARD handle state */
2277 uint32_t temp1;
2278 uint32_t temp2;
2279 temp1 = (uint32_t)hsmartcard->gState;
2280 temp2 = (uint32_t)hsmartcard->RxState;
2282 return (HAL_SMARTCARD_StateTypeDef)(temp1 | temp2);
2286 * @brief Return the SMARTCARD handle error code.
2287 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2288 * the configuration information for the specified SMARTCARD module.
2289 * @retval SMARTCARD handle Error Code
2291 uint32_t HAL_SMARTCARD_GetError(const SMARTCARD_HandleTypeDef *hsmartcard)
2293 return hsmartcard->ErrorCode;
2297 * @}
2301 * @}
2304 /** @defgroup SMARTCARD_Private_Functions SMARTCARD Private Functions
2305 * @{
2308 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2310 * @brief Initialize the callbacks to their default values.
2311 * @param hsmartcard SMARTCARD handle.
2312 * @retval none
2314 void SMARTCARD_InitCallbacksToDefault(SMARTCARD_HandleTypeDef *hsmartcard)
2316 /* Init the SMARTCARD Callback settings */
2317 hsmartcard->TxCpltCallback = HAL_SMARTCARD_TxCpltCallback; /* Legacy weak TxCpltCallback */
2318 hsmartcard->RxCpltCallback = HAL_SMARTCARD_RxCpltCallback; /* Legacy weak RxCpltCallback */
2319 hsmartcard->ErrorCallback = HAL_SMARTCARD_ErrorCallback; /* Legacy weak ErrorCallback */
2320 hsmartcard->AbortCpltCallback = HAL_SMARTCARD_AbortCpltCallback; /* Legacy weak AbortCpltCallback */
2321 hsmartcard->AbortTransmitCpltCallback = HAL_SMARTCARD_AbortTransmitCpltCallback; /* Legacy weak
2322 AbortTransmitCpltCallback */
2323 hsmartcard->AbortReceiveCpltCallback = HAL_SMARTCARD_AbortReceiveCpltCallback; /* Legacy weak
2324 AbortReceiveCpltCallback */
2325 hsmartcard->RxFifoFullCallback = HAL_SMARTCARDEx_RxFifoFullCallback; /* Legacy weak
2326 RxFifoFullCallback */
2327 hsmartcard->TxFifoEmptyCallback = HAL_SMARTCARDEx_TxFifoEmptyCallback; /* Legacy weak
2328 TxFifoEmptyCallback */
2331 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */
2334 * @brief Configure the SMARTCARD associated USART peripheral.
2335 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2336 * the configuration information for the specified SMARTCARD module.
2337 * @retval HAL status
2339 static HAL_StatusTypeDef SMARTCARD_SetConfig(SMARTCARD_HandleTypeDef *hsmartcard)
2341 uint32_t tmpreg;
2342 SMARTCARD_ClockSourceTypeDef clocksource;
2343 HAL_StatusTypeDef ret = HAL_OK;
2344 static const uint16_t SMARTCARDPrescTable[12] = {1U, 2U, 4U, 6U, 8U, 10U, 12U, 16U, 32U, 64U, 128U, 256U};
2345 PLL2_ClocksTypeDef pll2_clocks;
2346 PLL3_ClocksTypeDef pll3_clocks;
2347 uint32_t pclk;
2349 /* Check the parameters */
2350 assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance));
2351 assert_param(IS_SMARTCARD_BAUDRATE(hsmartcard->Init.BaudRate));
2352 assert_param(IS_SMARTCARD_WORD_LENGTH(hsmartcard->Init.WordLength));
2353 assert_param(IS_SMARTCARD_STOPBITS(hsmartcard->Init.StopBits));
2354 assert_param(IS_SMARTCARD_PARITY(hsmartcard->Init.Parity));
2355 assert_param(IS_SMARTCARD_MODE(hsmartcard->Init.Mode));
2356 assert_param(IS_SMARTCARD_POLARITY(hsmartcard->Init.CLKPolarity));
2357 assert_param(IS_SMARTCARD_PHASE(hsmartcard->Init.CLKPhase));
2358 assert_param(IS_SMARTCARD_LASTBIT(hsmartcard->Init.CLKLastBit));
2359 assert_param(IS_SMARTCARD_ONE_BIT_SAMPLE(hsmartcard->Init.OneBitSampling));
2360 assert_param(IS_SMARTCARD_NACK(hsmartcard->Init.NACKEnable));
2361 assert_param(IS_SMARTCARD_TIMEOUT(hsmartcard->Init.TimeOutEnable));
2362 assert_param(IS_SMARTCARD_AUTORETRY_COUNT(hsmartcard->Init.AutoRetryCount));
2363 assert_param(IS_SMARTCARD_CLOCKPRESCALER(hsmartcard->Init.ClockPrescaler));
2365 /*-------------------------- USART CR1 Configuration -----------------------*/
2366 /* In SmartCard mode, M and PCE are forced to 1 (8 bits + parity).
2367 * Oversampling is forced to 16 (OVER8 = 0).
2368 * Configure the Parity and Mode:
2369 * set PS bit according to hsmartcard->Init.Parity value
2370 * set TE and RE bits according to hsmartcard->Init.Mode value */
2371 tmpreg = (((uint32_t)hsmartcard->Init.Parity) | ((uint32_t)hsmartcard->Init.Mode) |
2372 ((uint32_t)hsmartcard->Init.WordLength));
2373 MODIFY_REG(hsmartcard->Instance->CR1, USART_CR1_FIELDS, tmpreg);
2375 /*-------------------------- USART CR2 Configuration -----------------------*/
2376 tmpreg = hsmartcard->Init.StopBits;
2377 /* Synchronous mode is activated by default */
2378 tmpreg |= (uint32_t) USART_CR2_CLKEN | hsmartcard->Init.CLKPolarity;
2379 tmpreg |= (uint32_t) hsmartcard->Init.CLKPhase | hsmartcard->Init.CLKLastBit;
2380 tmpreg |= (uint32_t) hsmartcard->Init.TimeOutEnable;
2381 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_FIELDS, tmpreg);
2383 /*-------------------------- USART CR3 Configuration -----------------------*/
2384 /* Configure
2385 * - one-bit sampling method versus three samples' majority rule
2386 * according to hsmartcard->Init.OneBitSampling
2387 * - NACK transmission in case of parity error according
2388 * to hsmartcard->Init.NACKEnable
2389 * - autoretry counter according to hsmartcard->Init.AutoRetryCount */
2391 tmpreg = (uint32_t) hsmartcard->Init.OneBitSampling | hsmartcard->Init.NACKEnable;
2392 tmpreg |= ((uint32_t)hsmartcard->Init.AutoRetryCount << USART_CR3_SCARCNT_Pos);
2393 MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_FIELDS, tmpreg);
2395 /*--------------------- SMARTCARD clock PRESC Configuration ----------------*/
2396 /* Configure
2397 * - SMARTCARD Clock Prescaler: set PRESCALER according to hsmartcard->Init.ClockPrescaler value */
2398 MODIFY_REG(hsmartcard->Instance->PRESC, USART_PRESC_PRESCALER, hsmartcard->Init.ClockPrescaler);
2400 /*-------------------------- USART GTPR Configuration ----------------------*/
2401 tmpreg = (hsmartcard->Init.Prescaler | ((uint32_t)hsmartcard->Init.GuardTime << USART_GTPR_GT_Pos));
2402 MODIFY_REG(hsmartcard->Instance->GTPR, (uint16_t)(USART_GTPR_GT | USART_GTPR_PSC), (uint16_t)tmpreg);
2404 /*-------------------------- USART RTOR Configuration ----------------------*/
2405 tmpreg = ((uint32_t)hsmartcard->Init.BlockLength << USART_RTOR_BLEN_Pos);
2406 if (hsmartcard->Init.TimeOutEnable == SMARTCARD_TIMEOUT_ENABLE)
2408 assert_param(IS_SMARTCARD_TIMEOUT_VALUE(hsmartcard->Init.TimeOutValue));
2409 tmpreg |= (uint32_t) hsmartcard->Init.TimeOutValue;
2411 WRITE_REG(hsmartcard->Instance->RTOR, tmpreg);
2413 /*-------------------------- USART BRR Configuration -----------------------*/
2414 SMARTCARD_GETCLOCKSOURCE(hsmartcard, clocksource);
2415 tmpreg = 0U;
2416 switch (clocksource)
2418 case SMARTCARD_CLOCKSOURCE_D2PCLK1:
2419 pclk = HAL_RCC_GetPCLK1Freq();
2420 tmpreg = (uint32_t)(((pclk / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2421 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2422 break;
2423 case SMARTCARD_CLOCKSOURCE_D2PCLK2:
2424 pclk = HAL_RCC_GetPCLK2Freq();
2425 tmpreg = (uint32_t)(((pclk / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2426 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2427 break;
2428 case SMARTCARD_CLOCKSOURCE_PLL2Q:
2429 HAL_RCCEx_GetPLL2ClockFreq(&pll2_clocks);
2430 tmpreg = (uint32_t)(((pll2_clocks.PLL2_Q_Frequency / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2431 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2432 break;
2433 case SMARTCARD_CLOCKSOURCE_PLL3Q:
2434 HAL_RCCEx_GetPLL3ClockFreq(&pll3_clocks);
2435 tmpreg = (uint32_t)(((pll3_clocks.PLL3_Q_Frequency / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2436 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2437 break;
2438 case SMARTCARD_CLOCKSOURCE_HSI:
2439 if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIDIV) != 0U)
2441 tmpreg = (uint32_t)((((HSI_VALUE >> (__HAL_RCC_GET_HSI_DIVIDER() >> 3U)) /
2442 SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2443 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2445 else
2447 tmpreg = (uint32_t)(((HSI_VALUE / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2448 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2450 break;
2451 case SMARTCARD_CLOCKSOURCE_CSI:
2452 tmpreg = (uint32_t)(((CSI_VALUE / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2453 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2454 break;
2455 case SMARTCARD_CLOCKSOURCE_LSE:
2456 tmpreg = (uint32_t)(((uint16_t)(LSE_VALUE / SMARTCARDPrescTable[hsmartcard->Init.ClockPrescaler]) +
2457 (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate);
2458 break;
2459 default:
2460 ret = HAL_ERROR;
2461 break;
2464 /* USARTDIV must be greater than or equal to 0d16 */
2465 if ((tmpreg >= USART_BRR_MIN) && (tmpreg <= USART_BRR_MAX))
2467 hsmartcard->Instance->BRR = (uint16_t)tmpreg;
2469 else
2471 ret = HAL_ERROR;
2474 /* Initialize the number of data to process during RX/TX ISR execution */
2475 hsmartcard->NbTxDataToProcess = 1U;
2476 hsmartcard->NbRxDataToProcess = 1U;
2478 /* Clear ISR function pointers */
2479 hsmartcard->RxISR = NULL;
2480 hsmartcard->TxISR = NULL;
2482 return ret;
2487 * @brief Configure the SMARTCARD associated USART peripheral advanced features.
2488 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2489 * the configuration information for the specified SMARTCARD module.
2490 * @retval None
2492 static void SMARTCARD_AdvFeatureConfig(SMARTCARD_HandleTypeDef *hsmartcard)
2494 /* Check whether the set of advanced features to configure is properly set */
2495 assert_param(IS_SMARTCARD_ADVFEATURE_INIT(hsmartcard->AdvancedInit.AdvFeatureInit));
2497 /* if required, configure TX pin active level inversion */
2498 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_TXINVERT_INIT))
2500 assert_param(IS_SMARTCARD_ADVFEATURE_TXINV(hsmartcard->AdvancedInit.TxPinLevelInvert));
2501 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_TXINV, hsmartcard->AdvancedInit.TxPinLevelInvert);
2504 /* if required, configure RX pin active level inversion */
2505 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_RXINVERT_INIT))
2507 assert_param(IS_SMARTCARD_ADVFEATURE_RXINV(hsmartcard->AdvancedInit.RxPinLevelInvert));
2508 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_RXINV, hsmartcard->AdvancedInit.RxPinLevelInvert);
2511 /* if required, configure data inversion */
2512 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_DATAINVERT_INIT))
2514 assert_param(IS_SMARTCARD_ADVFEATURE_DATAINV(hsmartcard->AdvancedInit.DataInvert));
2515 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_DATAINV, hsmartcard->AdvancedInit.DataInvert);
2518 /* if required, configure RX/TX pins swap */
2519 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_SWAP_INIT))
2521 assert_param(IS_SMARTCARD_ADVFEATURE_SWAP(hsmartcard->AdvancedInit.Swap));
2522 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_SWAP, hsmartcard->AdvancedInit.Swap);
2525 /* if required, configure RX overrun detection disabling */
2526 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_RXOVERRUNDISABLE_INIT))
2528 assert_param(IS_SMARTCARD_OVERRUN(hsmartcard->AdvancedInit.OverrunDisable));
2529 MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_OVRDIS, hsmartcard->AdvancedInit.OverrunDisable);
2532 /* if required, configure DMA disabling on reception error */
2533 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_DMADISABLEONERROR_INIT))
2535 assert_param(IS_SMARTCARD_ADVFEATURE_DMAONRXERROR(hsmartcard->AdvancedInit.DMADisableonRxError));
2536 MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_DDRE, hsmartcard->AdvancedInit.DMADisableonRxError);
2539 /* if required, configure MSB first on communication line */
2540 if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_MSBFIRST_INIT))
2542 assert_param(IS_SMARTCARD_ADVFEATURE_MSBFIRST(hsmartcard->AdvancedInit.MSBFirst));
2543 MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_MSBFIRST, hsmartcard->AdvancedInit.MSBFirst);
2549 * @brief Check the SMARTCARD Idle State.
2550 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2551 * the configuration information for the specified SMARTCARD module.
2552 * @retval HAL status
2554 static HAL_StatusTypeDef SMARTCARD_CheckIdleState(SMARTCARD_HandleTypeDef *hsmartcard)
2556 uint32_t tickstart;
2558 /* Initialize the SMARTCARD ErrorCode */
2559 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
2561 /* Init tickstart for timeout management */
2562 tickstart = HAL_GetTick();
2564 /* Check if the Transmitter is enabled */
2565 if ((hsmartcard->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE)
2567 /* Wait until TEACK flag is set */
2568 if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, USART_ISR_TEACK, RESET, tickstart,
2569 SMARTCARD_TEACK_REACK_TIMEOUT) != HAL_OK)
2571 /* Timeout occurred */
2572 return HAL_TIMEOUT;
2575 /* Check if the Receiver is enabled */
2576 if ((hsmartcard->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE)
2578 /* Wait until REACK flag is set */
2579 if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, USART_ISR_REACK, RESET, tickstart,
2580 SMARTCARD_TEACK_REACK_TIMEOUT) != HAL_OK)
2582 /* Timeout occurred */
2583 return HAL_TIMEOUT;
2587 /* Initialize the SMARTCARD states */
2588 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2589 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2591 /* Process Unlocked */
2592 __HAL_UNLOCK(hsmartcard);
2594 return HAL_OK;
2598 * @brief Handle SMARTCARD Communication Timeout. It waits
2599 * until a flag is no longer in the specified status.
2600 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2601 * the configuration information for the specified SMARTCARD module.
2602 * @param Flag Specifies the SMARTCARD flag to check.
2603 * @param Status The actual Flag status (SET or RESET).
2604 * @param Tickstart Tick start value
2605 * @param Timeout Timeout duration.
2606 * @retval HAL status
2608 static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t Flag,
2609 FlagStatus Status, uint32_t Tickstart, uint32_t Timeout)
2611 /* Wait until flag is set */
2612 while ((__HAL_SMARTCARD_GET_FLAG(hsmartcard, Flag) ? SET : RESET) == Status)
2614 /* Check for the Timeout */
2615 if (Timeout != HAL_MAX_DELAY)
2617 if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
2619 /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error)
2620 interrupts for the interrupt process */
2621 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE | USART_CR1_TXEIE_TXFNFIE));
2622 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
2624 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2625 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2627 /* Process Unlocked */
2628 __HAL_UNLOCK(hsmartcard);
2629 return HAL_TIMEOUT;
2633 return HAL_OK;
2638 * @brief End ongoing Tx transfer on SMARTCARD peripheral (following error detection or Transmit completion).
2639 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2640 * the configuration information for the specified SMARTCARD module.
2641 * @retval None
2643 static void SMARTCARD_EndTxTransfer(SMARTCARD_HandleTypeDef *hsmartcard)
2645 /* Disable TXEIE, TCIE and ERR (Frame error, noise error, overrun error) interrupts */
2646 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE_TXFNFIE | USART_CR1_TCIE));
2647 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
2649 /* At end of Tx process, restore hsmartcard->gState to Ready */
2650 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2655 * @brief End ongoing Rx transfer on UART peripheral (following error detection or Reception completion).
2656 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2657 * the configuration information for the specified SMARTCARD module.
2658 * @retval None
2660 static void SMARTCARD_EndRxTransfer(SMARTCARD_HandleTypeDef *hsmartcard)
2662 /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
2663 CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE));
2664 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
2666 /* At end of Rx process, restore hsmartcard->RxState to Ready */
2667 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2672 * @brief DMA SMARTCARD transmit process complete callback.
2673 * @param hdma Pointer to a DMA_HandleTypeDef structure that contains
2674 * the configuration information for the specified DMA module.
2675 * @retval None
2677 static void SMARTCARD_DMATransmitCplt(DMA_HandleTypeDef *hdma)
2679 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2680 hsmartcard->TxXferCount = 0U;
2682 /* Disable the DMA transfer for transmit request by resetting the DMAT bit
2683 in the SMARTCARD associated USART CR3 register */
2684 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT);
2686 /* Enable the SMARTCARD Transmit Complete Interrupt */
2687 __HAL_SMARTCARD_ENABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication);
2691 * @brief DMA SMARTCARD receive process complete callback.
2692 * @param hdma Pointer to a DMA_HandleTypeDef structure that contains
2693 * the configuration information for the specified DMA module.
2694 * @retval None
2696 static void SMARTCARD_DMAReceiveCplt(DMA_HandleTypeDef *hdma)
2698 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2699 hsmartcard->RxXferCount = 0U;
2701 /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */
2702 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE);
2703 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
2705 /* Disable the DMA transfer for the receiver request by resetting the DMAR bit
2706 in the SMARTCARD associated USART CR3 register */
2707 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR);
2709 /* At end of Rx process, restore hsmartcard->RxState to Ready */
2710 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2712 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2713 /* Call registered Rx complete callback */
2714 hsmartcard->RxCpltCallback(hsmartcard);
2715 #else
2716 /* Call legacy weak Rx complete callback */
2717 HAL_SMARTCARD_RxCpltCallback(hsmartcard);
2718 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2722 * @brief DMA SMARTCARD communication error callback.
2723 * @param hdma Pointer to a DMA_HandleTypeDef structure that contains
2724 * the configuration information for the specified DMA module.
2725 * @retval None
2727 static void SMARTCARD_DMAError(DMA_HandleTypeDef *hdma)
2729 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2731 /* Stop SMARTCARD DMA Tx request if ongoing */
2732 if (hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX)
2734 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT))
2736 hsmartcard->TxXferCount = 0U;
2737 SMARTCARD_EndTxTransfer(hsmartcard);
2741 /* Stop SMARTCARD DMA Rx request if ongoing */
2742 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_BUSY_RX)
2744 if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR))
2746 hsmartcard->RxXferCount = 0U;
2747 SMARTCARD_EndRxTransfer(hsmartcard);
2751 hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_DMA;
2752 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2753 /* Call registered user error callback */
2754 hsmartcard->ErrorCallback(hsmartcard);
2755 #else
2756 /* Call legacy weak user error callback */
2757 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2758 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2762 * @brief DMA SMARTCARD communication abort callback, when initiated by HAL services on Error
2763 * (To be called at end of DMA Abort procedure following error occurrence).
2764 * @param hdma DMA handle.
2765 * @retval None
2767 static void SMARTCARD_DMAAbortOnError(DMA_HandleTypeDef *hdma)
2769 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2770 hsmartcard->RxXferCount = 0U;
2771 hsmartcard->TxXferCount = 0U;
2773 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2774 /* Call registered user error callback */
2775 hsmartcard->ErrorCallback(hsmartcard);
2776 #else
2777 /* Call legacy weak user error callback */
2778 HAL_SMARTCARD_ErrorCallback(hsmartcard);
2779 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2783 * @brief DMA SMARTCARD Tx communication abort callback, when initiated by user
2784 * (To be called at end of DMA Tx Abort procedure following user abort request).
2785 * @note When this callback is executed, User Abort complete call back is called only if no
2786 * Abort still ongoing for Rx DMA Handle.
2787 * @param hdma DMA handle.
2788 * @retval None
2790 static void SMARTCARD_DMATxAbortCallback(DMA_HandleTypeDef *hdma)
2792 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2794 hsmartcard->hdmatx->XferAbortCallback = NULL;
2796 /* Check if an Abort process is still ongoing */
2797 if (hsmartcard->hdmarx != NULL)
2799 if (hsmartcard->hdmarx->XferAbortCallback != NULL)
2801 return;
2805 /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */
2806 hsmartcard->TxXferCount = 0U;
2807 hsmartcard->RxXferCount = 0U;
2809 /* Reset errorCode */
2810 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
2812 /* Clear the Error flags in the ICR register */
2813 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
2814 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF |
2815 SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
2817 /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
2818 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2819 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2821 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2822 /* Call registered Abort complete callback */
2823 hsmartcard->AbortCpltCallback(hsmartcard);
2824 #else
2825 /* Call legacy weak Abort complete callback */
2826 HAL_SMARTCARD_AbortCpltCallback(hsmartcard);
2827 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2832 * @brief DMA SMARTCARD Rx communication abort callback, when initiated by user
2833 * (To be called at end of DMA Rx Abort procedure following user abort request).
2834 * @note When this callback is executed, User Abort complete call back is called only if no
2835 * Abort still ongoing for Tx DMA Handle.
2836 * @param hdma DMA handle.
2837 * @retval None
2839 static void SMARTCARD_DMARxAbortCallback(DMA_HandleTypeDef *hdma)
2841 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2843 hsmartcard->hdmarx->XferAbortCallback = NULL;
2845 /* Check if an Abort process is still ongoing */
2846 if (hsmartcard->hdmatx != NULL)
2848 if (hsmartcard->hdmatx->XferAbortCallback != NULL)
2850 return;
2854 /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */
2855 hsmartcard->TxXferCount = 0U;
2856 hsmartcard->RxXferCount = 0U;
2858 /* Reset errorCode */
2859 hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE;
2861 /* Clear the Error flags in the ICR register */
2862 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
2863 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF |
2864 SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
2866 /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
2867 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2868 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2870 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2871 /* Call registered Abort complete callback */
2872 hsmartcard->AbortCpltCallback(hsmartcard);
2873 #else
2874 /* Call legacy weak Abort complete callback */
2875 HAL_SMARTCARD_AbortCpltCallback(hsmartcard);
2876 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2881 * @brief DMA SMARTCARD Tx communication abort callback, when initiated by user by a call to
2882 * HAL_SMARTCARD_AbortTransmit_IT API (Abort only Tx transfer)
2883 * (This callback is executed at end of DMA Tx Abort procedure following user abort request,
2884 * and leads to user Tx Abort Complete callback execution).
2885 * @param hdma DMA handle.
2886 * @retval None
2888 static void SMARTCARD_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma)
2890 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2892 hsmartcard->TxXferCount = 0U;
2894 /* Clear the Error flags in the ICR register */
2895 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF);
2897 /* Restore hsmartcard->gState to Ready */
2898 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
2900 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2901 /* Call registered Abort Transmit Complete Callback */
2902 hsmartcard->AbortTransmitCpltCallback(hsmartcard);
2903 #else
2904 /* Call legacy weak Abort Transmit Complete Callback */
2905 HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard);
2906 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2910 * @brief DMA SMARTCARD Rx communication abort callback, when initiated by user by a call to
2911 * HAL_SMARTCARD_AbortReceive_IT API (Abort only Rx transfer)
2912 * (This callback is executed at end of DMA Rx Abort procedure following user abort request,
2913 * and leads to user Rx Abort Complete callback execution).
2914 * @param hdma DMA handle.
2915 * @retval None
2917 static void SMARTCARD_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma)
2919 SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent);
2921 hsmartcard->RxXferCount = 0U;
2923 /* Clear the Error flags in the ICR register */
2924 __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard,
2925 SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF |
2926 SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF);
2928 /* Restore hsmartcard->RxState to Ready */
2929 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
2931 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
2932 /* Call registered Abort Receive Complete Callback */
2933 hsmartcard->AbortReceiveCpltCallback(hsmartcard);
2934 #else
2935 /* Call legacy weak Abort Receive Complete Callback */
2936 HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard);
2937 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
2941 * @brief Send an amount of data in non-blocking mode.
2942 * @note Function called under interruption only, once
2943 * interruptions have been enabled by HAL_SMARTCARD_Transmit_IT()
2944 * and when the FIFO mode is disabled.
2945 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2946 * the configuration information for the specified SMARTCARD module.
2947 * @retval None
2949 static void SMARTCARD_TxISR(SMARTCARD_HandleTypeDef *hsmartcard)
2951 /* Check that a Tx process is ongoing */
2952 if (hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX)
2954 if (hsmartcard->TxXferCount == 0U)
2956 /* Disable the SMARTCARD Transmit Data Register Empty Interrupt */
2957 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_TXEIE_TXFNFIE);
2959 /* Enable the SMARTCARD Transmit Complete Interrupt */
2960 __HAL_SMARTCARD_ENABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication);
2962 else
2964 hsmartcard->Instance->TDR = (uint8_t)(*hsmartcard->pTxBuffPtr & 0xFFU);
2965 hsmartcard->pTxBuffPtr++;
2966 hsmartcard->TxXferCount--;
2972 * @brief Send an amount of data in non-blocking mode.
2973 * @note Function called under interruption only, once
2974 * interruptions have been enabled by HAL_SMARTCARD_Transmit_IT()
2975 * and when the FIFO mode is enabled.
2976 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
2977 * the configuration information for the specified SMARTCARD module.
2978 * @retval None
2980 static void SMARTCARD_TxISR_FIFOEN(SMARTCARD_HandleTypeDef *hsmartcard)
2982 uint16_t nb_tx_data;
2984 /* Check that a Tx process is ongoing */
2985 if (hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX)
2987 for (nb_tx_data = hsmartcard->NbTxDataToProcess ; nb_tx_data > 0U ; nb_tx_data--)
2989 if (hsmartcard->TxXferCount == 0U)
2991 /* Disable the SMARTCARD Transmit Data Register Empty Interrupt */
2992 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_TXEIE_TXFNFIE);
2994 /* Enable the SMARTCARD Transmit Complete Interrupt */
2995 __HAL_SMARTCARD_ENABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication);
2997 else if (READ_BIT(hsmartcard->Instance->ISR, USART_ISR_TXE_TXFNF) != 0U)
2999 hsmartcard->Instance->TDR = (uint8_t)(*hsmartcard->pTxBuffPtr & 0xFFU);
3000 hsmartcard->pTxBuffPtr++;
3001 hsmartcard->TxXferCount--;
3003 else
3005 /* Nothing to do */
3012 * @brief Wrap up transmission in non-blocking mode.
3013 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
3014 * the configuration information for the specified SMARTCARD module.
3015 * @retval None
3017 static void SMARTCARD_EndTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard)
3019 /* Disable the SMARTCARD Transmit Complete Interrupt */
3020 __HAL_SMARTCARD_DISABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication);
3022 /* Check if a receive process is ongoing or not. If not disable ERR IT */
3023 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY)
3025 /* Disable the SMARTCARD Error Interrupt: (Frame error) */
3026 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
3029 /* Disable the Peripheral first to update mode */
3030 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
3031 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX)
3032 && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
3034 /* In case of TX only mode, if NACK is enabled, receiver block has been enabled
3035 for Transmit phase. Disable this receiver block. */
3036 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RE);
3038 if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX_RX)
3039 || (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE))
3041 /* Perform a TX FIFO Flush at end of Tx phase, as all sent bytes are appearing in Rx Data register */
3042 __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard);
3044 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE);
3046 /* Tx process is ended, restore hsmartcard->gState to Ready */
3047 hsmartcard->gState = HAL_SMARTCARD_STATE_READY;
3049 /* Clear TxISR function pointer */
3050 hsmartcard->TxISR = NULL;
3052 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
3053 /* Call registered Tx complete callback */
3054 hsmartcard->TxCpltCallback(hsmartcard);
3055 #else
3056 /* Call legacy weak Tx complete callback */
3057 HAL_SMARTCARD_TxCpltCallback(hsmartcard);
3058 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
3062 * @brief Receive an amount of data in non-blocking mode.
3063 * @note Function called under interruption only, once
3064 * interruptions have been enabled by HAL_SMARTCARD_Receive_IT()
3065 * and when the FIFO mode is disabled.
3066 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
3067 * the configuration information for the specified SMARTCARD module.
3068 * @retval None
3070 static void SMARTCARD_RxISR(SMARTCARD_HandleTypeDef *hsmartcard)
3072 /* Check that a Rx process is ongoing */
3073 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_BUSY_RX)
3075 *hsmartcard->pRxBuffPtr = (uint8_t)(hsmartcard->Instance->RDR & (uint8_t)0xFF);
3076 hsmartcard->pRxBuffPtr++;
3078 hsmartcard->RxXferCount--;
3079 if (hsmartcard->RxXferCount == 0U)
3081 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RXNEIE_RXFNEIE);
3083 /* Check if a transmit process is ongoing or not. If not disable ERR IT */
3084 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
3086 /* Disable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
3087 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
3090 /* Disable the SMARTCARD Parity Error Interrupt */
3091 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE);
3093 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
3095 /* Clear RxISR function pointer */
3096 hsmartcard->RxISR = NULL;
3098 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
3099 /* Call registered Rx complete callback */
3100 hsmartcard->RxCpltCallback(hsmartcard);
3101 #else
3102 /* Call legacy weak Rx complete callback */
3103 HAL_SMARTCARD_RxCpltCallback(hsmartcard);
3104 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
3107 else
3109 /* Clear RXNE interrupt flag */
3110 __HAL_SMARTCARD_SEND_REQ(hsmartcard, SMARTCARD_RXDATA_FLUSH_REQUEST);
3115 * @brief Receive an amount of data in non-blocking mode.
3116 * @note Function called under interruption only, once
3117 * interruptions have been enabled by HAL_SMARTCARD_Receive_IT()
3118 * and when the FIFO mode is enabled.
3119 * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
3120 * the configuration information for the specified SMARTCARD module.
3121 * @retval None
3123 static void SMARTCARD_RxISR_FIFOEN(SMARTCARD_HandleTypeDef *hsmartcard)
3125 uint16_t nb_rx_data;
3126 uint16_t rxdatacount;
3128 /* Check that a Rx process is ongoing */
3129 if (hsmartcard->RxState == HAL_SMARTCARD_STATE_BUSY_RX)
3131 for (nb_rx_data = hsmartcard->NbRxDataToProcess ; nb_rx_data > 0U ; nb_rx_data--)
3133 *hsmartcard->pRxBuffPtr = (uint8_t)(hsmartcard->Instance->RDR & (uint8_t)0xFF);
3134 hsmartcard->pRxBuffPtr++;
3136 hsmartcard->RxXferCount--;
3137 if (hsmartcard->RxXferCount == 0U)
3139 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RXNEIE_RXFNEIE);
3141 /* Check if a transmit process is ongoing or not. If not disable ERR IT */
3142 if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY)
3144 /* Disable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
3145 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE);
3148 /* Disable the SMARTCARD Parity Error Interrupt */
3149 CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE);
3151 hsmartcard->RxState = HAL_SMARTCARD_STATE_READY;
3153 /* Clear RxISR function pointer */
3154 hsmartcard->RxISR = NULL;
3156 #if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1)
3157 /* Call registered Rx complete callback */
3158 hsmartcard->RxCpltCallback(hsmartcard);
3159 #else
3160 /* Call legacy weak Rx complete callback */
3161 HAL_SMARTCARD_RxCpltCallback(hsmartcard);
3162 #endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */
3166 /* When remaining number of bytes to receive is less than the RX FIFO
3167 threshold, next incoming frames are processed as if FIFO mode was
3168 disabled (i.e. one interrupt per received frame).
3170 rxdatacount = hsmartcard->RxXferCount;
3171 if (((rxdatacount != 0U)) && (rxdatacount < hsmartcard->NbRxDataToProcess))
3173 /* Disable the UART RXFT interrupt*/
3174 CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_RXFTIE);
3176 /* Update the RxISR function pointer */
3177 hsmartcard->RxISR = SMARTCARD_RxISR;
3179 /* Enable the UART Data Register Not Empty interrupt */
3180 SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RXNEIE_RXFNEIE);
3183 else
3185 /* Clear RXNE interrupt flag */
3186 __HAL_SMARTCARD_SEND_REQ(hsmartcard, SMARTCARD_RXDATA_FLUSH_REQUEST);
3191 * @}
3194 #endif /* HAL_SMARTCARD_MODULE_ENABLED */
3196 * @}
3200 * @}