/** ***************************************************************************** * @file cmem7_uart.h * * @brief CMEM7 uart header file * * * @version V1.0 * @date 3. September 2013 * * @note * ***************************************************************************** * @attention * * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE * TIME. AS A RESULT, CAPITAL-MICRO SHALL NOT BE HELD LIABLE FOR ANY DIRECT, * INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS. * * <h2><center>© COPYRIGHT 2013 Capital-micro </center></h2> ***************************************************************************** */ #ifndef __CMEM7_UART_H #define __CMEM7_UART_H #ifdef __cplusplus extern "C" { #endif #include "cmem7.h" #include "cmem7_conf.h" #define IS_UART_ALL_PERIPH(PERIPH) (((PERIPH) == UART0) || \ ((PERIPH) == UART1) || \ ((PERIPH) == UART2)) /** @defgroup UART_StopBits * @{ */ #define UART_StopBits_0_5 0 #define UART_StopBits_1 1 #define UART_StopBits_1_5 2 #define UART_StopBits_2 3 #define IS_UART_STOPBITS(STOPBITS) (((STOPBITS) == UART_StopBits_1) || \ ((STOPBITS) == UART_StopBits_0_5) || \ ((STOPBITS) == UART_StopBits_2) || \ ((STOPBITS) == UART_StopBits_1_5)) /** * @} */ /** @defgroup UART_Parity * @{ */ #define UART_Parity_Even 0 #define UART_Parity_Odd 1 #define UART_Parity_None 2 #define IS_UART_PARITY(PARITY) (((PARITY) == UART_Parity_Even) || \ ((PARITY) == UART_Parity_Odd) || \ ((PARITY) == UART_Parity_None)) /** * @} */ /** @defgroup UART_Int * @{ */ #define UART_Int_RxNotEmpty 0x00000001 #define UART_Int_TxEmpty 0x00000002 #define UART_Int_TxHalfEmpty 0x00000004 #define UART_Int_TxTimeoutNotEmpty 0x00000008 #define UART_Int_TxTimeoutEmpty 0x00000010 #define UART_Int_RxHalfFull 0x00000020 #define UART_Int_TxFull 0x00000040 #define UART_Int_ParityError 0x00000080 #define UART_Int_FrameError 0x00000100 #define UART_Int_OverrunError 0x00000200 #define UART_Int_RxThresholdReach 0x00000400 #define UART_Int_All 0x000007FF #define IS_UART_INT(INT) (((INT) != 0) && (((INT) & ~UART_Int_All) == 0)) /** * @} */ /** * @brief UART initialization structure */ typedef struct { uint32_t UART_BaudRate; /*!< Baudrate */ uint8_t UART_StopBits; /*!< Specifies the number of stop bits transmitted, It's a value of @ref UART_StopBits */ uint8_t UART_Parity; /*!< Specifies the parity mode. It's a value of @ref UART_Parity */ BOOL UART_LoopBack; /*!< loop back mode */ BOOL UART_RxEn; /*!< Receive enable bit */ BOOL UART_CtsEn; /*!< Clear to set */ } UART_InitTypeDef; /** * @brief UART initialization * @note This function should be called at first before any other interfaces. * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] init A pointer to structure UART_InitTypeDef * @retval None */ void UART_Init(UART0_Type* UARTx, UART_InitTypeDef *init); /** * @brief Enable or disable UART interrupt. * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Int interrupt mask bits, which can be the combination of @ref UART_Int * @param[in] Enable The bit indicates if specific interrupts are enable or not * @retval None */ void UART_EnableInt(UART0_Type* UARTx, uint32_t Int, BOOL Enable); /** * @brief Enable or disable UART. * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Enable The bit indicates if the specific UART is enable or not * @retval None */ void UART_Enable(UART0_Type* UARTx, BOOL enable); /** * @brief Check specific interrupts are set or not * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Int interrupt mask bits, which can be the combination of @ref UART_Int * @retval BOOL The bit indicates if specific interrupts are set or not */ BOOL UART_GetIntStatus(UART0_Type* UARTx, uint32_t Int); /** * @brief Clear specific interrupts * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Int interrupt mask bits, which can be the combination of @ref UART_Int * @retval None */ void UART_ClearInt(UART0_Type* UARTx, uint32_t Int); /** * @brief Write data to UART * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Size Expected data size to be written * @param[in] Data A pointer to the data to be written * @retval uint8_t Actual written data size */ uint8_t UART_Write(UART0_Type* UARTx, uint8_t Size, uint8_t* Data); /** * @brief Read data from UART * @param[in] UARTx UART peripheral, which is UART0, UART1 or UART2 * @param[in] Size Expected data size to be read * @param[out] Data A user-allocated buffer to fetch data to be read * @retval uint8_t Actual read data size */ uint8_t UART_Read(UART0_Type* UARTx, uint8_t Size, uint8_t* Data); #ifdef __cplusplus } #endif #endif /* __CMEM7_UART_H */