2016-09-09 23:50:05 -07:00
/**
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* @ file stm32f7xx_hal_smartcard . c
* @ author MCD Application Team
2016-11-19 04:40:47 -08:00
* @ version V1 .1 .2
* @ date 23 - September - 2016
2016-09-09 23:50:05 -07:00
* @ brief SMARTCARD HAL module driver .
* This file provides firmware functions to manage the following
* functionalities of the SMARTCARD peripheral :
* + Initialization and de - initialization functions
* + IO operation functions
2016-11-19 04:40:47 -08:00
* + Peripheral Control functions
* + Peripheral State and Error functions
*
@ verbatim
2016-09-09 23:50:05 -07:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
# #### How to use this driver #####
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
2016-11-19 04:40:47 -08:00
The SMARTCARD HAL driver can be used as follows :
( # ) Declare a SMARTCARD_HandleTypeDef handle structure ( eg . SMARTCARD_HandleTypeDef hsmartcard ) .
( # ) Associate a USART to the SMARTCARD handle hsmartcard .
2016-09-09 23:50:05 -07:00
( # ) Initialize the SMARTCARD low level resources by implementing the HAL_SMARTCARD_MspInit ( ) API :
( # # ) Enable the USARTx interface clock .
( # # ) SMARTCARD pins configuration :
( + + + ) Enable the clock for the SMARTCARD GPIOs .
( + + + ) Configure these SMARTCARD pins as alternate function pull - up .
( # # ) NVIC configuration if you need to use interrupt process ( HAL_SMARTCARD_Transmit_IT ( )
and HAL_SMARTCARD_Receive_IT ( ) APIs ) :
( + + + ) Configure the USARTx interrupt priority .
( + + + ) Enable the NVIC USART IRQ handle .
( + + + ) The specific USART interrupts ( Transmission complete interrupt ,
RXNE interrupt and Error Interrupts ) will be managed using the macros
__HAL_SMARTCARD_ENABLE_IT ( ) and __HAL_SMARTCARD_DISABLE_IT ( ) inside the transmit and receive process .
( # # ) DMA Configuration if you need to use DMA process ( HAL_SMARTCARD_Transmit_DMA ( )
and HAL_SMARTCARD_Receive_DMA ( ) APIs ) :
( + + + ) Declare a DMA handle structure for the Tx / Rx stream .
( + + + ) Enable the DMAx interface clock .
( + + + ) Configure the declared DMA handle structure with the required Tx / Rx parameters .
( + + + ) Configure the DMA Tx / Rx Stream .
( + + + ) Associate the initialized DMA handle to the SMARTCARD DMA Tx / Rx handle .
( + + + ) Configure the priority and enable the NVIC for the transfer complete interrupt on the DMA Tx / Rx Stream .
( # ) Program the Baud Rate , Parity , Mode ( Receiver / Transmitter ) , clock enabling / disabling and accordingly ,
the clock parameters ( parity , phase , last bit ) , prescaler value , guard time and NACK on transmission
2016-11-19 04:40:47 -08:00
error enabling or disabling in the hsmartcard handle Init structure .
2016-09-09 23:50:05 -07:00
( # ) If required , program SMARTCARD advanced features ( TX / RX pins swap , TimeOut , auto - retry counter , . . . )
2016-11-19 04:40:47 -08:00
in the hsmartcard handle AdvancedInit structure .
( # ) Initialize the SMARTCARD registers by calling the HAL_SMARTCARD_Init ( ) API :
( + + ) This API configures also the low level Hardware GPIO , CLOCK , CORTEX . . . etc )
by calling the customized HAL_SMARTCARD_MspInit ( ) API .
[ . . ]
( @ ) The specific SMARTCARD interrupts ( Transmission complete interrupt ,
RXNE interrupt and Error Interrupts ) will be managed using the macros
__HAL_SMARTCARD_ENABLE_IT ( ) and __HAL_SMARTCARD_DISABLE_IT ( ) inside the transmit and receive process .
[ . . ]
[ . . ] Three operation modes are available within this driver :
* * * Polling mode IO operation * * *
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
( + ) Send an amount of data in blocking mode using HAL_SMARTCARD_Transmit ( )
( + ) Receive an amount of data in blocking mode using HAL_SMARTCARD_Receive ( )
* * * Interrupt mode IO operation * * *
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
( + ) Send an amount of data in non - blocking mode using HAL_SMARTCARD_Transmit_IT ( )
( + ) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback ( ) is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback ( )
( + ) Receive an amount of data in non - blocking mode using HAL_SMARTCARD_Receive_IT ( )
( + ) At reception end of transfer HAL_SMARTCARD_RxCpltCallback ( ) is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback ( )
( + ) In case of transfer Error , HAL_SMARTCARD_ErrorCallback ( ) function is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback ( )
* * * DMA mode IO operation * * *
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
( + ) Send an amount of data in non - blocking mode ( DMA ) using HAL_SMARTCARD_Transmit_DMA ( )
( + ) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback ( ) is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback ( )
( + ) Receive an amount of data in non - blocking mode ( DMA ) using HAL_SMARTCARD_Receive_DMA ( )
( + ) At reception end of transfer HAL_SMARTCARD_RxCpltCallback ( ) is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback ( )
( + ) In case of transfer Error , HAL_SMARTCARD_ErrorCallback ( ) function is executed and user can
add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback ( )
* * * SMARTCARD HAL driver macros list * * *
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
Below the list of most used macros in SMARTCARD HAL driver .
( + ) __HAL_SMARTCARD_GET_FLAG : Check whether or not the specified SMARTCARD flag is set
( + ) __HAL_SMARTCARD_CLEAR_FLAG : Clear the specified SMARTCARD pending flag
( + ) __HAL_SMARTCARD_ENABLE_IT : Enable the specified SMARTCARD interrupt
( + ) __HAL_SMARTCARD_DISABLE_IT : Disable the specified SMARTCARD interrupt
( + ) __HAL_SMARTCARD_GET_IT_SOURCE : Check whether or not the specified SMARTCARD interrupt is enabled
[ . . ]
( @ ) You can refer to the SMARTCARD HAL driver header file for more useful macros
2016-09-09 23:50:05 -07:00
@ endverbatim
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* @ attention
*
* < h2 > < center > & copy ; COPYRIGHT ( c ) 2016 STMicroelectronics < / center > < / h2 >
*
* Redistribution and use in source and binary forms , with or without modification ,
* are permitted provided that the following conditions are met :
* 1. Redistributions of source code must retain the above copyright notice ,
* this list of conditions and the following disclaimer .
* 2. Redistributions in binary form must reproduce the above copyright notice ,
* this list of conditions and the following disclaimer in the documentation
* and / or other materials provided with the distribution .
* 3. Neither the name of STMicroelectronics nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS "
* AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY ,
* OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*/
/* Includes ------------------------------------------------------------------*/
# include "stm32f7xx_hal.h"
/** @addtogroup STM32F7xx_HAL_Driver
* @ {
*/
/** @defgroup SMARTCARD SMARTCARD
2016-11-19 04:40:47 -08:00
* @ brief HAL SMARTCARD module driver
2016-09-09 23:50:05 -07:00
* @ {
*/
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
# ifdef HAL_SMARTCARD_MODULE_ENABLED
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* Private typedef -----------------------------------------------------------*/
/* Private define ------------------------------------------------------------*/
/** @defgroup SMARTCARD_Private_Constants SMARTCARD Private Constants
* @ {
*/
2016-11-19 04:40:47 -08:00
# define SMARTCARD_TEACK_REACK_TIMEOUT 1000U
2016-09-09 23:50:05 -07:00
# define HAL_SMARTCARD_TXDMA_TIMEOUTVALUE 22000U
# define USART_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | \
2016-11-19 04:40:47 -08:00
USART_CR1_TE | USART_CR1_RE | USART_CR1_OVER8 ) ) /*!< USART CR1 fields of parameters set by SMARTCARD_SetConfig API */
# define USART_CR2_CLK_FIELDS ((uint32_t)(USART_CR2_CLKEN|USART_CR2_CPOL|USART_CR2_CPHA|USART_CR2_LBCL)) /*!< SMARTCARD clock-related USART CR2 fields of parameters */
# define USART_CR2_FIELDS ((uint32_t)(USART_CR2_RTOEN|USART_CR2_CLK_FIELDS|USART_CR2_STOP)) /*!< USART CR2 fields of parameters set by SMARTCARD_SetConfig API */
# define USART_CR3_FIELDS ((uint32_t)(USART_CR3_ONEBIT|USART_CR3_NACK|USART_CR3_SCARCNT)) /*!< USART CR3 fields of parameters set by SMARTCARD_SetConfig API */
2016-09-09 23:50:05 -07:00
/**
* @ }
*/
2016-11-19 04:40:47 -08:00
/* Private macros ------------------------------------------------------------*/
2016-09-09 23:50:05 -07:00
/* Private variables ---------------------------------------------------------*/
/* Private function prototypes -----------------------------------------------*/
/** @addtogroup SMARTCARD_Private_Functions
* @ {
*/
2016-11-19 04:40:47 -08:00
static HAL_StatusTypeDef SMARTCARD_SetConfig ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static void SMARTCARD_AdvFeatureConfig ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static HAL_StatusTypeDef SMARTCARD_CheckIdleState ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout ( SMARTCARD_HandleTypeDef * hsmartcard , uint32_t Flag , FlagStatus Status , uint32_t Tickstart , uint32_t Timeout ) ;
static void SMARTCARD_EndTxTransfer ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static void SMARTCARD_EndRxTransfer ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
2016-09-09 23:50:05 -07:00
static void SMARTCARD_DMATransmitCplt ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMAReceiveCplt ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMAError ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMAAbortOnError ( DMA_HandleTypeDef * hdma ) ;
2016-11-19 04:40:47 -08:00
static void SMARTCARD_DMATxAbortCallback ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMARxAbortCallback ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMATxOnlyAbortCallback ( DMA_HandleTypeDef * hdma ) ;
static void SMARTCARD_DMARxOnlyAbortCallback ( DMA_HandleTypeDef * hdma ) ;
static HAL_StatusTypeDef SMARTCARD_Transmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static HAL_StatusTypeDef SMARTCARD_EndTransmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
static HAL_StatusTypeDef SMARTCARD_Receive_IT ( SMARTCARD_HandleTypeDef * hsmartcard ) ;
2016-09-09 23:50:05 -07:00
/**
* @ }
*/
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* Exported functions --------------------------------------------------------*/
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/** @defgroup SMARTCARD_Exported_Functions SMARTCARD Exported Functions
* @ {
*/
2016-11-19 04:40:47 -08:00
/** @defgroup SMARTCARD_Exported_Functions_Group1 Initialization and de-initialization functions
2016-09-09 23:50:05 -07:00
* @ brief Initialization and Configuration functions
*
@ verbatim
2016-11-19 04:40:47 -08:00
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
# #### Initialization and Configuration functions #####
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2016-09-09 23:50:05 -07:00
[ . . ]
2016-11-19 04:40:47 -08:00
This subsection provides a set of functions allowing to initialize the USARTx
2016-09-09 23:50:05 -07:00
associated to the SmartCard .
2016-11-19 04:40:47 -08:00
( + ) These parameters can be configured :
( + + ) Baud Rate
( + + ) Parity : parity should be enabled , frame Length is fixed to 8 bits plus parity
( + + ) Receiver / transmitter modes
( + + ) Synchronous mode ( and if enabled , phase , polarity and last bit parameters )
( + + ) Prescaler value
( + + ) Guard bit time
( + + ) NACK enabling or disabling on transmission error
( + ) The following advanced features can be configured as well :
( + + ) TX and / or RX pin level inversion
( + + ) data logical level inversion
( + + ) RX and TX pins swap
( + + ) RX overrun detection disabling
( + + ) DMA disabling on RX error
( + + ) MSB first on communication line
( + + ) Time out enabling ( and if activated , timeout value )
( + + ) Block length
( + + ) Auto - retry counter
[ . . ]
The HAL_SMARTCARD_Init ( ) API follows the USART synchronous configuration procedures
( details for the procedures are available in reference manual ) .
2016-09-09 23:50:05 -07:00
@ endverbatim
The USART frame format is given in the following table :
2016-11-19 04:40:47 -08:00
Table 1. USART frame format .
+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
| M1M0 bits | PCE bit | USART frame |
| - - - - - - - - - - - - - - - - - - - - - - - | - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - |
| 01 | 1 | | SB | 8 bit data | PB | STB | |
+ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - +
2016-09-09 23:50:05 -07:00
* @ {
*/
/**
2016-11-19 04:40:47 -08:00
* @ brief Initialize the SMARTCARD mode according to the specified
* parameters in the SMARTCARD_HandleTypeDef and initialize the associated handle .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Init ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
/* Check the SMARTCARD handle allocation */
2016-11-19 04:40:47 -08:00
if ( hsmartcard = = NULL )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
2016-11-19 04:40:47 -08:00
/* Check the USART associated to the SMARTCARD handle */
assert_param ( IS_SMARTCARD_INSTANCE ( hsmartcard - > Instance ) ) ;
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_RESET )
{
2016-09-09 23:50:05 -07:00
/* Allocate lock resource and initialize it */
2016-11-19 04:40:47 -08:00
hsmartcard - > Lock = HAL_UNLOCKED ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Init the low level hardware : GPIO, CLOCK */
HAL_SMARTCARD_MspInit ( hsmartcard ) ;
}
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > gState = HAL_SMARTCARD_STATE_BUSY ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable the Peripheral to set smartcard mode */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* In SmartCard mode, the following bits must be kept cleared:
2016-09-09 23:50:05 -07:00
- LINEN in the USART_CR2 register ,
- HDSEL and IREN bits in the USART_CR3 register . */
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR2 , USART_CR2_LINEN ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , ( USART_CR3_HDSEL | USART_CR3_IREN ) ) ;
2016-09-09 23:50:05 -07:00
/* set the USART in SMARTCARD mode */
2016-11-19 04:40:47 -08:00
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_SCEN ) ;
/* Set the SMARTCARD Communication parameters */
if ( SMARTCARD_SetConfig ( hsmartcard ) = = HAL_ERROR )
{
return HAL_ERROR ;
}
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Set the SMARTCARD transmission completion indication */
SMARTCARD_TRANSMISSION_COMPLETION_SETTING ( hsmartcard ) ;
if ( hsmartcard - > AdvancedInit . AdvFeatureInit ! = SMARTCARD_ADVFEATURE_NO_INIT )
{
SMARTCARD_AdvFeatureConfig ( hsmartcard ) ;
}
2016-09-09 23:50:05 -07:00
/* Enable the Peripheral */
2016-11-19 04:40:47 -08:00
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
/* TEACK and/or REACK to check before moving hsmartcard->gState and hsmartcard->RxState to Ready */
return ( SMARTCARD_CheckIdleState ( hsmartcard ) ) ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief DeInitialize the SMARTCARD peripheral .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_DeInit ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
/* Check the SMARTCARD handle allocation */
2016-11-19 04:40:47 -08:00
if ( hsmartcard = = NULL )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
2016-11-19 04:40:47 -08:00
/* Check the USART/UART associated to the SMARTCARD handle */
assert_param ( IS_SMARTCARD_INSTANCE ( hsmartcard - > Instance ) ) ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_BUSY ;
/* Disable the Peripheral */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
WRITE_REG ( hsmartcard - > Instance - > CR1 , 0x0 ) ;
WRITE_REG ( hsmartcard - > Instance - > CR2 , 0x0 ) ;
WRITE_REG ( hsmartcard - > Instance - > CR3 , 0x0 ) ;
WRITE_REG ( hsmartcard - > Instance - > RTOR , 0x0 ) ;
WRITE_REG ( hsmartcard - > Instance - > GTPR , 0x0 ) ;
2016-09-09 23:50:05 -07:00
/* DeInit the low level hardware */
2016-11-19 04:40:47 -08:00
HAL_SMARTCARD_MspDeInit ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_RESET ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_RESET ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Process Unlock */
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Initialize the SMARTCARD MSP .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
__weak void HAL_SMARTCARD_MspInit ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
/* Prevent unused argument(s) compilation warning */
2016-11-19 04:40:47 -08:00
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_MspInit can be implemented in the user file
2016-09-09 23:50:05 -07:00
*/
}
/**
2016-11-19 04:40:47 -08:00
* @ brief DeInitialize the SMARTCARD MSP .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
__weak void HAL_SMARTCARD_MspDeInit ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
/* Prevent unused argument(s) compilation warning */
2016-11-19 04:40:47 -08:00
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_MspDeInit can be implemented in the user file
2016-09-09 23:50:05 -07:00
*/
}
/**
* @ }
*/
2016-11-19 04:40:47 -08:00
/** @defgroup SMARTCARD_Exported_Functions_Group2 IO operation functions
* @ brief SMARTCARD Transmit and Receive functions
2016-09-09 23:50:05 -07:00
*
2016-11-19 04:40:47 -08:00
@ verbatim
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
# #### IO operation functions #####
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
2016-09-09 23:50:05 -07:00
This subsection provides a set of functions allowing to manage the SMARTCARD data transfers .
2016-11-19 04:40:47 -08:00
[ . . ]
Smartcard is a single wire half duplex communication protocol .
The Smartcard interface is designed to support asynchronous protocol Smartcards as
defined in the ISO 7816 - 3 standard . The USART should be configured as :
( + ) 8 bits plus parity : where M = 1 and PCE = 1 in the USART_CR1 register
( + ) 1.5 stop bits when transmitting and receiving : where STOP = 11 in the USART_CR2 register .
[ . . ]
( + ) There are two modes of transfer :
( + + ) Blocking mode : The communication is performed in polling mode .
The HAL status of all data processing is returned by the same function
after finishing transfer .
( + + ) Non - Blocking mode : The communication is performed using Interrupts
or DMA , the relevant API ' s return the HAL status .
The end of the data processing will be indicated through the
dedicated SMARTCARD IRQ when using Interrupt mode or the DMA IRQ when
using DMA mode .
( + + ) The HAL_SMARTCARD_TxCpltCallback ( ) , HAL_SMARTCARD_RxCpltCallback ( ) user callbacks
will be executed respectively at the end of the Transmit or Receive process
The HAL_SMARTCARD_ErrorCallback ( ) user callback will be executed when a communication
error is detected .
( + ) Blocking mode APIs are :
( + + ) HAL_SMARTCARD_Transmit ( )
( + + ) HAL_SMARTCARD_Receive ( )
( + ) Non Blocking mode APIs with Interrupt are :
( + + ) HAL_SMARTCARD_Transmit_IT ( )
( + + ) HAL_SMARTCARD_Receive_IT ( )
( + + ) HAL_SMARTCARD_IRQHandler ( )
( + ) Non Blocking mode functions with DMA are :
( + + ) HAL_SMARTCARD_Transmit_DMA ( )
( + + ) HAL_SMARTCARD_Receive_DMA ( )
( + ) A set of Transfer Complete Callbacks are provided in non Blocking mode :
( + + ) HAL_SMARTCARD_TxCpltCallback ( )
( + + ) HAL_SMARTCARD_RxCpltCallback ( )
( + + ) HAL_SMARTCARD_ErrorCallback ( )
( # ) Non - Blocking mode transfers could be aborted using Abort API ' s :
( + ) HAL_SMARTCARD_Abort ( )
( + ) HAL_SMARTCARD_AbortTransmit ( )
( + ) HAL_SMARTCARD_AbortReceive ( )
( + ) HAL_SMARTCARD_Abort_IT ( )
( + ) HAL_SMARTCARD_AbortTransmit_IT ( )
( + ) HAL_SMARTCARD_AbortReceive_IT ( )
( # ) For Abort services based on interrupts ( HAL_SMARTCARD_Abortxxx_IT ) , a set of Abort Complete Callbacks are provided :
( + ) HAL_SMARTCARD_AbortCpltCallback ( )
( + ) HAL_SMARTCARD_AbortTransmitCpltCallback ( )
( + ) HAL_SMARTCARD_AbortReceiveCpltCallback ( )
( # ) In Non - Blocking mode transfers , possible errors are split into 2 categories .
Errors are handled as follows :
( + ) Error is considered as Recoverable and non blocking : Transfer could go till end , but error severity is
to be evaluated by user : this concerns Frame Error , Parity Error or Noise Error in Interrupt mode reception .
Received character is then retrieved and stored in Rx buffer , Error code is set to allow user to identify error type ,
and HAL_SMARTCARD_ErrorCallback ( ) user callback is executed . Transfer is kept ongoing on SMARTCARD side .
If user wants to abort it , Abort services should be called by user .
( + ) Error is considered as Blocking : Transfer could not be completed properly and is aborted .
This concerns Frame Error in Interrupt mode tranmission , Overrun Error in Interrupt mode reception and all errors in DMA mode .
Error code is set to allow user to identify error type , and HAL_SMARTCARD_ErrorCallback ( ) user callback is executed .
2016-09-09 23:50:05 -07:00
@ endverbatim
* @ {
*/
/**
2016-11-19 04:40:47 -08:00
* @ brief Send an amount of data in blocking mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be sent .
* @ param Timeout Timeout duration .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Transmit ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size , uint32_t Timeout )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
uint32_t tickstart = 0 ;
/* Check that a Tx process is not already ongoing */
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_BUSY_TX ;
2016-09-09 23:50:05 -07:00
/* Init tickstart for timeout managment*/
tickstart = HAL_GetTick ( ) ;
2016-11-19 04:40:47 -08:00
/* Disable the Peripheral first to update mode for TX master */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
/* Disable Rx, enable Tx */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RE ) ;
SET_BIT ( hsmartcard - > Instance - > RQR , SMARTCARD_RXDATA_FLUSH_REQUEST ) ;
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_TE ) ;
/* Enable the Peripheral */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > TxXferSize = Size ;
hsmartcard - > TxXferCount = Size ;
while ( hsmartcard - > TxXferCount > 0 )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
hsmartcard - > TxXferCount - - ;
if ( SMARTCARD_WaitOnFlagUntilTimeout ( hsmartcard , SMARTCARD_FLAG_TXE , RESET , tickstart , Timeout ) ! = HAL_OK )
{
2016-09-09 23:50:05 -07:00
return HAL_TIMEOUT ;
}
2016-11-19 04:40:47 -08:00
hsmartcard - > Instance - > TDR = ( * pData + + & ( uint8_t ) 0xFF ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
if ( SMARTCARD_WaitOnFlagUntilTimeout ( hsmartcard , SMARTCARD_TRANSMISSION_COMPLETION_FLAG ( hsmartcard ) , RESET , tickstart , Timeout ) ! = HAL_OK )
{
2016-09-09 23:50:05 -07:00
return HAL_TIMEOUT ;
}
2016-11-19 04:40:47 -08:00
/* Re-enable Rx at end of transmission if initial mode is Rx/Tx */
if ( hsmartcard - > Init . Mode = = SMARTCARD_MODE_TX_RX )
{
/* Disable the Peripheral first to update modes */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RE ) ;
/* Enable the Peripheral */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
}
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* At end of Tx process, restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Receive an amount of data in blocking mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be received .
* @ param Timeout Timeout duration .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Receive ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size , uint32_t Timeout )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
uint32_t tickstart = 0 ;
/* Check that a Rx process is not already ongoing */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_BUSY_RX ;
2016-09-09 23:50:05 -07:00
/* Init tickstart for timeout managment*/
tickstart = HAL_GetTick ( ) ;
2016-11-19 04:40:47 -08:00
hsmartcard - > RxXferSize = Size ;
hsmartcard - > RxXferCount = Size ;
2016-09-09 23:50:05 -07:00
/* Check the remain data to be received */
2016-11-19 04:40:47 -08:00
while ( hsmartcard - > RxXferCount > 0 )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
hsmartcard - > RxXferCount - - ;
if ( SMARTCARD_WaitOnFlagUntilTimeout ( hsmartcard , SMARTCARD_FLAG_RXNE , RESET , tickstart , Timeout ) ! = HAL_OK )
2016-09-09 23:50:05 -07:00
{
return HAL_TIMEOUT ;
}
2016-11-19 04:40:47 -08:00
* pData + + = ( uint8_t ) ( hsmartcard - > Instance - > RDR & ( uint8_t ) 0x00FF ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
/* At end of Rx process, restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Send an amount of data in interrupt mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be sent .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Transmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size )
2016-09-09 23:50:05 -07:00
{
/* Check that a Tx process is not already ongoing */
2016-11-19 04:40:47 -08:00
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_BUSY_TX ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > pTxBuffPtr = pData ;
hsmartcard - > TxXferSize = Size ;
hsmartcard - > TxXferCount = Size ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable the Peripheral first to update mode for TX master */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
/* Disable Rx, enable Tx */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RE ) ;
SET_BIT ( hsmartcard - > Instance - > RQR , SMARTCARD_RXDATA_FLUSH_REQUEST ) ;
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_TE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the Peripheral */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the SMARTCARD Error Interrupt: (Frame error) */
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the SMARTCARD Transmit Data Register Empty Interrupt */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_TXEIE ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Receive an amount of data in interrupt mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be received .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Receive_IT ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Check that a Rx process is not already ongoing */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_BUSY_RX ;
hsmartcard - > pRxBuffPtr = pData ;
hsmartcard - > RxXferSize = Size ;
hsmartcard - > RxXferCount = Size ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the SMARTCARD Parity Error and Data Register not empty Interrupts */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_PEIE | USART_CR1_RXNEIE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Send an amount of data in DMA mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be sent .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Transmit_DMA ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size )
2016-09-09 23:50:05 -07:00
{
/* Check that a Tx process is not already ongoing */
2016-11-19 04:40:47 -08:00
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_BUSY_TX ;
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > pTxBuffPtr = pData ;
hsmartcard - > TxXferSize = Size ;
hsmartcard - > TxXferCount = Size ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable the Peripheral first to update mode for TX master */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable Rx, enable Tx */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RE ) ;
SET_BIT ( hsmartcard - > Instance - > RQR , SMARTCARD_RXDATA_FLUSH_REQUEST ) ;
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_TE ) ;
/* Enable the Peripheral */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
2016-09-09 23:50:05 -07:00
/* Set the SMARTCARD DMA transfer complete callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmatx - > XferCpltCallback = SMARTCARD_DMATransmitCplt ;
2016-09-09 23:50:05 -07:00
/* Set the SMARTCARD error callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmatx - > XferErrorCallback = SMARTCARD_DMAError ;
2016-09-09 23:50:05 -07:00
/* Set the DMA abort callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
/* Enable the SMARTCARD transmit DMA channel */
HAL_DMA_Start_IT ( hsmartcard - > hdmatx , ( uint32_t ) hsmartcard - > pTxBuffPtr , ( uint32_t ) & hsmartcard - > Instance - > TDR , Size ) ;
/* Clear the TC flag in the ICR register */
CLEAR_BIT ( hsmartcard - > Instance - > ICR , USART_ICR_TCCF ) ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
/* Enable the UART Error Interrupt: (Frame error) */
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
2016-09-09 23:50:05 -07:00
/* Enable the DMA transfer for transmit request by setting the DMAT bit
in the SMARTCARD associated USART CR3 register */
2016-11-19 04:40:47 -08:00
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Receive an amount of data in DMA mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param pData pointer to data buffer .
* @ param Size amount of data to be received .
* @ note The SMARTCARD - associated USART parity is enabled ( PCE = 1 ) ,
* the received data contain the parity bit ( MSB position ) .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
HAL_StatusTypeDef HAL_SMARTCARD_Receive_DMA ( SMARTCARD_HandleTypeDef * hsmartcard , uint8_t * pData , uint16_t Size )
2016-09-09 23:50:05 -07:00
{
/* Check that a Rx process is not already ongoing */
2016-11-19 04:40:47 -08:00
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
if ( ( pData = = NULL ) | | ( Size = = 0 ) )
2016-09-09 23:50:05 -07:00
{
return HAL_ERROR ;
}
/* Process Locked */
2016-11-19 04:40:47 -08:00
__HAL_LOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_BUSY_RX ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
hsmartcard - > pRxBuffPtr = pData ;
hsmartcard - > RxXferSize = Size ;
2016-09-09 23:50:05 -07:00
/* Set the SMARTCARD DMA transfer complete callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmarx - > XferCpltCallback = SMARTCARD_DMAReceiveCplt ;
2016-09-09 23:50:05 -07:00
/* Set the SMARTCARD DMA error callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmarx - > XferErrorCallback = SMARTCARD_DMAError ;
2016-09-09 23:50:05 -07:00
/* Set the DMA abort callback */
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
/* Enable the DMA channel */
HAL_DMA_Start_IT ( hsmartcard - > hdmarx , ( uint32_t ) & hsmartcard - > Instance - > RDR , ( uint32_t ) hsmartcard - > pRxBuffPtr , Size ) ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the UART Parity Error Interrupt */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_PEIE ) ;
/* Enable the UART Error Interrupt: (Frame error, noise error, overrun error) */
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Enable the DMA transfer for the receiver request by setting the DMAR bit
in the SMARTCARD associated USART CR3 register */
SET_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
2016-09-09 23:50:05 -07:00
return HAL_OK ;
}
else
{
return HAL_BUSY ;
}
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ brief Abort ongoing transfers ( blocking mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Tx and Rx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort ( in case of transfer in DMA mode )
* - Set handle State to READY
* @ note This procedure is executed in blocking mode : when exiting function , Abort is considered as completed .
* @ retval HAL status
*/
HAL_StatusTypeDef HAL_SMARTCARD_Abort ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE | USART_CR1_RTOIE | USART_CR1_EOBIE ) ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable the SMARTCARD DMA Tx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
/* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */
if ( hsmartcard - > hdmatx ! = NULL )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Set the SMARTCARD DMA Abort callback to Null.
No call back execution at end of DMA abort procedure */
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
HAL_DMA_Abort ( hsmartcard - > hdmatx ) ;
2016-09-09 23:50:05 -07:00
}
}
2016-11-19 04:40:47 -08:00
/* Disable the SMARTCARD DMA Rx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */
if ( hsmartcard - > hdmarx ! = NULL )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Set the SMARTCARD DMA Abort callback to Null.
No call back execution at end of DMA abort procedure */
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
HAL_DMA_Abort ( hsmartcard - > hdmarx ) ;
2016-09-09 23:50:05 -07:00
}
}
2016-11-19 04:40:47 -08:00
/* Reset Tx and Rx transfer counters */
hsmartcard - > TxXferCount = 0 ;
hsmartcard - > RxXferCount = 0 ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Reset Handle ErrorCode to No Error */
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
return HAL_OK ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Abort ongoing Transmit transfer ( blocking mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Tx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort ( in case of transfer in DMA mode )
* - Set handle State to READY
* @ note This procedure is executed in blocking mode : when exiting function , Abort is considered as completed .
* @ retval HAL status
*/
HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Disable TXEIE and TCIE interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_TXEIE | USART_CR1_TCIE ) ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Check if a receive process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Disable the SMARTCARD DMA Tx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */
if ( hsmartcard - > hdmatx ! = NULL )
{
/* Set the SMARTCARD DMA Abort callback to Null.
No call back execution at end of DMA abort procedure */
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
HAL_DMA_Abort ( hsmartcard - > hdmatx ) ;
}
}
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Reset Tx transfer counter */
hsmartcard - > TxXferCount = 0 ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_FEF ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
/* Restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
return HAL_OK ;
}
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ brief Abort ongoing Receive transfer ( blocking mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Rx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort ( in case of transfer in DMA mode )
* - Set handle State to READY
* @ note This procedure is executed in blocking mode : when exiting function , Abort is considered as completed .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
2016-11-19 04:40:47 -08:00
*/
HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Disable RTOIE, EOBIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE | USART_CR1_EOBIE ) ) ;
/* Check if a Transmit process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
/* Disable the SMARTCARD DMA Rx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
/* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */
if ( hsmartcard - > hdmarx ! = NULL )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Set the SMARTCARD DMA Abort callback to Null.
No call back execution at end of DMA abort procedure */
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
HAL_DMA_Abort ( hsmartcard - > hdmarx ) ;
2016-09-09 23:50:05 -07:00
}
}
2016-11-19 04:40:47 -08:00
/* Reset Rx transfer counter */
hsmartcard - > RxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
return HAL_OK ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief Abort ongoing transfers ( Interrupt mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Tx and Rx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort_IT ( in case of transfer in DMA mode )
* - Set handle State to READY
* - At abort completion , call user abort complete callback
* @ note This procedure is executed in Interrupt mode , meaning that abort procedure could be
* considered as completed only when user abort complete callback is executed ( not when exiting function ) .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
2016-11-19 04:40:47 -08:00
*/
HAL_StatusTypeDef HAL_SMARTCARD_Abort_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
uint32_t abortcplt = 1 ;
/* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE | USART_CR1_RTOIE | USART_CR1_EOBIE ) ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
/* If DMA Tx and/or DMA Rx Handles are associated to SMARTCARD Handle, DMA Abort complete callbacks should be initialised
before any call to DMA Abort functions */
/* DMA Tx Handle is valid */
if ( hsmartcard - > hdmatx ! = NULL )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Set DMA Abort Complete callback if SMARTCARD DMA Tx request if enabled.
Otherwise , set it to NULL */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
hsmartcard - > hdmatx - > XferAbortCallback = SMARTCARD_DMATxAbortCallback ;
}
else
{
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
2016-09-09 23:50:05 -07:00
}
}
2016-11-19 04:40:47 -08:00
/* DMA Rx Handle is valid */
if ( hsmartcard - > hdmarx ! = NULL )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Set DMA Abort Complete callback if SMARTCARD DMA Rx request if enabled.
Otherwise , set it to NULL */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
{
hsmartcard - > hdmarx - > XferAbortCallback = SMARTCARD_DMARxAbortCallback ;
}
else
{
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
}
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
/* Disable the SMARTCARD DMA Tx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
{
/* Disable DMA Tx at UART level */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
/* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */
if ( hsmartcard - > hdmatx ! = NULL )
{
/* SMARTCARD Tx DMA Abort callback has already been initialised :
will lead to call HAL_SMARTCARD_AbortCpltCallback ( ) at end of DMA abort procedure */
/* Abort DMA TX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmatx ) ! = HAL_OK )
{
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
}
else
{
abortcplt = 0 ;
}
}
}
/* Disable the SMARTCARD DMA Rx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
/* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */
if ( hsmartcard - > hdmarx ! = NULL )
{
/* SMARTCARD Rx DMA Abort callback has already been initialised :
will lead to call HAL_SMARTCARD_AbortCpltCallback ( ) at end of DMA abort procedure */
/* Abort DMA RX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmarx ) ! = HAL_OK )
{
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
abortcplt = 1 ;
}
else
{
abortcplt = 0 ;
}
}
}
/* if no DMA abort complete callback execution is required => call user Abort Complete callback */
if ( abortcplt = = 1 )
{
/* Reset Tx and Rx transfer counters */
hsmartcard - > TxXferCount = 0 ;
hsmartcard - > RxXferCount = 0 ;
/* Reset errorCode */
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* As no DMA to be aborted, call directly user Abort complete callback */
HAL_SMARTCARD_AbortCpltCallback ( hsmartcard ) ;
}
return HAL_OK ;
}
/**
* @ brief Abort ongoing Transmit transfer ( Interrupt mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Tx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort_IT ( in case of transfer in DMA mode )
* - Set handle State to READY
* - At abort completion , call user abort complete callback
* @ note This procedure is executed in Interrupt mode , meaning that abort procedure could be
* considered as completed only when user abort complete callback is executed ( not when exiting function ) .
* @ retval HAL status
*/
HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Disable TXEIE and TCIE interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_TXEIE | USART_CR1_TCIE ) ) ;
/* Check if a receive process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
/* Disable the SMARTCARD DMA Tx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
/* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */
if ( hsmartcard - > hdmatx ! = NULL )
{
/* Set the SMARTCARD DMA Abort callback :
will lead to call HAL_SMARTCARD_AbortCpltCallback ( ) at end of DMA abort procedure */
hsmartcard - > hdmatx - > XferAbortCallback = SMARTCARD_DMATxOnlyAbortCallback ;
/* Abort DMA TX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmatx ) ! = HAL_OK )
{
/* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */
hsmartcard - > hdmatx - > XferAbortCallback ( hsmartcard - > hdmatx ) ;
}
}
else
{
/* Reset Tx transfer counter */
hsmartcard - > TxXferCount = 0 ;
/* Restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
/* As no DMA to be aborted, call directly user Abort complete callback */
HAL_SMARTCARD_AbortTransmitCpltCallback ( hsmartcard ) ;
}
}
else
{
/* Reset Tx transfer counter */
hsmartcard - > TxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_FEF ) ;
/* Restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
/* As no DMA to be aborted, call directly user Abort complete callback */
HAL_SMARTCARD_AbortTransmitCpltCallback ( hsmartcard ) ;
}
return HAL_OK ;
}
/**
* @ brief Abort ongoing Receive transfer ( Interrupt mode ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode .
* This procedure performs following operations :
* - Disable SMARTCARD Interrupts ( Rx )
* - Disable the DMA transfer in the peripheral register ( if enabled )
* - Abort DMA transfer by calling HAL_DMA_Abort_IT ( in case of transfer in DMA mode )
* - Set handle State to READY
* - At abort completion , call user abort complete callback
* @ note This procedure is executed in Interrupt mode , meaning that abort procedure could be
* considered as completed only when user abort complete callback is executed ( not when exiting function ) .
* @ retval HAL status
*/
HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Disable RTOIE, EOBIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE | USART_CR1_EOBIE ) ) ;
/* Check if a Transmit process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
/* Disable the SMARTCARD DMA Rx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
/* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */
if ( hsmartcard - > hdmarx ! = NULL )
{
/* Set the SMARTCARD DMA Abort callback :
will lead to call HAL_SMARTCARD_AbortCpltCallback ( ) at end of DMA abort procedure */
hsmartcard - > hdmarx - > XferAbortCallback = SMARTCARD_DMARxOnlyAbortCallback ;
/* Abort DMA RX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmarx ) ! = HAL_OK )
{
/* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */
hsmartcard - > hdmarx - > XferAbortCallback ( hsmartcard - > hdmarx ) ;
}
}
else
{
/* Reset Rx transfer counter */
hsmartcard - > RxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* As no DMA to be aborted, call directly user Abort complete callback */
HAL_SMARTCARD_AbortReceiveCpltCallback ( hsmartcard ) ;
}
}
else
{
/* Reset Rx transfer counter */
hsmartcard - > RxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* As no DMA to be aborted, call directly user Abort complete callback */
HAL_SMARTCARD_AbortReceiveCpltCallback ( hsmartcard ) ;
}
return HAL_OK ;
}
/**
* @ brief Handle SMARTCARD interrupt requests .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
void HAL_SMARTCARD_IRQHandler ( SMARTCARD_HandleTypeDef * hsmartcard )
{
uint32_t isrflags = READ_REG ( hsmartcard - > Instance - > ISR ) ;
uint32_t cr1its = READ_REG ( hsmartcard - > Instance - > CR1 ) ;
uint32_t cr3its ;
uint32_t errorflags ;
/* If no error occurs */
errorflags = ( isrflags & ( uint32_t ) ( USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF ) ) ;
if ( errorflags = = RESET )
{
/* SMARTCARD in mode Receiver ---------------------------------------------------*/
if ( ( ( isrflags & USART_ISR_RXNE ) ! = RESET ) & & ( ( cr1its & USART_CR1_RXNEIE ) ! = RESET ) )
{
SMARTCARD_Receive_IT ( hsmartcard ) ;
/* Clear RXNE interrupt flag done by reading RDR in SMARTCARD_Receive_IT() */
return ;
}
}
/* If some errors occur */
cr3its = READ_REG ( hsmartcard - > Instance - > CR3 ) ;
if ( ( errorflags ! = RESET )
& & ( ( ( cr3its & USART_CR3_EIE ) ! = RESET )
| | ( ( cr1its & ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE ) ) ! = RESET ) ) )
{
/* SMARTCARD parity error interrupt occurred -------------------------------------*/
if ( ( ( isrflags & USART_ISR_PE ) ! = RESET ) & & ( ( cr1its & USART_CR1_PEIE ) ! = RESET ) )
{
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_PEF ) ;
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_PE ;
}
/* SMARTCARD frame error interrupt occurred --------------------------------------*/
if ( ( ( isrflags & USART_ISR_FE ) ! = RESET ) & & ( ( cr3its & USART_CR3_EIE ) ! = RESET ) )
{
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_FEF ) ;
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_FE ;
}
/* SMARTCARD noise error interrupt occurred --------------------------------------*/
if ( ( ( isrflags & USART_ISR_NE ) ! = RESET ) & & ( ( cr3its & USART_CR3_EIE ) ! = RESET ) )
{
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_NEF ) ;
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_NE ;
}
/* SMARTCARD Over-Run interrupt occurred -----------------------------------------*/
if ( ( ( isrflags & USART_ISR_ORE ) ! = RESET ) & &
( ( ( cr1its & USART_CR1_RXNEIE ) ! = RESET ) | | ( ( cr3its & USART_CR3_EIE ) ! = RESET ) ) )
{
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_OREF ) ;
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_ORE ;
}
/* SMARTCARD receiver timeout interrupt occurred -----------------------------------------*/
if ( ( ( isrflags & USART_ISR_RTOF ) ! = RESET ) & & ( ( cr1its & USART_CR1_RTOIE ) ! = RESET ) )
{
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_RTOF ) ;
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_RTO ;
}
/* Call SMARTCARD Error Call back function if need be --------------------------*/
if ( hsmartcard - > ErrorCode ! = HAL_SMARTCARD_ERROR_NONE )
{
/* SMARTCARD in mode Receiver ---------------------------------------------------*/
if ( ( ( isrflags & USART_ISR_RXNE ) ! = RESET ) & & ( ( cr1its & USART_CR1_RXNEIE ) ! = RESET ) )
{
SMARTCARD_Receive_IT ( hsmartcard ) ;
}
/* If Error is to be considered as blocking :
- Receiver Timeout error in Reception
- Overrun error in Reception
- any error occurs in DMA mode reception
*/
if ( ( ( hsmartcard - > ErrorCode & ( HAL_SMARTCARD_ERROR_RTO | HAL_SMARTCARD_ERROR_ORE ) ) ! = RESET )
| | ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ) )
{
/* Blocking error : transfer is aborted
Set the SMARTCARD state ready to be able to start again the process ,
Disable Rx Interrupts , and disable Rx DMA request , if ongoing */
SMARTCARD_EndRxTransfer ( hsmartcard ) ;
/* Disable the SMARTCARD DMA Rx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
/* Abort the SMARTCARD DMA Rx channel */
if ( hsmartcard - > hdmarx ! = NULL )
{
/* Set the SMARTCARD DMA Abort callback :
will lead to call HAL_SMARTCARD_ErrorCallback ( ) at end of DMA abort procedure */
hsmartcard - > hdmarx - > XferAbortCallback = SMARTCARD_DMAAbortOnError ;
/* Abort DMA RX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmarx ) ! = HAL_OK )
{
/* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */
hsmartcard - > hdmarx - > XferAbortCallback ( hsmartcard - > hdmarx ) ;
}
}
else
{
/* Call user error callback */
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
}
}
else
{
/* Call user error callback */
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
}
}
/* other error type to be considered as blocking :
- Frame error in Transmission
*/
else if ( ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_BUSY_TX ) & & ( ( hsmartcard - > ErrorCode & HAL_SMARTCARD_ERROR_FE ) ! = RESET ) )
{
/* Blocking error : transfer is aborted
Set the SMARTCARD state ready to be able to start again the process ,
Disable Tx Interrupts , and disable Tx DMA request , if ongoing */
SMARTCARD_EndTxTransfer ( hsmartcard ) ;
/* Disable the SMARTCARD DMA Tx request if enabled */
if ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
/* Abort the SMARTCARD DMA Tx channel */
if ( hsmartcard - > hdmatx ! = NULL )
{
/* Set the SMARTCARD DMA Abort callback :
will lead to call HAL_SMARTCARD_ErrorCallback ( ) at end of DMA abort procedure */
hsmartcard - > hdmatx - > XferAbortCallback = SMARTCARD_DMAAbortOnError ;
/* Abort DMA TX */
if ( HAL_DMA_Abort_IT ( hsmartcard - > hdmatx ) ! = HAL_OK )
{
/* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */
hsmartcard - > hdmatx - > XferAbortCallback ( hsmartcard - > hdmatx ) ;
}
}
else
{
/* Call user error callback */
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
}
}
else
{
/* Call user error callback */
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
}
}
else
{
/* Non Blocking error : transfer could go on.
Error is notified to user through user error callback */
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
}
}
return ;
} /* End if some error occurs */
/* SMARTCARD in mode Receiver, end of block interruption ------------------------*/
if ( ( ( isrflags & USART_ISR_EOBF ) ! = RESET ) & & ( ( cr1its & USART_CR1_EOBIE ) ! = RESET ) )
{
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
__HAL_UNLOCK ( hsmartcard ) ;
HAL_SMARTCARD_RxCpltCallback ( hsmartcard ) ;
/* Clear EOBF interrupt after HAL_SMARTCARD_RxCpltCallback() call for the End of Block information
* to be available during HAL_SMARTCARD_RxCpltCallback ( ) processing */
__HAL_SMARTCARD_CLEAR_IT ( hsmartcard , SMARTCARD_CLEAR_EOBF ) ;
return ;
}
/* SMARTCARD in mode Transmitter ------------------------------------------------*/
if ( ( ( isrflags & USART_ISR_TXE ) ! = RESET ) & & ( ( cr1its & USART_CR1_TXEIE ) ! = RESET ) )
{
SMARTCARD_Transmit_IT ( hsmartcard ) ;
return ;
}
/* SMARTCARD in mode Transmitter (transmission end) ------------------------*/
if ( ( __HAL_SMARTCARD_GET_IT ( hsmartcard , hsmartcard - > AdvancedInit . TxCompletionIndication ) ! = RESET ) & & ( __HAL_SMARTCARD_GET_IT_SOURCE ( hsmartcard , hsmartcard - > AdvancedInit . TxCompletionIndication ) ! = RESET ) )
{
SMARTCARD_EndTransmit_IT ( hsmartcard ) ;
return ;
}
}
/**
* @ brief Tx Transfer completed callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_TxCpltCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_TxCpltCallback can be implemented in the user file .
*/
}
/**
* @ brief Rx Transfer completed callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_RxCpltCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_RxCpltCallback can be implemented in the user file .
*/
}
/**
* @ brief SMARTCARD error callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_ErrorCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_ErrorCallback can be implemented in the user file .
*/
}
/**
* @ brief SMARTCARD Abort Complete callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_AbortCpltCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_AbortCpltCallback can be implemented in the user file .
*/
}
/**
* @ brief SMARTCARD Abort Complete callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_AbortTransmitCpltCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_AbortTransmitCpltCallback can be implemented in the user file .
*/
}
/**
* @ brief SMARTCARD Abort Receive Complete callback .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval None
*/
__weak void HAL_SMARTCARD_AbortReceiveCpltCallback ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Prevent unused argument(s) compilation warning */
UNUSED ( hsmartcard ) ;
/* NOTE : This function should not be modified, when the callback is needed,
the HAL_SMARTCARD_AbortReceiveCpltCallback can be implemented in the user file .
*/
}
/**
* @ }
*/
/** @defgroup SMARTCARD_Exported_Functions_Group4 Peripheral State and Errors functions
* @ brief SMARTCARD State and Errors functions
*
@ verbatim
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
# #### Peripheral State and Errors functions #####
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
[ . . ]
This subsection provides a set of functions allowing to return the State of SmartCard
handle and also return Peripheral Errors occurred during communication process
( + ) HAL_SMARTCARD_GetState ( ) API can be helpful to check in run - time the state
of the SMARTCARD peripheral .
( + ) HAL_SMARTCARD_GetError ( ) checks in run - time errors that could occur during
communication .
@ endverbatim
* @ {
*/
/**
* @ brief Return the SMARTCARD handle state .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval SMARTCARD handle state
*/
HAL_SMARTCARD_StateTypeDef HAL_SMARTCARD_GetState ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Return SMARTCARD handle state */
uint32_t temp1 = 0x00 , temp2 = 0x00 ;
temp1 = hsmartcard - > gState ;
temp2 = hsmartcard - > RxState ;
return ( HAL_SMARTCARD_StateTypeDef ) ( temp1 | temp2 ) ;
}
/**
* @ brief Return the SMARTCARD handle error code .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval SMARTCARD handle Error Code
*/
uint32_t HAL_SMARTCARD_GetError ( SMARTCARD_HandleTypeDef * hsmartcard )
{
return hsmartcard - > ErrorCode ;
}
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ }
*/
/**
* @ }
*/
/** @defgroup SMARTCARD_Private_Functions SMARTCARD Private Functions
* @ {
*/
/**
* @ brief Configure the SMARTCARD associated USART peripheral .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static HAL_StatusTypeDef SMARTCARD_SetConfig ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
uint32_t tmpreg = 0x00000000 ;
SMARTCARD_ClockSourceTypeDef clocksource = SMARTCARD_CLOCKSOURCE_UNDEFINED ;
HAL_StatusTypeDef ret = HAL_OK ;
/* Check the parameters */
assert_param ( IS_SMARTCARD_INSTANCE ( hsmartcard - > Instance ) ) ;
assert_param ( IS_SMARTCARD_BAUDRATE ( hsmartcard - > Init . BaudRate ) ) ;
assert_param ( IS_SMARTCARD_WORD_LENGTH ( hsmartcard - > Init . WordLength ) ) ;
assert_param ( IS_SMARTCARD_STOPBITS ( hsmartcard - > Init . StopBits ) ) ;
assert_param ( IS_SMARTCARD_PARITY ( hsmartcard - > Init . Parity ) ) ;
assert_param ( IS_SMARTCARD_MODE ( hsmartcard - > Init . Mode ) ) ;
assert_param ( IS_SMARTCARD_POLARITY ( hsmartcard - > Init . CLKPolarity ) ) ;
assert_param ( IS_SMARTCARD_PHASE ( hsmartcard - > Init . CLKPhase ) ) ;
assert_param ( IS_SMARTCARD_LASTBIT ( hsmartcard - > Init . CLKLastBit ) ) ;
assert_param ( IS_SMARTCARD_ONE_BIT_SAMPLE ( hsmartcard - > Init . OneBitSampling ) ) ;
assert_param ( IS_SMARTCARD_NACK ( hsmartcard - > Init . NACKEnable ) ) ;
assert_param ( IS_SMARTCARD_TIMEOUT ( hsmartcard - > Init . TimeOutEnable ) ) ;
assert_param ( IS_SMARTCARD_AUTORETRY_COUNT ( hsmartcard - > Init . AutoRetryCount ) ) ;
2016-09-09 23:50:05 -07:00
/*-------------------------- USART CR1 Configuration -----------------------*/
/* In SmartCard mode, M and PCE are forced to 1 (8 bits + parity).
* Oversampling is forced to 16 ( OVER8 = 0 ) .
2016-11-19 04:40:47 -08:00
* Configure the Parity and Mode :
* set PS bit according to hsmartcard - > Init . Parity value
* set TE and RE bits according to hsmartcard - > Init . Mode value */
tmpreg = ( uint32_t ) hsmartcard - > Init . Parity | hsmartcard - > Init . Mode ;
tmpreg | = ( uint32_t ) hsmartcard - > Init . WordLength ;
MODIFY_REG ( hsmartcard - > Instance - > CR1 , USART_CR1_FIELDS , tmpreg ) ;
2016-09-09 23:50:05 -07:00
/*-------------------------- USART CR2 Configuration -----------------------*/
2016-11-19 04:40:47 -08:00
tmpreg = hsmartcard - > Init . StopBits ;
2016-09-09 23:50:05 -07:00
/* Synchronous mode is activated by default */
2016-11-19 04:40:47 -08:00
tmpreg | = ( uint32_t ) USART_CR2_CLKEN | hsmartcard - > Init . CLKPolarity ;
tmpreg | = ( uint32_t ) hsmartcard - > Init . CLKPhase | hsmartcard - > Init . CLKLastBit ;
tmpreg | = ( uint32_t ) hsmartcard - > Init . TimeOutEnable ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_FIELDS , tmpreg ) ;
2016-09-09 23:50:05 -07:00
/*-------------------------- USART CR3 Configuration -----------------------*/
2016-11-19 04:40:47 -08:00
/* Configure
* - one - bit sampling method versus three samples ' majority rule
* according to hsmartcard - > Init . OneBitSampling
* - NACK transmission in case of parity error according
* to hsmartcard - > Init . NACKEnable
* - autoretry counter according to hsmartcard - > Init . AutoRetryCount */
tmpreg = ( uint32_t ) hsmartcard - > Init . OneBitSampling | hsmartcard - > Init . NACKEnable ;
tmpreg | = ( ( uint32_t ) hsmartcard - > Init . AutoRetryCount < < SMARTCARD_CR3_SCARCNT_LSB_POS ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR3 , USART_CR3_FIELDS , tmpreg ) ;
2016-09-09 23:50:05 -07:00
/*-------------------------- USART GTPR Configuration ----------------------*/
2016-11-19 04:40:47 -08:00
tmpreg = ( hsmartcard - > Init . Prescaler | ( ( uint32_t ) hsmartcard - > Init . GuardTime < < SMARTCARD_GTPR_GT_LSB_POS ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > GTPR , ( USART_GTPR_GT | USART_GTPR_PSC ) , tmpreg ) ;
/*-------------------------- USART RTOR Configuration ----------------------*/
tmpreg = ( ( uint32_t ) hsmartcard - > Init . BlockLength < < SMARTCARD_RTOR_BLEN_LSB_POS ) ;
if ( hsmartcard - > Init . TimeOutEnable = = SMARTCARD_TIMEOUT_ENABLE )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_TIMEOUT_VALUE ( hsmartcard - > Init . TimeOutValue ) ) ;
tmpreg | = ( uint32_t ) hsmartcard - > Init . TimeOutValue ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
MODIFY_REG ( hsmartcard - > Instance - > RTOR , ( USART_RTOR_RTO | USART_RTOR_BLEN ) , tmpreg ) ;
2016-09-09 23:50:05 -07:00
/*-------------------------- USART BRR Configuration -----------------------*/
2016-11-19 04:40:47 -08:00
SMARTCARD_GETCLOCKSOURCE ( hsmartcard , clocksource ) ;
2016-09-09 23:50:05 -07:00
switch ( clocksource )
{
2016-11-19 04:40:47 -08:00
case SMARTCARD_CLOCKSOURCE_PCLK1 :
hsmartcard - > Instance - > BRR = ( uint16_t ) ( ( HAL_RCC_GetPCLK1Freq ( ) + ( hsmartcard - > Init . BaudRate / 2 ) ) / hsmartcard - > Init . BaudRate ) ;
break ;
case SMARTCARD_CLOCKSOURCE_PCLK2 :
hsmartcard - > Instance - > BRR = ( uint16_t ) ( ( HAL_RCC_GetPCLK2Freq ( ) + ( hsmartcard - > Init . BaudRate / 2 ) ) / hsmartcard - > Init . BaudRate ) ;
break ;
case SMARTCARD_CLOCKSOURCE_HSI :
hsmartcard - > Instance - > BRR = ( uint16_t ) ( ( HSI_VALUE + ( hsmartcard - > Init . BaudRate / 2 ) ) / hsmartcard - > Init . BaudRate ) ;
break ;
case SMARTCARD_CLOCKSOURCE_SYSCLK :
hsmartcard - > Instance - > BRR = ( uint16_t ) ( ( HAL_RCC_GetSysClockFreq ( ) + ( hsmartcard - > Init . BaudRate / 2 ) ) / hsmartcard - > Init . BaudRate ) ;
break ;
case SMARTCARD_CLOCKSOURCE_LSE :
hsmartcard - > Instance - > BRR = ( uint16_t ) ( ( LSE_VALUE + ( hsmartcard - > Init . BaudRate / 2 ) ) / hsmartcard - > Init . BaudRate ) ;
break ;
case SMARTCARD_CLOCKSOURCE_UNDEFINED :
default :
ret = HAL_ERROR ;
break ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
return ret ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ brief Configure the SMARTCARD associated USART peripheral advanced features .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static void SMARTCARD_AdvFeatureConfig ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Check whether the set of advanced features to configure is properly set */
assert_param ( IS_SMARTCARD_ADVFEATURE_INIT ( hsmartcard - > AdvancedInit . AdvFeatureInit ) ) ;
2016-09-09 23:50:05 -07:00
/* if required, configure TX pin active level inversion */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_TXINVERT_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_TXINV ( hsmartcard - > AdvancedInit . TxPinLevelInvert ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_TXINV , hsmartcard - > AdvancedInit . TxPinLevelInvert ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* if required, configure RX pin active level inversion */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_RXINVERT_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_RXINV ( hsmartcard - > AdvancedInit . RxPinLevelInvert ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_RXINV , hsmartcard - > AdvancedInit . RxPinLevelInvert ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* if required, configure data inversion */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_DATAINVERT_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_DATAINV ( hsmartcard - > AdvancedInit . DataInvert ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_DATAINV , hsmartcard - > AdvancedInit . DataInvert ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* if required, configure RX/TX pins swap */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_SWAP_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_SWAP ( hsmartcard - > AdvancedInit . Swap ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_SWAP , hsmartcard - > AdvancedInit . Swap ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* if required, configure RX overrun detection disabling */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_RXOVERRUNDISABLE_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_OVERRUN ( hsmartcard - > AdvancedInit . OverrunDisable ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR3 , USART_CR3_OVRDIS , hsmartcard - > AdvancedInit . OverrunDisable ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* if required, configure DMA disabling on reception error */
2016-11-19 04:40:47 -08:00
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_DMADISABLEONERROR_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_DMAONRXERROR ( hsmartcard - > AdvancedInit . DMADisableonRxError ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR3 , USART_CR3_DDRE , hsmartcard - > AdvancedInit . DMADisableonRxError ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
/* if required, configure MSB first on communication line */
if ( HAL_IS_BIT_SET ( hsmartcard - > AdvancedInit . AdvFeatureInit , SMARTCARD_ADVFEATURE_MSBFIRST_INIT ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
assert_param ( IS_SMARTCARD_ADVFEATURE_MSBFIRST ( hsmartcard - > AdvancedInit . MSBFirst ) ) ;
MODIFY_REG ( hsmartcard - > Instance - > CR2 , USART_CR2_MSBFIRST , hsmartcard - > AdvancedInit . MSBFirst ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
/**
* @ brief Check the SMARTCARD Idle State .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval HAL status
*/
static HAL_StatusTypeDef SMARTCARD_CheckIdleState ( SMARTCARD_HandleTypeDef * hsmartcard )
{
uint32_t tickstart = 0 ;
/* Initialize the SMARTCARD ErrorCode */
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
/* Init tickstart for timeout managment*/
tickstart = HAL_GetTick ( ) ;
/* Check if the Transmitter is enabled */
if ( ( hsmartcard - > Instance - > CR1 & USART_CR1_TE ) = = USART_CR1_TE )
{
/* Wait until TEACK flag is set */
if ( SMARTCARD_WaitOnFlagUntilTimeout ( hsmartcard , USART_ISR_TEACK , RESET , tickstart , SMARTCARD_TEACK_REACK_TIMEOUT ) ! = HAL_OK )
{
/* Timeout occurred */
return HAL_TIMEOUT ;
}
}
/* Check if the Receiver is enabled */
if ( ( hsmartcard - > Instance - > CR1 & USART_CR1_RE ) = = USART_CR1_RE )
{
/* Wait until REACK flag is set */
if ( SMARTCARD_WaitOnFlagUntilTimeout ( hsmartcard , USART_ISR_REACK , RESET , tickstart , SMARTCARD_TEACK_REACK_TIMEOUT ) ! = HAL_OK )
{
/* Timeout occurred */
return HAL_TIMEOUT ;
}
}
/* Initialize the SMARTCARD states */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* Process Unlocked */
__HAL_UNLOCK ( hsmartcard ) ;
return HAL_OK ;
}
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ brief Handle SMARTCARD Communication Timeout .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ param Flag Specifies the SMARTCARD flag to check .
2016-09-09 23:50:05 -07:00
* @ param Status The new Flag status ( SET or RESET ) .
* @ param Tickstart Tick start value
2016-11-19 04:40:47 -08:00
* @ param Timeout Timeout duration .
2016-09-09 23:50:05 -07:00
* @ retval HAL status
*/
2016-11-19 04:40:47 -08:00
static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout ( SMARTCARD_HandleTypeDef * hsmartcard , uint32_t Flag , FlagStatus Status , uint32_t Tickstart , uint32_t Timeout )
2016-09-09 23:50:05 -07:00
{
/* Wait until flag is set */
2016-11-19 04:40:47 -08:00
while ( ( __HAL_SMARTCARD_GET_FLAG ( hsmartcard , Flag ) ? SET : RESET ) = = Status )
2016-09-09 23:50:05 -07:00
{
/* Check for the Timeout */
if ( Timeout ! = HAL_MAX_DELAY )
{
2016-11-19 04:40:47 -08:00
if ( ( Timeout = = 0 ) | | ( ( HAL_GetTick ( ) - Tickstart ) > Timeout ) )
2016-09-09 23:50:05 -07:00
{
/* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts for the interrupt process */
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE ) ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
/* Process Unlocked */
2016-11-19 04:40:47 -08:00
__HAL_UNLOCK ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
return HAL_TIMEOUT ;
}
}
}
return HAL_OK ;
}
2016-11-19 04:40:47 -08:00
/**
2016-09-09 23:50:05 -07:00
* @ brief End ongoing Tx transfer on SMARTCARD peripheral ( following error detection or Transmit completion ) .
2016-11-19 04:40:47 -08:00
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static void SMARTCARD_EndTxTransfer ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
/* Disable TXEIE, TCIE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_TXEIE | USART_CR1_TCIE ) ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
/* At end of Tx process, restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief End ongoing Rx transfer on UART peripheral ( following error detection or Reception completion ) .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static void SMARTCARD_EndRxTransfer ( SMARTCARD_HandleTypeDef * hsmartcard )
2016-09-09 23:50:05 -07:00
{
/* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , ( USART_CR1_RXNEIE | USART_CR1_PEIE ) ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
/* At end of Rx process, restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/**
2016-11-19 04:40:47 -08:00
* @ brief DMA SMARTCARD transmit process complete callback .
* @ param hdma Pointer to a DMA_HandleTypeDef structure that contains
* the configuration information for the specified DMA module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static void SMARTCARD_DMATransmitCplt ( DMA_HandleTypeDef * hdma )
{
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > TxXferCount = 0 ;
/* Disable the DMA transfer for transmit request by resetting the DMAT bit
in the SMARTCARD associated USART CR3 register */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ;
/* Enable the SMARTCARD Transmit Complete Interrupt */
__HAL_SMARTCARD_ENABLE_IT ( hsmartcard , hsmartcard - > AdvancedInit . TxCompletionIndication ) ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief DMA SMARTCARD receive process complete callback .
* @ param hdma Pointer to a DMA_HandleTypeDef structure that contains
* the configuration information for the specified DMA module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
2016-11-19 04:40:47 -08:00
static void SMARTCARD_DMAReceiveCplt ( DMA_HandleTypeDef * hdma )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > RxXferCount = 0 ;
/* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_PEIE ) ;
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
/* Disable the DMA transfer for the receiver request by resetting the DMAR bit
2016-09-09 23:50:05 -07:00
in the SMARTCARD associated USART CR3 register */
2016-11-19 04:40:47 -08:00
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ;
/* At end of Rx process, restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
HAL_SMARTCARD_RxCpltCallback ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief DMA SMARTCARD communication error callback .
* @ param hdma Pointer to a DMA_HandleTypeDef structure that contains
* the configuration information for the specified DMA module .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
static void SMARTCARD_DMAError ( DMA_HandleTypeDef * hdma )
{
2016-11-19 04:40:47 -08:00
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
2016-09-09 23:50:05 -07:00
/* Stop SMARTCARD DMA Tx request if ongoing */
2016-11-19 04:40:47 -08:00
if ( ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_BUSY_TX )
& & ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAT ) ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
hsmartcard - > TxXferCount = 0 ;
SMARTCARD_EndTxTransfer ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
2016-09-09 23:50:05 -07:00
/* Stop SMARTCARD DMA Rx request if ongoing */
2016-11-19 04:40:47 -08:00
if ( ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_BUSY_RX )
& & ( HAL_IS_BIT_SET ( hsmartcard - > Instance - > CR3 , USART_CR3_DMAR ) ) )
2016-09-09 23:50:05 -07:00
{
2016-11-19 04:40:47 -08:00
hsmartcard - > RxXferCount = 0 ;
SMARTCARD_EndRxTransfer ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
}
2016-11-19 04:40:47 -08:00
hsmartcard - > ErrorCode | = HAL_SMARTCARD_ERROR_DMA ;
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
2016-09-09 23:50:05 -07:00
}
/**
2016-11-19 04:40:47 -08:00
* @ brief DMA SMARTCARD communication abort callback , when initiated by HAL services on Error
* ( To be called at end of DMA Abort procedure following error occurrence ) .
* @ param hdma DMA handle .
2016-09-09 23:50:05 -07:00
* @ retval None
*/
static void SMARTCARD_DMAAbortOnError ( DMA_HandleTypeDef * hdma )
{
2016-11-19 04:40:47 -08:00
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > RxXferCount = 0 ;
hsmartcard - > TxXferCount = 0 ;
HAL_SMARTCARD_ErrorCallback ( hsmartcard ) ;
}
/**
* @ brief DMA SMARTCARD Tx communication abort callback , when initiated by user
* ( To be called at end of DMA Tx Abort procedure following user abort request ) .
* @ note When this callback is executed , User Abort complete call back is called only if no
* Abort still ongoing for Rx DMA Handle .
* @ param hdma DMA handle .
* @ retval None
*/
static void SMARTCARD_DMATxAbortCallback ( DMA_HandleTypeDef * hdma )
{
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > hdmatx - > XferAbortCallback = NULL ;
/* Check if an Abort process is still ongoing */
if ( hsmartcard - > hdmarx ! = NULL )
{
if ( hsmartcard - > hdmarx - > XferAbortCallback ! = NULL )
{
return ;
}
}
/* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */
hsmartcard - > TxXferCount = 0 ;
hsmartcard - > RxXferCount = 0 ;
/* Reset errorCode */
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* Call user Abort complete callback */
HAL_SMARTCARD_AbortCpltCallback ( hsmartcard ) ;
}
/**
* @ brief DMA SMARTCARD Rx communication abort callback , when initiated by user
* ( To be called at end of DMA Rx Abort procedure following user abort request ) .
* @ note When this callback is executed , User Abort complete call back is called only if no
* Abort still ongoing for Tx DMA Handle .
* @ param hdma DMA handle .
* @ retval None
*/
static void SMARTCARD_DMARxAbortCallback ( DMA_HandleTypeDef * hdma )
{
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > hdmarx - > XferAbortCallback = NULL ;
/* Check if an Abort process is still ongoing */
if ( hsmartcard - > hdmatx ! = NULL )
{
if ( hsmartcard - > hdmatx - > XferAbortCallback ! = NULL )
{
return ;
}
}
/* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */
hsmartcard - > TxXferCount = 0 ;
hsmartcard - > RxXferCount = 0 ;
/* Reset errorCode */
hsmartcard - > ErrorCode = HAL_SMARTCARD_ERROR_NONE ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->gState and hsmartcard->RxState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* Call user Abort complete callback */
HAL_SMARTCARD_AbortCpltCallback ( hsmartcard ) ;
}
/**
* @ brief DMA SMARTCARD Tx communication abort callback , when initiated by user by a call to
* HAL_SMARTCARD_AbortTransmit_IT API ( Abort only Tx transfer )
* ( This callback is executed at end of DMA Tx Abort procedure following user abort request ,
* and leads to user Tx Abort Complete callback execution ) .
* @ param hdma DMA handle .
* @ retval None
*/
static void SMARTCARD_DMATxOnlyAbortCallback ( DMA_HandleTypeDef * hdma )
{
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > TxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_FEF ) ;
/* Restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
/* Call user Abort complete callback */
HAL_SMARTCARD_AbortTransmitCpltCallback ( hsmartcard ) ;
}
/**
* @ brief DMA SMARTCARD Rx communication abort callback , when initiated by user by a call to
* HAL_SMARTCARD_AbortReceive_IT API ( Abort only Rx transfer )
* ( This callback is executed at end of DMA Rx Abort procedure following user abort request ,
* and leads to user Rx Abort Complete callback execution ) .
* @ param hdma DMA handle .
* @ retval None
*/
static void SMARTCARD_DMARxOnlyAbortCallback ( DMA_HandleTypeDef * hdma )
{
SMARTCARD_HandleTypeDef * hsmartcard = ( SMARTCARD_HandleTypeDef * ) ( hdma - > Parent ) ;
hsmartcard - > RxXferCount = 0 ;
/* Clear the Error flags in the ICR register */
__HAL_SMARTCARD_CLEAR_FLAG ( hsmartcard , SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF ) ;
/* Restore hsmartcard->RxState to Ready */
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
/* Call user Abort complete callback */
HAL_SMARTCARD_AbortReceiveCpltCallback ( hsmartcard ) ;
}
/**
* @ brief Send an amount of data in non - blocking mode .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* Function called under interruption only , once
* interruptions have been enabled by HAL_SMARTCARD_Transmit_IT ( )
* @ retval HAL status
*/
static HAL_StatusTypeDef SMARTCARD_Transmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Check that a Tx process is ongoing */
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_BUSY_TX )
{
if ( hsmartcard - > TxXferCount = = 0 )
{
/* Disable the SMARTCARD Transmit Data Register Empty Interrupt */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_TXEIE ) ;
/* Enable the SMARTCARD Transmit Complete Interrupt */
__HAL_SMARTCARD_ENABLE_IT ( hsmartcard , hsmartcard - > AdvancedInit . TxCompletionIndication ) ;
return HAL_OK ;
}
else
{
hsmartcard - > Instance - > TDR = ( * hsmartcard - > pTxBuffPtr + + & ( uint8_t ) 0xFF ) ;
hsmartcard - > TxXferCount - - ;
return HAL_OK ;
}
}
else
{
return HAL_BUSY ;
}
}
/**
* @ brief Wrap up transmission in non - blocking mode .
* @ param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* @ retval HAL status
*/
static HAL_StatusTypeDef SMARTCARD_EndTransmit_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Disable the SMARTCARD Transmit Complete Interrupt */
__HAL_SMARTCARD_DISABLE_IT ( hsmartcard , hsmartcard - > AdvancedInit . TxCompletionIndication ) ;
/* Check if a receive process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
/* Re-enable Rx at end of transmission if initial mode is Rx/Tx */
if ( hsmartcard - > Init . Mode = = SMARTCARD_MODE_TX_RX )
{
/* Disable the Peripheral first to update modes */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RE ) ;
/* Enable the Peripheral */
SET_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_UE ) ;
}
/* Tx process is ended, restore hsmartcard->gState to Ready */
hsmartcard - > gState = HAL_SMARTCARD_STATE_READY ;
HAL_SMARTCARD_TxCpltCallback ( hsmartcard ) ;
return HAL_OK ;
}
/**
* @ brief Receive an amount of data in non - blocking mode .
* @ param hsmartcard : Pointer to a SMARTCARD_HandleTypeDef structure that contains
* the configuration information for the specified SMARTCARD module .
* Function called under interruption only , once
* interruptions have been enabled by HAL_SMARTCARD_Receive_IT ( ) .
* @ retval HAL status
*/
static HAL_StatusTypeDef SMARTCARD_Receive_IT ( SMARTCARD_HandleTypeDef * hsmartcard )
{
/* Check that a Rx process is ongoing */
if ( hsmartcard - > RxState = = HAL_SMARTCARD_STATE_BUSY_RX )
{
* hsmartcard - > pRxBuffPtr + + = ( uint8_t ) ( hsmartcard - > Instance - > RDR & ( uint8_t ) 0xFF ) ;
if ( - - hsmartcard - > RxXferCount = = 0 )
{
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_RXNEIE ) ;
/* Check if a transmit process is ongoing or not. If not disable ERR IT */
if ( hsmartcard - > gState = = HAL_SMARTCARD_STATE_READY )
{
/* Disable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */
CLEAR_BIT ( hsmartcard - > Instance - > CR3 , USART_CR3_EIE ) ;
}
/* Disable the SMARTCARD Parity Error Interrupt */
CLEAR_BIT ( hsmartcard - > Instance - > CR1 , USART_CR1_PEIE ) ;
hsmartcard - > RxState = HAL_SMARTCARD_STATE_READY ;
HAL_SMARTCARD_RxCpltCallback ( hsmartcard ) ;
return HAL_OK ;
}
return HAL_OK ;
}
else
{
/* Clear RXNE interrupt flag */
__HAL_SMARTCARD_SEND_REQ ( hsmartcard , SMARTCARD_RXDATA_FLUSH_REQUEST ) ;
2016-09-09 23:50:05 -07:00
2016-11-19 04:40:47 -08:00
return HAL_BUSY ;
}
2016-09-09 23:50:05 -07:00
}
/**
* @ }
*/
# endif /* HAL_SMARTCARD_MODULE_ENABLED */
/**
* @ }
*/
/**
* @ }
*/
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/