mirror of
https://github.com/espressif/ESP8266_RTOS_SDK.git
synced 2025-05-22 09:37:00 +08:00
205 lines
13 KiB
C
205 lines
13 KiB
C
/*
|
||
* Copyright 2018 Espressif Systems (Shanghai) PTE LTD
|
||
*
|
||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
* you may not use this file except in compliance with the License.
|
||
* You may obtain a copy of the License at
|
||
*
|
||
* http://www.apache.org/licenses/LICENSE-2.0
|
||
*
|
||
* Unless required by applicable law or agreed to in writing, software
|
||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
* See the License for the specific language governing permissions and
|
||
* limitations under the License.
|
||
*
|
||
*/
|
||
|
||
#ifndef _UART_STRUCT_H_
|
||
#define _UART_STRUCT_H_
|
||
|
||
#include <stdint.h>
|
||
#include "esp8266/eagle_soc.h"
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
/* ESP8266 UART Register Definitions */
|
||
|
||
typedef volatile struct {
|
||
union {
|
||
struct {
|
||
uint8_t rw_byte; /*This register stores one byte data read by rx fifo.*/
|
||
uint8_t reserved[3];
|
||
};
|
||
__RO__ uint32_t val;
|
||
} fifo;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_full: 1; /*This interrupt raw bit turns to high level when receiver receives more data than (rx_flow_thrhd_h3 rx_flow_thrhd).*/
|
||
uint32_t txfifo_empty: 1; /*This interrupt raw bit turns to high level when the amount of data in transmitter's fifo is less than ((tx_mem_cnttxfifo_cnt) .*/
|
||
uint32_t parity_err: 1; /*This interrupt raw bit turns to high level when receiver detects the parity error of data.*/
|
||
uint32_t frm_err: 1; /*This interrupt raw bit turns to high level when receiver detects data's frame error .*/
|
||
uint32_t rxfifo_ovf: 1; /*This interrupt raw bit turns to high level when receiver receives more data than the fifo can store.*/
|
||
uint32_t dsr_chg: 1; /*This interrupt raw bit turns to high level when receiver detects the edge change of dsrn signal.*/
|
||
uint32_t cts_chg: 1; /*This interrupt raw bit turns to high level when receiver detects the edge change of ctsn signal.*/
|
||
uint32_t brk_det: 1; /*This interrupt raw bit turns to high level when receiver detects the 0 after the stop bit.*/
|
||
uint32_t rxfifo_tout: 1; /*This interrupt raw bit turns to high level when receiver takes more time than rx_tout_thrhd to receive a byte.*/
|
||
uint32_t reserved9: 23;
|
||
};
|
||
__RO__ uint32_t val;
|
||
} int_raw;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_full: 1; /*This is the status bit for rxfifo_full_int_raw when rxfifo_full_int_ena is set to 1.*/
|
||
uint32_t txfifo_empty: 1; /*This is the status bit for txfifo_empty_int_raw when txfifo_empty_int_ena is set to 1.*/
|
||
uint32_t parity_err: 1; /*This is the status bit for parity_err_int_raw when parity_err_int_ena is set to 1.*/
|
||
uint32_t frm_err: 1; /*This is the status bit for frm_err_int_raw when fm_err_int_ena is set to 1.*/
|
||
uint32_t rxfifo_ovf: 1; /*This is the status bit for rxfifo_ovf_int_raw when rxfifo_ovf_int_ena is set to 1.*/
|
||
uint32_t dsr_chg: 1; /*This is the status bit for dsr_chg_int_raw when dsr_chg_int_ena is set to 1.*/
|
||
uint32_t cts_chg: 1; /*This is the status bit for cts_chg_int_raw when cts_chg_int_ena is set to 1.*/
|
||
uint32_t brk_det: 1; /*This is the status bit for brk_det_int_raw when brk_det_int_ena is set to 1.*/
|
||
uint32_t rxfifo_tout: 1; /*This is the status bit for rxfifo_tout_int_raw when rxfifo_tout_int_ena is set to 1.*/
|
||
uint32_t reserved9: 23;
|
||
};
|
||
__RO__ uint32_t val;
|
||
} int_st;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_full: 1; /*This is the enable bit for rxfifo_full_int_st register.*/
|
||
uint32_t txfifo_empty: 1; /*This is the enable bit for rxfifo_full_int_st register.*/
|
||
uint32_t parity_err: 1; /*This is the enable bit for parity_err_int_st register.*/
|
||
uint32_t frm_err: 1; /*This is the enable bit for frm_err_int_st register.*/
|
||
uint32_t rxfifo_ovf: 1; /*This is the enable bit for rxfifo_ovf_int_st register.*/
|
||
uint32_t dsr_chg: 1; /*This is the enable bit for dsr_chg_int_st register.*/
|
||
uint32_t cts_chg: 1; /*This is the enable bit for cts_chg_int_st register.*/
|
||
uint32_t brk_det: 1; /*This is the enable bit for brk_det_int_st register.*/
|
||
uint32_t rxfifo_tout: 1; /*This is the enable bit for rxfifo_tout_int_st register.*/
|
||
uint32_t reserved9: 23;
|
||
};
|
||
__RW__ uint32_t val;
|
||
} int_ena;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_full: 1; /*Set this bit to clear the rxfifo_full_int_raw interrupt.*/
|
||
uint32_t txfifo_empty: 1; /*Set this bit to clear txfifo_empty_int_raw interrupt.*/
|
||
uint32_t parity_err: 1; /*Set this bit to clear parity_err_int_raw interrupt.*/
|
||
uint32_t frm_err: 1; /*Set this bit to clear frm_err_int_raw interrupt.*/
|
||
uint32_t rxfifo_ovf: 1; /*Set this bit to clear rxfifo_ovf_int_raw interrupt.*/
|
||
uint32_t dsr_chg: 1; /*Set this bit to clear the dsr_chg_int_raw interrupt.*/
|
||
uint32_t cts_chg: 1; /*Set this bit to clear the cts_chg_int_raw interrupt.*/
|
||
uint32_t brk_det: 1; /*Set this bit to clear the brk_det_int_raw interrupt.*/
|
||
uint32_t rxfifo_tout: 1; /*Set this bit to clear the rxfifo_tout_int_raw interrupt.*/
|
||
uint32_t reserved9: 23;
|
||
};
|
||
__WO__ uint32_t val;
|
||
} int_clr;
|
||
union {
|
||
struct {
|
||
uint32_t div_int: 20; /*The register value is the integer part of the frequency divider's factor.*/
|
||
uint32_t reserved20: 12;
|
||
};
|
||
__RW__ uint32_t val;
|
||
} clk_div;
|
||
union {
|
||
struct {
|
||
uint32_t en: 1; /*This is the enable bit for detecting baudrate.*/
|
||
uint32_t reserved1: 7;
|
||
uint32_t glitch_filt: 8; /*when input pulse width is lower then this value ignore this pulse.this register is used in auto-baud detect process.*/
|
||
uint32_t reserved16: 16;
|
||
};
|
||
__RW__ uint32_t val;
|
||
} auto_baud;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_cnt: 8; /*(rx_mem_cnt rxfifo_cnt) stores the byte number of valid data in receiver's fifo. rx_mem_cnt register stores the 3 most significant bits rxfifo_cnt stores the 8 least significant bits.*/
|
||
uint32_t reserved8: 5;
|
||
uint32_t dsrn: 1; /*This register stores the level value of the internal uart dsr signal.*/
|
||
uint32_t ctsn: 1; /*This register stores the level value of the internal uart cts signal.*/
|
||
uint32_t rxd: 1; /*This register stores the level value of the internal uart rxd signal.*/
|
||
uint32_t txfifo_cnt: 8; /*(tx_mem_cnt txfifo_cnt) stores the byte number of valid data in transmitter's fifo.tx_mem_cnt stores the 3 most significant bits txfifo_cnt stores the 8 least significant bits.*/
|
||
uint32_t reserved24: 5;
|
||
uint32_t dtrn: 1; /*The register represent the level value of the internal uart dsr signal.*/
|
||
uint32_t rtsn: 1; /*This register represent the level value of the internal uart cts signal.*/
|
||
uint32_t txd: 1; /*This register represent the level value of the internal uart rxd signal.*/
|
||
};
|
||
__RO__ uint32_t val;
|
||
} status;
|
||
union {
|
||
struct {
|
||
uint32_t parity: 1; /*This register is used to configure the parity check mode. 0:even 1:odd*/
|
||
uint32_t parity_en: 1; /*Set this bit to enable uart parity check.*/
|
||
uint32_t bit_num: 2; /*This register is used to set the length of data: 0:5bits 1:6bits 2:7bits 3:8bits*/
|
||
uint32_t stop_bit_num: 2; /*This register is used to set the length of stop bit. 1:1bit 2:1.5bits 3:2bits*/
|
||
uint32_t sw_rts: 1; /*This register is used to configure the software rts signal which is used in software flow control.*/
|
||
uint32_t sw_dtr: 1; /*This register is used to configure the software dtr signal which is used in software flow control..*/
|
||
uint32_t txd_brk: 1; /*Set this bit to enable transmitter to send 0 when the process of sending data is done.*/
|
||
uint32_t irda_dplx: 1; /*Set this bit to enable irda loop-back mode.*/
|
||
uint32_t irda_tx_en: 1; /*This is the start enable bit for irda transmitter.*/
|
||
uint32_t irda_wctl: 1; /*1:the irda transmitter's 11th bit is the same to the 10th bit. 0:set irda transmitter's 11th bit to 0.*/
|
||
uint32_t irda_tx_inv: 1; /*Set this bit to inverse the level value of irda transmitter's level.*/
|
||
uint32_t irda_rx_inv: 1; /*Set this bit to inverse the level value of irda receiver's level.*/
|
||
uint32_t loopback: 1; /*Set this bit to enable uart loop-back test mode.*/
|
||
uint32_t tx_flow_en: 1; /*Set this bit to enable transmitter's flow control function.*/
|
||
uint32_t irda_en: 1; /*Set this bit to enable irda protocol.*/
|
||
uint32_t rxfifo_rst: 1; /*Set this bit to reset uart receiver's fifo.*/
|
||
uint32_t txfifo_rst: 1; /*Set this bit to reset uart transmitter's fifo.*/
|
||
uint32_t rxd_inv: 1; /*Set this bit to inverse the level value of uart rxd signal.*/
|
||
uint32_t cts_inv: 1; /*Set this bit to inverse the level value of uart cts signal.*/
|
||
uint32_t dsr_inv: 1; /*Set this bit to inverse the level value of uart dsr signal.*/
|
||
uint32_t txd_inv: 1; /*Set this bit to inverse the level value of uart txd signal.*/
|
||
uint32_t rts_inv: 1; /*Set this bit to inverse the level value of uart rts signal.*/
|
||
uint32_t dtr_inv: 1; /*Set this bit to inverse the level value of uart dtr signal.*/
|
||
uint32_t reserved25: 7;
|
||
};
|
||
__RW__ uint32_t val;
|
||
} conf0;
|
||
union {
|
||
struct {
|
||
uint32_t rxfifo_full_thrhd: 7; /*When receiver receives more data than its threshold value,receiver will produce rxfifo_full_int_raw interrupt.the threshold value is (rx_flow_thrhd_h3 rxfifo_full_thrhd).*/
|
||
uint32_t reserved7: 1;
|
||
uint32_t txfifo_empty_thrhd: 7; /*when the data amount in transmitter fifo is less than its threshold value, it will produce txfifo_empty_int_raw interrupt. the threshold value is (tx_mem_empty_thresh txfifo_empty_thrhd)*/
|
||
uint32_t reserved15: 1;
|
||
uint32_t rx_flow_thrhd: 7; /*when receiver receives more data than its threshold value, receiver produce signal to tell the transmitter stop transferring data. the threshold value is (rx_flow_thrhd_h3 rx_flow_thrhd).*/
|
||
uint32_t rx_flow_en: 1; /*This is the flow enable bit for uart receiver. 1:choose software flow control with configuring sw_rts signal*/
|
||
uint32_t rx_tout_thrhd: 7; /*This register is used to configure the timeout value for uart receiver receiving a byte.*/
|
||
uint32_t rx_tout_en: 1; /*This is the enable bit for uart receiver's timeout function.*/
|
||
};
|
||
__RW__ uint32_t val;
|
||
} conf1;
|
||
union {
|
||
struct {
|
||
uint32_t min_cnt: 20; /*This register stores the value of the minimum duration time for the low level pulse, it is used in baudrate-detect process.*/
|
||
uint32_t reserved20: 12;
|
||
};
|
||
__RO__ uint32_t val;
|
||
} lowpulse;
|
||
union {
|
||
struct {
|
||
uint32_t min_cnt: 20; /*This register stores the value of the maximum duration time for the high level pulse, it is used in baudrate-detect process.*/
|
||
uint32_t reserved20: 12;
|
||
};
|
||
__RO__ uint32_t val;
|
||
} highpulse;
|
||
union {
|
||
struct {
|
||
uint32_t edge_cnt: 10; /*This register stores the count of rxd edge change, it is used in baudrate-detect process.*/
|
||
uint32_t reserved10: 22;
|
||
};
|
||
__RO__ uint32_t val;
|
||
} rxd_cnt;
|
||
uint32_t reserved[18];
|
||
__RW__ uint32_t date; /**/
|
||
__RW__ uint32_t id; /**/
|
||
} uart_dev_t;
|
||
|
||
extern uart_dev_t uart0;
|
||
extern uart_dev_t uart1;
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif /* end of __cplusplus */
|
||
|
||
#endif /* _UART_STRUCT_H_ */
|