UART: Add ability to configure stopbits and parity bit (#590)
This commit is contained in:
		
							parent
							
								
									f296f4d91e
								
							
						
					
					
						commit
						5c18d42c8d
					
				
					 4 changed files with 148 additions and 1 deletions
				
			
		|  | @ -124,4 +124,40 @@ static inline int uart_get_baud(int uart_num) | |||
|     return APB_CLK_FREQ / FIELD2VAL(UART_CLOCK_DIVIDER_VALUE, UART(uart_num).CLOCK_DIVIDER); | ||||
| } | ||||
| 
 | ||||
| /* Set uart stop bit count to the desired value */ | ||||
| static inline void uart_set_stopbits(int uart_num, UART_StopBits stop_bits) { | ||||
|     UART(uart_num).CONF0 = SET_FIELD(UART(uart_num).CONF0, UART_CONF0_STOP_BITS, stop_bits); | ||||
| } | ||||
| 
 | ||||
| /* Returns the current stopbit count for the UART */ | ||||
| static inline UART_StopBits uart_get_stopbits(int uart_num) { | ||||
|     return (UART_StopBits)(FIELD2VAL(UART_CONF0_STOP_BITS, UART(uart_num).CONF0)); | ||||
| } | ||||
| 
 | ||||
| /* Set if uart parity bit should be enabled */ | ||||
| static inline void uart_set_parity_enabled(int uart_num, bool enable) { | ||||
|     if(enable) | ||||
|         UART(uart_num).CONF0 = SET_MASK_BITS(UART(uart_num).CONF0, UART_CONF0_PARITY_ENABLE); | ||||
|     else | ||||
|         UART(uart_num).CONF0 = CLEAR_MASK_BITS(UART(uart_num).CONF0, UART_CONF0_PARITY_ENABLE); | ||||
| } | ||||
| 
 | ||||
| /* Set uart parity bit type */ | ||||
| static inline void uart_set_parity(int uart_num, UART_Parity parity) { | ||||
|     if(parity == UART_PARITY_EVEN) | ||||
|         UART(uart_num).CONF0 = CLEAR_MASK_BITS(UART(uart_num).CONF0, UART_CONF0_PARITY); | ||||
|     else | ||||
|         UART(uart_num).CONF0 = SET_MASK_BITS(UART(uart_num).CONF0, UART_CONF0_PARITY); | ||||
| } | ||||
| 
 | ||||
| /* Returns if parity bit is currently enabled for UART uart_num */ | ||||
| static inline bool uart_get_parity_enabled(int uart_num) { | ||||
|     return ((UART(uart_num).CONF0 & UART_CONF0_PARITY_ENABLE) != 0); | ||||
| } | ||||
| 
 | ||||
| /* Returns the current parity bit type for UART uart_num (also if parity bit is not enabled) */ | ||||
| static inline UART_Parity uart_get_parity(int uart_num) { | ||||
|     return (UART_Parity)((UART(uart_num).CONF0 & UART_CONF0_PARITY) != 0); | ||||
| } | ||||
| 
 | ||||
| #endif /* _ESP_UART_H */ | ||||
|  |  | |||
|  | @ -50,6 +50,18 @@ struct UART_REGS { | |||
| 
 | ||||
| _Static_assert(sizeof(struct UART_REGS) == 0x80, "UART_REGS is the wrong size"); | ||||
| 
 | ||||
| typedef enum { | ||||
|     UART_STOPBITS_0 = 0b00, | ||||
|     UART_STOPBITS_1 = 0b01, | ||||
|     UART_STOPBITS_1_5 = 0b10, | ||||
|     UART_STOPBITS_2 = 0b11 | ||||
| } UART_StopBits; | ||||
| 
 | ||||
| typedef enum { | ||||
|     UART_PARITY_EVEN = 0b0, | ||||
|     UART_PARITY_ODD = 0b1 | ||||
| } UART_Parity; | ||||
| 
 | ||||
| /* Details for FIFO register */ | ||||
| 
 | ||||
| #define UART_FIFO_DATA_M  0x000000ff | ||||
|  | @ -153,7 +165,7 @@ _Static_assert(sizeof(struct UART_REGS) == 0x80, "UART_REGS is the wrong size"); | |||
| #define UART_CONF0_BYTE_LEN_M                0x00000003 | ||||
| #define UART_CONF0_BYTE_LEN_S                2 | ||||
| #define UART_CONF0_PARITY_ENABLE             BIT(1) | ||||
| #define UART_CONF0_PARITY                    BIT(0) //FIXME: does this indicate odd or even?
 | ||||
| #define UART_CONF0_PARITY                    BIT(0) //where 0 means even
 | ||||
| 
 | ||||
| /* Details for CONF1 register */ | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue