135 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			135 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | /****************************************************************************
 | ||
|  | 
 | ||
|  | Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED. | ||
|  | 
 | ||
|  | This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT | ||
|  | be copied by any method or incorporated into another program without | ||
|  | the express written consent of Aerospace C.Power. This Information or any portion | ||
|  | thereof remains the property of Aerospace C.Power. The Information contained herein | ||
|  | is believed to be accurate and Aerospace C.Power assumes no responsibility or | ||
|  | liability for its use in any way and conveys no license or title under | ||
|  | any patent or copyright and makes no representation or warranty that this | ||
|  | Information is free from patent or copyright infringement. | ||
|  | 
 | ||
|  | ****************************************************************************/ | ||
|  | 
 | ||
|  | #ifndef _UART_H
 | ||
|  | #define _UART_H
 | ||
|  | 
 | ||
|  | #include "iot_config.h"
 | ||
|  | #include "iot_uart_api.h"
 | ||
|  | #include "uart_e.h"
 | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | extern "C" { | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #define IOT_UART_PORT_NUM_ONCHIP    HW_UART_PORT_NUM
 | ||
|  | 
 | ||
|  | typedef struct uart_ctrl { | ||
|  |     int (*init)(int pt); | ||
|  |     int (*txfifo_full)(int pt); | ||
|  |     int (*putc)(int pt, char ch); | ||
|  |     int (*puts)(int pt, uint8_t *tx_rb, uint32_t len); | ||
|  |     int (*getc)(int pt); | ||
|  |     int (*gets)(int pt, uint8_t *rx_rb, uint32_t len); | ||
|  |     int (*try_putc)(int pt, char ch); | ||
|  |     int (*try_getc)(int pt); | ||
|  |     int (*config)(int pt, int br, int d_len, int stop, int parity); | ||
|  |     int (*get_int_status)(int pt); | ||
|  |     int (*clear_int_status)(int pt, int msk); | ||
|  |     int (*set_int)(int pt, int msk); | ||
|  |     int (*clear_int)(int pt, int msk); | ||
|  |     int (*flow_ctrl)(int pt, int fl, int thr); | ||
|  |     int (*set_irda)(int pt, int tx_pin); | ||
|  |     int (*threshold)(int pt, int type, int thr); | ||
|  |     void (*reset_fifo)(int pt); | ||
|  |     int (*rx_disable)(int pt, int rx_pin); | ||
|  |     int (*rx_enable)(int pt, int rx_pin); | ||
|  |     int (*tx_fifo_cnt)(int pt); | ||
|  |     int (*rx_fifo_cnt)(int pt); | ||
|  |     int (*set_brk)(int pt, int value); | ||
|  |     int (*set_baud_rate)(int pt, int br); | ||
|  |     int (*tx_disable)(int pt, int tx_pin); | ||
|  |     int (*tx_enable)(int pt, int tx_pin); | ||
|  |     int (*enable_rs485)(int pt); | ||
|  |     int (*get_vector)(int pt); | ||
|  |     int (*update_baudrate)(void); | ||
|  | }iot_uart_ctrl_t; | ||
|  | 
 | ||
|  | typedef struct { | ||
|  |     unsigned used:1; | ||
|  |     unsigned baudrate:31; | ||
|  | }uart_baudrate_info_t; | ||
|  | 
 | ||
|  | typedef enum { | ||
|  |     UART_PT0    = 0, | ||
|  |     UART_PT1, | ||
|  |     UART_PT2, | ||
|  |     UART_PT3, | ||
|  |     UART_PT4, | ||
|  |     UART_PT5, | ||
|  |     UART_PT6, | ||
|  |     UART_PT7, | ||
|  |     UART_PT8, | ||
|  | 
 | ||
|  |     UART_COUNT | ||
|  | } UART_PORT; | ||
|  | 
 | ||
|  | #define DEBUG_UART_PORT IOT_UART_PORT0
 | ||
|  | 
 | ||
|  | enum | ||
|  | { | ||
|  |     UART_DATA_5_BITS = IOT_UART_DLEN_5_BITS, | ||
|  |     UART_DATA_6_BITS = IOT_UART_DLEN_6_BITS, | ||
|  |     UART_DATA_7_BITS = IOT_UART_DLEN_7_BITS, | ||
|  |     UART_DATA_8_BITS = IOT_UART_DLEN_8_BITS | ||
|  | }; | ||
|  | 
 | ||
|  | enum | ||
|  | { | ||
|  |     UART_STOP_BITS_1    = IOT_UART_STOP_1_BITS, | ||
|  |     UART_STOP_BITS_1_5  = IOT_UART_STOP_1_5_BITS, | ||
|  |     UART_STOP_BITS_2    = IOT_UART_STOP_2_BITS | ||
|  | }; | ||
|  | 
 | ||
|  | enum | ||
|  | { | ||
|  |     UART_PARITY_DISABLE = IOT_UART_PARITY_NONE, | ||
|  |     UART_PARITY_ODD     = IOT_UART_PARITY_ODD, | ||
|  |     UART_PARITY_EVEN    = IOT_UART_PARITY_EVEN | ||
|  | }; | ||
|  | 
 | ||
|  | /* RXFIFO_FULL_INT_ENA_MASK */ | ||
|  | #define UART_RXI        0x01
 | ||
|  | /* TXFIFO_EMPTY_INT_ENA_MASK */ | ||
|  | #define UART_TXI        0x02
 | ||
|  | /* RXFIFO_TOUT_INT_ENA_MASK */ | ||
|  | #define UART_RTI        0x04
 | ||
|  | /* UART_TX_DONE */ | ||
|  | #define UART_TX_DONE    0x08
 | ||
|  | /* RXFIFO_OVF_INT_ENA_MASK */ | ||
|  | #define UART_OVR_FL     0x10
 | ||
|  | /* UART_RX_BRK */ | ||
|  | #define UART_RX_BRK     0x20
 | ||
|  | /* UART_TX_BRK */ | ||
|  | #define UART_TX_BRK     0x40
 | ||
|  | /* UART_RX_IDLE */ | ||
|  | #define UART_RX_IDLE    0x80
 | ||
|  | 
 | ||
|  | #define UART_BANDRATE_AUTO          0
 | ||
|  | 
 | ||
|  | #define UART_BANDRATE_DEFAULT       IOT_UART_BANDRATE_DEFAULT
 | ||
|  | 
 | ||
|  | /* The API table from HW level. HW will define all the APIs. */ | ||
|  | extern struct uart_ctrl uart_e_ctrl; | ||
|  | 
 | ||
|  | /* The API table for HAL used finally. */ | ||
|  | extern struct uart_ctrl g_uart_ctrl; | ||
|  | 
 | ||
|  | #ifdef __cplusplus
 | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #endif //_UART_H
 |