123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- /**
- *****************************************************************************
- * @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 */
|