| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380 | /**  **************************************************************************  * @file     at32f403a_407_usart.h  * @brief    at32f403a_407 usart header file  **************************************************************************  *                       Copyright notice & Disclaimer  *  * The software Board Support Package (BSP) that is made available to  * download from Artery official website is the copyrighted work of Artery.  * Artery authorizes customers to use, copy, and distribute the BSP  * software and its related documentation for the purpose of design and  * development in conjunction with Artery microcontrollers. Use of the  * software is governed by this copyright notice and the following disclaimer.  *  * THIS SOFTWARE IS PROVIDED ON "AS IS" BASIS WITHOUT WARRANTIES,  * GUARANTEES OR REPRESENTATIONS OF ANY KIND. ARTERY EXPRESSLY DISCLAIMS,  * TO THE FULLEST EXTENT PERMITTED BY LAW, ALL EXPRESS, IMPLIED OR  * STATUTORY OR OTHER WARRANTIES, GUARANTEES OR REPRESENTATIONS,  * INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY,  * FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT.  *  **************************************************************************  *//* define to prevent recursive inclusion -------------------------------------*/#ifndef __AT32F403A_407_USART_H#define __AT32F403A_407_USART_H#ifdef __cplusplusextern "C" {#endif/* includes ------------------------------------------------------------------*/#include "at32f403a_407.h"/** @addtogroup AT32F403A_407_periph_driver  * @{  *//** @addtogroup USART  * @{  *//** @defgroup USART_flags_definition  * @brief usart flag  * @{  */#define USART_PERR_FLAG                  ((uint32_t)0x00000001) /*!< usart parity error flag */#define USART_FERR_FLAG                  ((uint32_t)0x00000002) /*!< usart framing error flag */#define USART_NERR_FLAG                  ((uint32_t)0x00000004) /*!< usart noise error flag */#define USART_ROERR_FLAG                 ((uint32_t)0x00000008) /*!< usart receiver overflow error flag */#define USART_IDLEF_FLAG                 ((uint32_t)0x00000010) /*!< usart idle flag */#define USART_RDBF_FLAG                  ((uint32_t)0x00000020) /*!< usart receive data buffer full flag */#define USART_TDC_FLAG                   ((uint32_t)0x00000040) /*!< usart transmit data complete flag */#define USART_TDBE_FLAG                  ((uint32_t)0x00000080) /*!< usart transmit data buffer empty flag */#define USART_BFF_FLAG                   ((uint32_t)0x00000100) /*!< usart break frame flag */#define USART_CTSCF_FLAG                 ((uint32_t)0x00000200) /*!< usart cts change flag *//**  * @}  *//** @defgroup USART_interrupts_definition  * @brief usart interrupt  * @{  */#define USART_IDLE_INT                   MAKE_VALUE(0x0C,0x04) /*!< usart idle interrupt */#define USART_RDBF_INT                   MAKE_VALUE(0x0C,0x05) /*!< usart receive data buffer full interrupt */#define USART_TDC_INT                    MAKE_VALUE(0x0C,0x06) /*!< usart transmit data complete interrupt */#define USART_TDBE_INT                   MAKE_VALUE(0x0C,0x07) /*!< usart transmit data buffer empty interrupt */#define USART_PERR_INT                   MAKE_VALUE(0x0C,0x08) /*!< usart parity error interrupt */#define USART_BF_INT                     MAKE_VALUE(0x10,0x06) /*!< usart break frame interrupt */#define USART_ERR_INT                    MAKE_VALUE(0x14,0x00) /*!< usart error interrupt */#define USART_CTSCF_INT                  MAKE_VALUE(0x14,0x0A) /*!< usart cts change interrupt *//**  * @}  *//** @defgroup USART_exported_types  * @{  *//**  * @brief  usart parity selection type  */typedef enum{  USART_PARITY_NONE                      = 0x00, /*!< usart no parity */  USART_PARITY_EVEN                      = 0x01, /*!< usart even parity */  USART_PARITY_ODD                       = 0x02  /*!< usart odd parity */} usart_parity_selection_type;/**  * @brief  usart wakeup mode type  */typedef enum{  USART_WAKEUP_BY_IDLE_FRAME             = 0x00, /*!< usart wakeup by idle frame */  USART_WAKEUP_BY_MATCHING_ID            = 0x01  /*!< usart wakeup by matching id */} usart_wakeup_mode_type;/**  * @brief  usart data bit num type  */typedef enum{  USART_DATA_8BITS                       = 0x00, /*!< usart data size is 8 bits */  USART_DATA_9BITS                       = 0x01  /*!< usart data size is 9 bits */} usart_data_bit_num_type;/**  * @brief  usart break frame bit num type  */typedef enum{  USART_BREAK_10BITS                     = 0x00, /*!< usart lin mode berak frame detection 10 bits */  USART_BREAK_11BITS                     = 0x01  /*!< usart lin mode berak frame detection 11 bits */} usart_break_bit_num_type;/**  * @brief  usart phase of the clock type  */typedef enum{  USART_CLOCK_PHASE_1EDGE                = 0x00, /*!< usart data capture is done on the clock leading edge */  USART_CLOCK_PHASE_2EDGE                = 0x01  /*!< usart data capture is done on the clock trailing edge */} usart_clock_phase_type;/**  * @brief  usart polarity of the clock type  */typedef enum{  USART_CLOCK_POLARITY_LOW               = 0x00, /*!< usart clock stay low level outside transmission window */  USART_CLOCK_POLARITY_HIGH              = 0x01  /*!< usart clock stay high level outside transmission window */} usart_clock_polarity_type;/**  * @brief  usart last bit clock pulse type  */typedef enum{  USART_CLOCK_LAST_BIT_NONE              = 0x00, /*!< usart clock pulse of the last data bit is not outputted */  USART_CLOCK_LAST_BIT_OUTPUT            = 0x01  /*!< usart clock pulse of the last data bit is outputted */} usart_lbcp_type;/**  * @brief  usart stop bit num type  */typedef enum{  USART_STOP_1_BIT                       = 0x00, /*!< usart stop bits num is 1 */  USART_STOP_0_5_BIT                     = 0x01, /*!< usart stop bits num is 0.5 */  USART_STOP_2_BIT                       = 0x02, /*!< usart stop bits num is 2 */  USART_STOP_1_5_BIT                     = 0x03  /*!< usart stop bits num is 1.5 */} usart_stop_bit_num_type;/**  * @brief  usart hardware flow control type  */typedef enum{  USART_HARDWARE_FLOW_NONE               = 0x00, /*!< usart without hardware flow */  USART_HARDWARE_FLOW_RTS                = 0x01, /*!< usart hardware flow only rts */  USART_HARDWARE_FLOW_CTS                = 0x02, /*!< usart hardware flow only cts */  USART_HARDWARE_FLOW_RTS_CTS            = 0x03  /*!< usart hardware flow both rts and cts */} usart_hardware_flow_control_type;/**  * @brief type define usart register all  */typedef struct{  /**    * @brief usart sts register, offset:0x00    */  union  {    __IO uint32_t sts;    struct    {      __IO uint32_t perr                 : 1; /* [0] */      __IO uint32_t ferr                 : 1; /* [1] */      __IO uint32_t nerr                 : 1; /* [2] */      __IO uint32_t roerr                : 1; /* [3] */      __IO uint32_t idlef                : 1; /* [4] */      __IO uint32_t rdbf                 : 1; /* [5] */      __IO uint32_t tdc                  : 1; /* [6] */      __IO uint32_t tdbe                 : 1; /* [7] */      __IO uint32_t bff                  : 1; /* [8] */      __IO uint32_t ctscf                : 1; /* [9] */      __IO uint32_t reserved1            : 22;/* [31:10] */    } sts_bit;  };  /**    * @brief usart dt register, offset:0x04    */  union  {    __IO uint32_t dt;    struct    {      __IO uint32_t dt                   : 9; /* [8:0] */      __IO uint32_t reserved1            : 23;/* [31:9] */    } dt_bit;  };  /**    * @brief usart baudr register, offset:0x08    */  union  {    __IO uint32_t baudr;    struct    {      __IO uint32_t div                  : 16;/* [15:0] */      __IO uint32_t reserved1            : 16;/* [31:16] */    } baudr_bit;  };  /**    * @brief usart ctrl1 register, offset:0x0C    */  union  {    __IO uint32_t ctrl1;    struct    {      __IO uint32_t sbf                  : 1; /* [0] */      __IO uint32_t rm                   : 1; /* [1] */      __IO uint32_t ren                  : 1; /* [2] */      __IO uint32_t ten                  : 1; /* [3] */      __IO uint32_t idleien              : 1; /* [4] */      __IO uint32_t rdbfien              : 1; /* [5] */      __IO uint32_t tdcien               : 1; /* [6] */      __IO uint32_t tdbeien              : 1; /* [7] */      __IO uint32_t perrien              : 1; /* [8] */      __IO uint32_t psel                 : 1; /* [9] */      __IO uint32_t pen                  : 1; /* [10] */      __IO uint32_t wum                  : 1; /* [11] */      __IO uint32_t dbn                  : 1; /* [12] */      __IO uint32_t uen                  : 1; /* [13] */      __IO uint32_t reserved1            : 18;/* [31:14] */    } ctrl1_bit;  };  /**    * @brief usart ctrl2 register, offset:0x10    */  union  {    __IO uint32_t ctrl2;    struct    {      __IO uint32_t id                   : 4; /* [3:0] */      __IO uint32_t reserved1            : 1; /* [4] */      __IO uint32_t bfbn                 : 1; /* [5] */      __IO uint32_t bfien                : 1; /* [6] */      __IO uint32_t reserved2            : 1; /* [7] */      __IO uint32_t lbcp                 : 1; /* [8] */      __IO uint32_t clkpha               : 1; /* [9] */      __IO uint32_t clkpol               : 1; /* [10] */      __IO uint32_t clken                : 1; /* [11] */      __IO uint32_t stopbn               : 2; /* [13:12] */      __IO uint32_t linen                : 1; /* [14] */      __IO uint32_t reserved3            : 17;/* [31:15] */    } ctrl2_bit;  };  /**    * @brief usart ctrl3 register, offset:0x14    */  union  {    __IO uint32_t ctrl3;    struct    {      __IO uint32_t errien               : 1; /* [0] */      __IO uint32_t irdaen               : 1; /* [1] */      __IO uint32_t irdalp               : 1; /* [2] */      __IO uint32_t slben                : 1; /* [3] */      __IO uint32_t scnacken             : 1; /* [4] */      __IO uint32_t scmen                : 1; /* [5] */      __IO uint32_t dmaren               : 1; /* [6] */      __IO uint32_t dmaten               : 1; /* [7] */      __IO uint32_t rtsen                : 1; /* [8] */      __IO uint32_t ctsen                : 1; /* [9] */      __IO uint32_t ctscfien             : 1; /* [10] */      __IO uint32_t reserved1            : 21;/* [31:11] */    } ctrl3_bit;  };  /**    * @brief usart gdiv register, offset:0x18    */  union  {    __IO uint32_t gdiv;    struct    {      __IO uint32_t isdiv                : 8; /* [7:0] */      __IO uint32_t scgt                 : 8; /* [15:8] */      __IO uint32_t reserved1            : 16;/* [31:16] */    } gdiv_bit;  };} usart_type;/**  * @}  */#define USART1                           ((usart_type *) USART1_BASE)#define USART2                           ((usart_type *) USART2_BASE)#define USART3                           ((usart_type *) USART3_BASE)#define UART4                            ((usart_type *) UART4_BASE)#define UART5                            ((usart_type *) UART5_BASE)#define USART6                           ((usart_type *) USART6_BASE)#define UART7                            ((usart_type *) UART7_BASE)#if defined (AT32F403ARx) || defined (AT32F403AVx) || defined (AT32F407Rx) || \    defined (AT32F407Vx)#define UART8                            ((usart_type *) UART8_BASE)#endif/** @defgroup USART_exported_functions  * @{  */void usart_reset(usart_type* usart_x);void usart_init(usart_type* usart_x, uint32_t baud_rate, usart_data_bit_num_type data_bit, usart_stop_bit_num_type stop_bit);void usart_parity_selection_config(usart_type* usart_x, usart_parity_selection_type parity);void usart_enable(usart_type* usart_x, confirm_state new_state);void usart_transmitter_enable(usart_type* usart_x, confirm_state new_state);void usart_receiver_enable(usart_type* usart_x, confirm_state new_state);void usart_clock_config(usart_type* usart_x, usart_clock_polarity_type clk_pol, usart_clock_phase_type clk_pha, usart_lbcp_type clk_lb);void usart_clock_enable(usart_type* usart_x, confirm_state new_state);void usart_interrupt_enable(usart_type* usart_x, uint32_t usart_int, confirm_state new_state);void usart_dma_transmitter_enable(usart_type* usart_x, confirm_state new_state);void usart_dma_receiver_enable(usart_type* usart_x, confirm_state new_state);void usart_wakeup_id_set(usart_type* usart_x, uint8_t usart_id);void usart_wakeup_mode_set(usart_type* usart_x, usart_wakeup_mode_type wakeup_mode);void usart_receiver_mute_enable(usart_type* usart_x, confirm_state new_state);void usart_break_bit_num_set(usart_type* usart_x, usart_break_bit_num_type break_bit);void usart_lin_mode_enable(usart_type* usart_x, confirm_state new_state);void usart_data_transmit(usart_type* usart_x, uint16_t data);uint16_t usart_data_receive(usart_type* usart_x);void usart_break_send(usart_type* usart_x);void usart_smartcard_guard_time_set(usart_type* usart_x, uint8_t guard_time_val);void usart_irda_smartcard_division_set(usart_type* usart_x, uint8_t div_val);void usart_smartcard_mode_enable(usart_type* usart_x, confirm_state new_state);void usart_smartcard_nack_set(usart_type* usart_x, confirm_state new_state);void usart_single_line_halfduplex_select(usart_type* usart_x, confirm_state new_state);void usart_irda_mode_enable(usart_type* usart_x, confirm_state new_state);void usart_irda_low_power_enable(usart_type* usart_x, confirm_state new_state);void usart_hardware_flow_control_set(usart_type* usart_x,usart_hardware_flow_control_type flow_state);flag_status usart_flag_get(usart_type* usart_x, uint32_t flag);flag_status usart_interrupt_flag_get(usart_type* usart_x, uint32_t flag);void usart_flag_clear(usart_type* usart_x, uint32_t flag);/**  * @}  *//**  * @}  *//**  * @}  */#ifdef __cplusplus}#endif#endif
 |