/**************************************************************************//** * @file sc.h * @version V3.00 * @brief Smart Card(SC) driver header file * * @note * @copyright (C) 2018 Nuvoton Technology Corp. All rights reserved. *****************************************************************************/ #ifndef __SC_H__ #define __SC_H__ #ifdef __cplusplus extern "C" { #endif /** @addtogroup Standard_Driver Standard Driver @{ */ /** @addtogroup SC_Driver SC Driver @{ */ /** @addtogroup SC_EXPORTED_CONSTANTS SC Exported Constants @{ */ #define SC_INTERFACE_NUM (1ul) /*!< Smartcard interface numbers \hideinitializer */ #define SC_PIN_STATE_HIGH (1ul) /*!< Smartcard pin status high \hideinitializer */ #define SC_PIN_STATE_LOW (0ul) /*!< Smartcard pin status low \hideinitializer */ #define SC_PIN_STATE_IGNORE (0xFFFFFFFFul) /*!< Ignore pin status \hideinitializer */ #define SC_CLK_ON (1ul) /*!< Smartcard clock on \hideinitializer */ #define SC_CLK_OFF (0ul) /*!< Smartcard clock off \hideinitializer */ #define SC_TMR_MODE_0 (0ul << SC_TMRCTL0_OPMODE_Pos) /*!INTEN |= (u32Mask)) /** * @brief Disable Smartcard Interrupt * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Mask Interrupt mask to be disabled. A combination of * - \ref SC_INTEN_ACERRIEN_Msk * - \ref SC_INTEN_RXTOIEN_Msk * - \ref SC_INTEN_INITIEN_Msk * - \ref SC_INTEN_CDIEN_Msk * - \ref SC_INTEN_BGTIEN_Msk * - \ref SC_INTEN_TMR2IEN_Msk * - \ref SC_INTEN_TMR1IEN_Msk * - \ref SC_INTEN_TMR0IEN_Msk * - \ref SC_INTEN_TERRIEN_Msk * - \ref SC_INTEN_TBEIEN_Msk * - \ref SC_INTEN_RDAIEN_Msk * * @return None * * @details The macro is used to disable Auto-convention error interrupt, Receiver buffer time-out interrupt, Initial end interrupt, * Card detect interrupt, Block guard time interrupt, Timer2 interrupt, Timer1 interrupt, Timer0 interrupt, * Transfer error interrupt, Transmit buffer empty interrupt or Receive data reach trigger level interrupt. * \hideinitializer */ #define SC_DISABLE_INT(psSC, u32Mask) ((psSC)->INTEN &= ~(u32Mask)) /** * @brief Check Smartcard Interrupt Status Flag * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Mask Interrupt mask to be disabled. A combination of * - \ref SC_INTSTS_ACERRIF_Msk * - \ref SC_INTSTS_RXTOIF_Msk * - \ref SC_INTSTS_INITIF_Msk * - \ref SC_INTSTS_CDIF_Msk * - \ref SC_INTSTS_BGTIF_Msk * - \ref SC_INTSTS_TMR2IF_Msk * - \ref SC_INTSTS_TMR1IF_Msk * - \ref SC_INTSTS_TMR0IF_Msk * - \ref SC_INTSTS_TERRIF_Msk * - \ref SC_INTSTS_TBEIF_Msk * - \ref SC_INTSTS_RDAIF_Msk * * @return None * * @details The macro is used to check Auto-convention error interrupt, Receiver buffer time-out interrupt, Initial end interrupt, * Card detect interrupt, Block guard time interrupt, Timer2 interrupt, Timer1 interrupt, Timer0 interrupt, * Transfer error interrupt, Transmit buffer empty interrupt or Receive data reach trigger level interrupt. * \hideinitializer */ #define SC_CHECK_INTSTS(psSC, u32Mask) ((psSC)->INTSTS &= u32Mask) /** * @brief Clear Smartcard Interrupt Status Flag * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Mask Interrupt mask to be disabled. A combination of * - \ref SC_INTSTS_ACERRIF_Msk * - \ref SC_INTSTS_RXTOIF_Msk * - \ref SC_INTSTS_INITIF_Msk * - \ref SC_INTSTS_CDIF_Msk * - \ref SC_INTSTS_BGTIF_Msk * - \ref SC_INTSTS_TMR2IF_Msk * - \ref SC_INTSTS_TMR1IF_Msk * - \ref SC_INTSTS_TMR0IF_Msk * - \ref SC_INTSTS_TERRIF_Msk * - \ref SC_INTSTS_TBEIF_Msk * - \ref SC_INTSTS_RDAIF_Msk * * @return None * * @details The macro is used to check Auto-convention error interrupt, Receiver buffer time-out interrupt, Initial end interrupt, * Card detect interrupt, Block guard time interrupt, Timer2 interrupt, Timer1 interrupt, Timer0 interrupt, * Transfer error interrupt, Transmit buffer empty interrupt or Receive data reach trigger level interrupt. * \hideinitializer */ #define SC_CLEAR_INTSTS(psSC, u32Mask) ((psSC)->INTSTS = u32Mask) /** * @brief Set ETU Divider * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Mask ETU divider value * * @return None * * @details The macro is used to give ETU divider. Its value must be given more than 4. * \hideinitializer */ #define SC_SET_ETUDIV(psSC, u32Mask) ((psSC)->ETUCTL = (((psSC)->ETUCTL&(~SC_ETUCTL_ETURDIV_Msk)) | (u32Mask <PINCTL & SC_PINCTL_SYNC_Msk);\ if(u32State)\ (psSC)->PINCTL |= SC_PINCTL_PWREN_Msk;\ else\ (psSC)->PINCTL &= ~SC_PINCTL_PWREN_Msk;\ }while(0) /** * @brief Set Smartcard Clock Status * * @param[in] psSC The pointer of smartcard module. * @param[in] u32OnOff Set clock on or off for selected smartcard module, valid values are: * - \ref SC_CLK_ON * - \ref SC_CLK_OFF * * @return None * * @details User can set CLKKEEP (SC_PINCTL[6]) to decide SC_CLK pin always keeps free running or not. * \hideinitializer */ #define SC_SET_CLK_PIN(psSC, u32OnOff)\ do {\ while((psSC)->PINCTL & SC_PINCTL_SYNC_Msk);\ if(u32OnOff)\ (psSC)->PINCTL |= SC_PINCTL_CLKKEEP_Msk;\ else\ (psSC)->PINCTL &= ~(SC_PINCTL_CLKKEEP_Msk);\ }while(0) /** * @brief Set Smartcard I/O Pin State * * @param[in] psSC The pointer of smartcard module. * @param[in] u32State Set pin state of I/O pin, valid parameters are: * - \ref SC_PIN_STATE_HIGH * - \ref SC_PIN_STATE_LOW * * @return None * * @details User can set SCDATA (SC_PINCTL[9]) to decide SC_DATA pin to high or low. * \hideinitializer */ #define SC_SET_IO_PIN(psSC, u32State)\ do {\ while((psSC)->PINCTL & SC_PINCTL_SYNC_Msk);\ if(u32State)\ (psSC)->PINCTL |= SC_PINCTL_SCDATA_Msk;\ else\ (psSC)->PINCTL &= ~SC_PINCTL_SCDATA_Msk;\ }while(0) /** * @brief Set Smartcard Reset Pin State * * @param[in] psSC The pointer of smartcard module. * @param[in] u32State Set pin state of reset pin, valid parameters are: * - \ref SC_PIN_STATE_HIGH * - \ref SC_PIN_STATE_LOW * * @return None * * @details User can set SCRST (SC_PINCTL[1]) to decide SC_RST pin to high or low. * \hideinitializer */ #define SC_SET_RST_PIN(psSC, u32State)\ do {\ while((psSC)->PINCTL & SC_PINCTL_SYNC_Msk);\ if(u32State)\ (psSC)->PINCTL |= SC_PINCTL_RSTEN_Msk;\ else\ (psSC)->PINCTL &= ~SC_PINCTL_RSTEN_Msk;\ }while(0) /** * @brief Read One Byte Data * * @param[in] psSC The pointer of smartcard module. * * @return One byte read from receive FIFO * * @details By reading DAT register, the SC will return an 8-bit received data. * \hideinitializer */ #define SC_READ(psSC) ((char)((psSC)->DAT)) /** * @brief Write One Byte Data * * @param[in] psSC The pointer of smartcard module. * @param[in] u8Data Data to write to transmit FIFO. * * @return None * * @details By writing data to DAT register, the SC will send out an 8-bit data. * \hideinitializer */ #define SC_WRITE(psSC, u8Data) ((psSC)->DAT = (u8Data)) /** * @brief Set Smartcard Stop Bit Length * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Len Stop bit length, ether 1 or 2. * * @return None * * @details Stop bit length must be 1 for T = 1 protocol and 2 for T = 0 protocol. * \hideinitializer */ #define SC_SET_STOP_BIT_LEN(psSC, u32Len) ((psSC)->CTL = ((psSC)->CTL & ~SC_CTL_NSB_Msk) | (((u32Len) == 1)? SC_CTL_NSB_Msk : 0)) /*---------------------------------------------------------------------------------------------------------*/ /* static inline functions */ /*---------------------------------------------------------------------------------------------------------*/ /* Declare these inline functions here to avoid MISRA C 2004 rule 8.1 error */ __STATIC_INLINE void SC_SetTxRetry(SC_T *psSC, uint32_t u32Count); __STATIC_INLINE void SC_SetRxRetry(SC_T *psSC, uint32_t u32Count); /** * @brief Set Tx Error Retry Count * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Count The number of Tx error retry count, between 0~8 and 0 means disable Tx error retry function. * * @return None * * @details This function is used to enable/disable transmitter retry function when parity error has occurred, and set error retry count. * @note Set error retry count to 0 will disable Tx error retry function. */ __STATIC_INLINE void SC_SetTxRetry(SC_T *psSC, uint32_t u32Count) { while ((psSC)->CTL & SC_CTL_SYNC_Msk) {} /* Retry count must set while enable bit disabled, so disable it first */ (psSC)->CTL &= ~(SC_CTL_TXRTY_Msk | SC_CTL_TXRTYEN_Msk); if ((u32Count) != 0UL) { while ((psSC)->CTL & SC_CTL_SYNC_Msk) {} (psSC)->CTL |= (((u32Count) - 1UL) << SC_CTL_TXRTY_Pos) | SC_CTL_TXRTYEN_Msk; } } /** * @brief Set Rx Error Retry Count * * @param[in] psSC The pointer of smartcard module. * @param[in] u32Count The number of Rx error retry count, between 0~8 and 0 means disable Rx error retry function. * * @return None * * @details This function is used to enable/disable receiver retry function when parity error has occurred, and set error retry count. * @note Set error retry count to 0 will disable Rx error retry function. */ __STATIC_INLINE void SC_SetRxRetry(SC_T *psSC, uint32_t u32Count) { while ((psSC)->CTL & SC_CTL_SYNC_Msk) {} /* Retry count must set while enable bit disabled, so disable it first */ (psSC)->CTL &= ~(SC_CTL_RXRTY_Msk | SC_CTL_RXRTYEN_Msk); if ((u32Count) != 0UL) { while ((psSC)->CTL & SC_CTL_SYNC_Msk) {} (psSC)->CTL |= (((u32Count) - 1UL) << SC_CTL_RXRTY_Pos) | SC_CTL_RXRTYEN_Msk; } } uint32_t SC_IsCardInserted(SC_T *psSC); void SC_ClearFIFO(SC_T *psSC); void SC_Close(SC_T *psSC); void SC_Open(SC_T *psSC, uint32_t u32CardDet, uint32_t u32PWR); void SC_ResetReader(SC_T *psSC); void SC_SetBlockGuardTime(SC_T *psSC, uint32_t u32BGT); void SC_SetCharGuardTime(SC_T *psSC, uint32_t u32CGT); void SC_StopAllTimer(SC_T *psSC); void SC_StartTimer(SC_T *psSC, uint32_t u32TimerNum, uint32_t u32Mode, uint32_t u32ETUCount); void SC_StopTimer(SC_T *psSC, uint32_t u32TimerNum); uint32_t SC_GetInterfaceClock(SC_T *psSC); /*@}*/ /* end of group SC_EXPORTED_FUNCTIONS */ /*@}*/ /* end of group SC_Driver */ /*@}*/ /* end of group Standard_Driver */ #ifdef __cplusplus } #endif #endif /* __SC_H__ */ /*** (C) COPYRIGHT 2018 Nuvoton Technology Corp. ***/