/** ******************************************************************************** * @file stm8s_uart2.h * @author MCD Application Team * @version V2.3.0 * @date 16-June-2017 * @brief This file contains all functions prototypes and macros for the UART2 peripheral. ****************************************************************************** * @attention * *

© COPYRIGHT 2014 STMicroelectronics

* * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); * You may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.st.com/software_license_agreement_liberty_v2 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ****************************************************************************** */ /* Define to prevent recursive inclusion -------------------------------------*/ #ifndef __STM8S_UART2_H #define __STM8S_UART2_H /* Includes ------------------------------------------------------------------*/ #include "stm8s.h" /** @addtogroup STM8S_StdPeriph_Driver * @{ */ /* Exported types ------------------------------------------------------------*/ /** @addtogroup UART2_Exported_Types * @{ */ /** * @brief UART2 Irda Modes */ typedef enum { UART2_IRDAMODE_NORMAL = (uint8_t)0x00, /**< 0x00 Irda Normal Mode */ UART2_IRDAMODE_LOWPOWER = (uint8_t)0x01 /**< 0x01 Irda Low Power Mode */ } UART2_IrDAMode_TypeDef; /** * @brief UART2 WakeUP Modes */ typedef enum { UART2_WAKEUP_IDLELINE = (uint8_t)0x00, /**< 0x01 Idle Line wake up */ UART2_WAKEUP_ADDRESSMARK = (uint8_t)0x08 /**< 0x02 Address Mark wake up */ } UART2_WakeUp_TypeDef; /** * @brief UART2 LIN Break detection length possible values */ typedef enum { UART2_LINBREAKDETECTIONLENGTH_10BITS = (uint8_t)0x00, /**< 0x01 10 bits Lin Break detection */ UART2_LINBREAKDETECTIONLENGTH_11BITS = (uint8_t)0x01 /**< 0x02 11 bits Lin Break detection */ } UART2_LINBreakDetectionLength_TypeDef; /** * @brief UART2 stop bits possible values */ typedef enum { UART2_STOPBITS_1 = (uint8_t)0x00, /**< One stop bit is transmitted at the end of frame*/ UART2_STOPBITS_0_5 = (uint8_t)0x10, /**< Half stop bits is transmitted at the end of frame*/ UART2_STOPBITS_2 = (uint8_t)0x20, /**< Two stop bits are transmitted at the end of frame*/ UART2_STOPBITS_1_5 = (uint8_t)0x30 /**< One and half stop bits*/ } UART2_StopBits_TypeDef; /** * @brief UART2 parity possible values */ typedef enum { UART2_PARITY_NO = (uint8_t)0x00, /**< No Parity*/ UART2_PARITY_EVEN = (uint8_t)0x04, /**< Even Parity*/ UART2_PARITY_ODD = (uint8_t)0x06 /**< Odd Parity*/ } UART2_Parity_TypeDef; /** * @brief UART2 Mode possible values */ typedef enum { UART2_LIN_MODE_MASTER = (uint8_t)0x00, /**< LIN Master Mode*/ UART2_LIN_MODE_SLAVE = (uint8_t)0x01 /**< LIN Slave Mode*/ } UART2_LinMode_TypeDef; /** * @brief UART2 automatic resynchronisation possible values */ typedef enum { UART2_LIN_AUTOSYNC_DISABLE = (uint8_t)0x00, /**< LIN Autosynchronization Disable*/ UART2_LIN_AUTOSYNC_ENABLE = (uint8_t)0x01 /**< LIN Autosynchronization Enable*/ } UART2_LinAutosync_TypeDef; /** * @brief UART2 Divider Update Method possible values */ typedef enum { UART2_LIN_DIVUP_LBRR1 = (uint8_t)0x00, /**< LIN LDIV is updated as soon as LBRR1 is written*/ UART2_LIN_DIVUP_NEXTRXNE = (uint8_t)0x01 /**< LIN LDIV is updated at the next received character*/ } UART2_LinDivUp_TypeDef; /** * @brief UART2 Synchrone modes */ typedef enum { UART2_SYNCMODE_CLOCK_DISABLE = (uint8_t)0x80, /**< 0x80 Sync mode Disable, SLK pin Disable */ UART2_SYNCMODE_CLOCK_ENABLE = (uint8_t)0x08, /**< 0x08 Sync mode Enable, SLK pin Enable */ UART2_SYNCMODE_CPOL_LOW = (uint8_t)0x40, /**< 0x40 Steady low value on SCLK pin outside transmission window */ UART2_SYNCMODE_CPOL_HIGH = (uint8_t)0x04, /**< 0x04 Steady high value on SCLK pin outside transmission window */ UART2_SYNCMODE_CPHA_MIDDLE = (uint8_t)0x20, /**< 0x20 SCLK clock line activated in middle of data bit */ UART2_SYNCMODE_CPHA_BEGINING = (uint8_t)0x02, /**< 0x02 SCLK clock line activated at beginning of data bit */ UART2_SYNCMODE_LASTBIT_DISABLE = (uint8_t)0x10, /**< 0x10 The clock pulse of the last data bit is not output to the SCLK pin */ UART2_SYNCMODE_LASTBIT_ENABLE = (uint8_t)0x01 /**< 0x01 The clock pulse of the last data bit is output to the SCLK pin */ } UART2_SyncMode_TypeDef; /** * @brief UART2 Word length possible values */ typedef enum { UART2_WORDLENGTH_8D = (uint8_t)0x00,/**< 0x00 8 bits Data */ UART2_WORDLENGTH_9D = (uint8_t)0x10 /**< 0x10 9 bits Data */ } UART2_WordLength_TypeDef; /** * @brief UART2 Mode possible values */ typedef enum { UART2_MODE_RX_ENABLE = (uint8_t)0x08, /**< 0x08 Receive Enable */ UART2_MODE_TX_ENABLE = (uint8_t)0x04, /**< 0x04 Transmit Enable */ UART2_MODE_TX_DISABLE = (uint8_t)0x80, /**< 0x80 Transmit Disable */ UART2_MODE_RX_DISABLE = (uint8_t)0x40, /**< 0x40 Single-wire Half-duplex mode */ UART2_MODE_TXRX_ENABLE = (uint8_t)0x0C /**< 0x0C Transmit Enable and Receive Enable */ } UART2_Mode_TypeDef; /** * @brief UART2 Flag possible values */ typedef enum { UART2_FLAG_TXE = (uint16_t)0x0080, /*!< Transmit Data Register Empty flag */ UART2_FLAG_TC = (uint16_t)0x0040, /*!< Transmission Complete flag */ UART2_FLAG_RXNE = (uint16_t)0x0020, /*!< Read Data Register Not Empty flag */ UART2_FLAG_IDLE = (uint16_t)0x0010, /*!< Idle line detected flag */ UART2_FLAG_OR_LHE = (uint16_t)0x0008, /*!< OverRun error flag */ UART2_FLAG_NF = (uint16_t)0x0004, /*!< Noise error flag */ UART2_FLAG_FE = (uint16_t)0x0002, /*!< Framing Error flag */ UART2_FLAG_PE = (uint16_t)0x0001, /*!< Parity Error flag */ UART2_FLAG_SBK = (uint16_t)0x0101, /**< Send Break Complete interrupt flag */ UART2_FLAG_LBDF = (uint16_t)0x0210, /**< LIN Break Detection Flag */ UART2_FLAG_LHDF = (uint16_t)0x0302, /**< LIN Header Detection Flag*/ UART2_FLAG_LSF = (uint16_t)0x0301 /**< LIN Sync Field Flag*/ } UART2_Flag_TypeDef; /** * @brief UART2 Interrupt definition * UART2_IT possible values * Elements values convention: 0xZYX * X: Position of the corresponding Interrupt * - For the following values, X means the interrupt position in the CR2 register. * UART2_IT_TXE * UART2_IT_TC * UART2_IT_RXNE * UART2_IT_IDLE * UART2_IT_OR * - For the UART2_IT_PE value, X means the flag position in the CR1 register. * - For the UART2_IT_LBDF value, X means the flag position in the CR4 register. * - For the UART2_IT_LHDF value, X means the flag position in the CR6 register. * Y: Flag position * - For the following values, Y means the flag (pending bit) position in the SR register. * UART2_IT_TXE * UART2_IT_TC * UART2_IT_RXNE * UART2_IT_IDLE * UART2_IT_OR * UART2_IT_PE * - For the UART2_IT_LBDF value, Y means the flag position in the CR4 register. * - For the UART2_IT_LHDF value, Y means the flag position in the CR6 register. * Z: Register index: indicate in which register the dedicated interrupt source is: * - 1==> CR1 register * - 2==> CR2 register * - 3==> CR4 register * - 4==> CR6 register */ typedef enum { UART2_IT_TXE = (uint16_t)0x0277, /**< Transmit interrupt */ UART2_IT_TC = (uint16_t)0x0266, /**< Transmission Complete interrupt */ UART2_IT_RXNE = (uint16_t)0x0255, /**< Data Register Not Empty interrupt */ UART2_IT_IDLE = (uint16_t)0x0244, /**< Idle line detected interrupt */ UART2_IT_OR = (uint16_t)0x0235, /**< OverRun error interrupt */ UART2_IT_PE = (uint16_t)0x0100, /**< Parity Error interrupt */ UART2_IT_LBDF = (uint16_t)0x0346, /**< LIN Break Detection interrupt */ UART2_IT_LHDF = (uint16_t)0x0412, /**< LIN Header Detection interrupt*/ UART2_IT_RXNE_OR = (uint16_t)0x0205 /*!< Receive/Overrun interrupt */ } UART2_IT_TypeDef; /** * @} */ /* Exported constants --------------------------------------------------------*/ /* Exported macros ------------------------------------------------------------*/ /* Private macros ------------------------------------------------------------*/ /** @addtogroup UART2_Private_Macros * @{ */ /** * @brief Macro used by the assert function to check the different functions parameters. */ /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the MODEs possible combination should be one of * the following. */ #define IS_UART2_MODE_OK(Mode) \ (((Mode) == (uint8_t)UART2_MODE_RX_ENABLE) || \ ((Mode) == (uint8_t)UART2_MODE_RX_DISABLE) || \ ((Mode) == (uint8_t)UART2_MODE_TX_ENABLE) || \ ((Mode) == (uint8_t)UART2_MODE_TX_DISABLE) || \ ((Mode) == (uint8_t)UART2_MODE_TXRX_ENABLE) || \ ((Mode) == (uint8_t)((uint8_t)UART2_MODE_TX_ENABLE|(uint8_t)UART2_MODE_RX_ENABLE)) || \ ((Mode) == (uint8_t)((uint8_t)UART2_MODE_TX_ENABLE|(uint8_t)UART2_MODE_RX_DISABLE)) || \ ((Mode) == (uint8_t)((uint8_t)UART2_MODE_TX_DISABLE|(uint8_t)UART2_MODE_RX_DISABLE)) || \ ((Mode) == (uint8_t)((uint8_t)UART2_MODE_TX_DISABLE|(uint8_t)UART2_MODE_RX_ENABLE))) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the WordLengths */ #define IS_UART2_WORDLENGTH_OK(WordLength) \ (((WordLength) == UART2_WORDLENGTH_8D) || \ ((WordLength) == UART2_WORDLENGTH_9D)) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the SyncModes; it should exclude values such * as UART2_CLOCK_ENABLE|UART2_CLOCK_DISABLE */ #define IS_UART2_SYNCMODE_OK(SyncMode) \ (!((((SyncMode)&(((uint8_t)UART2_SYNCMODE_CLOCK_ENABLE)|((uint8_t)UART2_SYNCMODE_CLOCK_DISABLE))) == (((uint8_t)UART2_SYNCMODE_CLOCK_ENABLE)|((uint8_t)UART2_SYNCMODE_CLOCK_DISABLE))) || \ (((SyncMode)&(((uint8_t)UART2_SYNCMODE_CPOL_LOW )|((uint8_t)UART2_SYNCMODE_CPOL_HIGH))) == (((uint8_t)UART2_SYNCMODE_CPOL_LOW )|((uint8_t)UART2_SYNCMODE_CPOL_HIGH))) || \ (((SyncMode)&(((uint8_t)UART2_SYNCMODE_CPHA_MIDDLE)|((uint8_t)UART2_SYNCMODE_CPHA_BEGINING))) == (((uint8_t)UART2_SYNCMODE_CPHA_MIDDLE)|((uint8_t)UART2_SYNCMODE_CPHA_BEGINING))) || \ (((SyncMode)&(((uint8_t)UART2_SYNCMODE_LASTBIT_DISABLE)|((uint8_t)UART2_SYNCMODE_LASTBIT_ENABLE))) == (((uint8_t)UART2_SYNCMODE_LASTBIT_DISABLE)|((uint8_t)UART2_SYNCMODE_LASTBIT_ENABLE))))) /** * @brief Macro used by the assert_param function in order to check the * different sensitivity values for the FLAGs */ #define IS_UART2_FLAG_OK(Flag) \ (((Flag) == UART2_FLAG_TXE) || \ ((Flag) == UART2_FLAG_TC) || \ ((Flag) == UART2_FLAG_RXNE) || \ ((Flag) == UART2_FLAG_IDLE) || \ ((Flag) == UART2_FLAG_OR_LHE) || \ ((Flag) == UART2_FLAG_NF) || \ ((Flag) == UART2_FLAG_FE) || \ ((Flag) == UART2_FLAG_PE) || \ ((Flag) == UART2_FLAG_SBK) || \ ((Flag) == UART2_FLAG_LSF) || \ ((Flag) == UART2_FLAG_LHDF) || \ ((Flag) == UART2_FLAG_LBDF)) /** * @brief Macro used by the assert_param function in order to check the * different sensitivity values for the FLAGs that can be cleared by writing 0 */ #define IS_UART2_CLEAR_FLAG_OK(Flag) \ (((Flag) == UART2_FLAG_RXNE) || \ ((Flag) == UART2_FLAG_LHDF) || \ ((Flag) == UART2_FLAG_LSF) || \ ((Flag) == UART2_FLAG_LBDF)) /** * @brief Macro used by the assert_param function in order to check * the different sensitivity values for the Interrupts */ #define IS_UART2_CONFIG_IT_OK(Interrupt) \ (((Interrupt) == UART2_IT_PE) || \ ((Interrupt) == UART2_IT_TXE) || \ ((Interrupt) == UART2_IT_TC) || \ ((Interrupt) == UART2_IT_RXNE_OR ) || \ ((Interrupt) == UART2_IT_IDLE) || \ ((Interrupt) == UART2_IT_LHDF) || \ ((Interrupt) == UART2_IT_LBDF)) /** * @brief Macro used by the assert function in order to check the different * sensitivity values for the pending bit */ #define IS_UART2_GET_IT_OK(ITPendingBit) \ (((ITPendingBit) == UART2_IT_TXE) || \ ((ITPendingBit) == UART2_IT_TC) || \ ((ITPendingBit) == UART2_IT_RXNE) || \ ((ITPendingBit) == UART2_IT_IDLE) || \ ((ITPendingBit) == UART2_IT_OR) || \ ((ITPendingBit) == UART2_IT_LBDF) || \ ((ITPendingBit) == UART2_IT_LHDF) || \ ((ITPendingBit) == UART2_IT_PE)) /** * @brief Macro used by the assert function in order to check the different * sensitivity values for the pending bit that can be cleared by writing 0 */ #define IS_UART2_CLEAR_IT_OK(ITPendingBit) \ (((ITPendingBit) == UART2_IT_RXNE) || \ ((ITPendingBit) == UART2_IT_LHDF) || \ ((ITPendingBit) == UART2_IT_LBDF)) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the IrDAModes */ #define IS_UART2_IRDAMODE_OK(IrDAMode) \ (((IrDAMode) == UART2_IRDAMODE_LOWPOWER) || \ ((IrDAMode) == UART2_IRDAMODE_NORMAL)) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the WakeUps */ #define IS_UART2_WAKEUP_OK(WakeUp) \ (((WakeUp) == UART2_WAKEUP_IDLELINE) || \ ((WakeUp) == UART2_WAKEUP_ADDRESSMARK)) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the LINBreakDetectionLengths */ #define IS_UART2_LINBREAKDETECTIONLENGTH_OK(LINBreakDetectionLength) \ (((LINBreakDetectionLength) == UART2_LINBREAKDETECTIONLENGTH_10BITS) || \ ((LINBreakDetectionLength) == UART2_LINBREAKDETECTIONLENGTH_11BITS)) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the UART2_StopBits */ #define IS_UART2_STOPBITS_OK(StopBit) (((StopBit) == UART2_STOPBITS_1) || \ ((StopBit) == UART2_STOPBITS_0_5) || \ ((StopBit) == UART2_STOPBITS_2) || \ ((StopBit) == UART2_STOPBITS_1_5 )) /** * @brief Macro used by the assert_param function in order to check the different * sensitivity values for the Paritys */ #define IS_UART2_PARITY_OK(Parity) (((Parity) == UART2_PARITY_NO) || \ ((Parity) == UART2_PARITY_EVEN) || \ ((Parity) == UART2_PARITY_ODD )) /** * @brief Macro used by the assert_param function in order to check the maximum * baudrate value */ #define IS_UART2_BAUDRATE_OK(NUM) ((NUM) <= (uint32_t)625000) /** * @brief Macro used by the assert_param function in order to check the address * of the UART2 or UART node */ #define UART2_ADDRESS_MAX ((uint8_t)16) #define IS_UART2_ADDRESS_OK(node) ((node) < UART2_ADDRESS_MAX ) /** * @brief Macro used by the assert_param function in order to check the LIN mode */ #define IS_UART2_SLAVE_OK(Mode) \ (((Mode) == UART2_LIN_MODE_MASTER) || \ ((Mode) == UART2_LIN_MODE_SLAVE)) /** * @brief Macro used by the assert_param function in order to check the LIN * automatic resynchronization mode */ #define IS_UART2_AUTOSYNC_OK(AutosyncMode) \ (((AutosyncMode) == UART2_LIN_AUTOSYNC_ENABLE) || \ ((AutosyncMode) == UART2_LIN_AUTOSYNC_DISABLE)) /** * @brief Macro used by the assert_param function in order to check the LIN divider update method */ #define IS_UART2_DIVUP_OK(DivupMethod) \ (((DivupMethod) == UART2_LIN_DIVUP_LBRR1) || \ ((DivupMethod) == UART2_LIN_DIVUP_NEXTRXNE)) /** * @} */ /* Exported functions ------------------------------------------------------- */ /** @addtogroup UART2_Exported_Functions * @{ */ void UART2_DeInit(void); void UART2_Init(uint32_t BaudRate, UART2_WordLength_TypeDef WordLength, UART2_StopBits_TypeDef StopBits, UART2_Parity_TypeDef Parity, UART2_SyncMode_TypeDef SyncMode, UART2_Mode_TypeDef Mode); void UART2_Cmd(FunctionalState NewState); void UART2_ITConfig(UART2_IT_TypeDef UART2_IT, FunctionalState NewState); void UART2_HalfDuplexCmd(FunctionalState NewState); void UART2_IrDAConfig(UART2_IrDAMode_TypeDef UART2_IrDAMode); void UART2_IrDACmd(FunctionalState NewState); void UART2_LINBreakDetectionConfig(UART2_LINBreakDetectionLength_TypeDef UART2_LINBreakDetectionLength); void UART2_LINConfig(UART2_LinMode_TypeDef UART2_Mode, UART2_LinAutosync_TypeDef UART2_Autosync, UART2_LinDivUp_TypeDef UART2_DivUp); void UART2_LINCmd(FunctionalState NewState); void UART2_SmartCardCmd(FunctionalState NewState); void UART2_SmartCardNACKCmd(FunctionalState NewState); void UART2_WakeUpConfig(UART2_WakeUp_TypeDef UART2_WakeUp); void UART2_ReceiverWakeUpCmd(FunctionalState NewState); uint8_t UART2_ReceiveData8(void); uint16_t UART2_ReceiveData9(void); void UART2_SendData8(uint8_t Data); void UART2_SendData9(uint16_t Data); void UART2_SendBreak(void); void UART2_SetAddress(uint8_t UART2_Address); void UART2_SetGuardTime(uint8_t UART2_GuardTime); void UART2_SetPrescaler(uint8_t UART2_Prescaler); FlagStatus UART2_GetFlagStatus(UART2_Flag_TypeDef UART2_FLAG); void UART2_ClearFlag(UART2_Flag_TypeDef UART2_FLAG); ITStatus UART2_GetITStatus(UART2_IT_TypeDef UART2_IT); void UART2_ClearITPendingBit(UART2_IT_TypeDef UART2_IT); /** * @} */ #endif /* __STM8S_UART2_H */ /** * @} */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/