/** esp/uart.h * * Configuration of UART registers. * * Part of esp-open-rtos * Copyright (C) 2015 Superhouse Automation Pty Ltd * BSD Licensed as described in the file LICENSE */ /* Copyright (c) 2015, SuperHouse Automation Pty Ltd All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef UART_REGS_H #define UART_REGS_H #ifndef DOXYGEN #include "esp/types.h" #include "common_macros.h" #ifdef __cplusplus extern "C" { #endif /* Register definitions for the UART peripherals on the ESP8266. * * There are twp UART devices built into the ESP8266: * UART(0) is at 0x60000000 * UART(1) is at 0x60000F00 * * Each device is allocated a block of 64 32-bit registers (256 bytes of * address space) to communicate with application code. */ #define UART_BASE 0x60000000 #define UART(i) (*(struct UART_REGS *)(UART_BASE + (i)*0xf00)) #define UART0_BASE UART_BASE #define UART1_BASE (UART_BASE + 0xf00) struct UART_REGS { uint32_t volatile FIFO; // 0x00 uint32_t volatile INT_RAW; // 0x04 uint32_t volatile INT_STATUS; // 0x08 uint32_t volatile INT_ENABLE; // 0x0c uint32_t volatile INT_CLEAR; // 0x10 uint32_t volatile CLOCK_DIVIDER; // 0x14 uint32_t volatile AUTOBAUD; // 0x18 uint32_t volatile STATUS; // 0x1c uint32_t volatile CONF0; // 0x20 uint32_t volatile CONF1; // 0x24 uint32_t volatile LOW_PULSE; // 0x28 uint32_t volatile HIGH_PULSE; // 0x2c uint32_t volatile PULSE_COUNT; // 0x30 uint32_t volatile _unused[17]; // 0x34 - 0x74 uint32_t volatile DATE; // 0x78 uint32_t volatile ID; // 0x7c }; _Static_assert(sizeof(struct UART_REGS) == 0x80, "UART_REGS is the wrong size"); /* Details for FIFO register */ #define UART_FIFO_DATA_M 0x000000ff #define UART_FIFO_DATA_S 0 /* Details for INT_RAW register */ #define UART_INT_RAW_RXFIFO_TIMEOUT BIT(8) #define UART_INT_RAW_BREAK_DETECTED BIT(7) #define UART_INT_RAW_CTS_CHANGED BIT(6) #define UART_INT_RAW_DSR_CHANGED BIT(5) #define UART_INT_RAW_RXFIFO_OVERFLOW BIT(4) #define UART_INT_RAW_FRAMING_ERR BIT(3) #define UART_INT_RAW_PARITY_ERR BIT(2) #define UART_INT_RAW_TXFIFO_EMPTY BIT(1) #define UART_INT_RAW_RXFIFO_FULL BIT(0) /* Details for INT_STATUS register */ #define UART_INT_STATUS_RXFIFO_TIMEOUT BIT(8) #define UART_INT_STATUS_BREAK_DETECTED BIT(7) #define UART_INT_STATUS_CTS_CHANGED BIT(6) #define UART_INT_STATUS_DSR_CHANGED BIT(5) #define UART_INT_STATUS_RXFIFO_OVERFLOW BIT(4) #define UART_INT_STATUS_FRAMING_ERR BIT(3) #define UART_INT_STATUS_PARITY_ERR BIT(2) #define UART_INT_STATUS_TXFIFO_EMPTY BIT(1) #define UART_INT_STATUS_RXFIFO_FULL BIT(0) /* Details for INT_ENABLE register */ #define UART_INT_ENABLE_RXFIFO_TIMEOUT BIT(8) #define UART_INT_ENABLE_BREAK_DETECTED BIT(7) #define UART_INT_ENABLE_CTS_CHANGED BIT(6) #define UART_INT_ENABLE_DSR_CHANGED BIT(5) #define UART_INT_ENABLE_RXFIFO_OVERFLOW BIT(4) #define UART_INT_ENABLE_FRAMING_ERR BIT(3) #define UART_INT_ENABLE_PARITY_ERR BIT(2) #define UART_INT_ENABLE_TXFIFO_EMPTY BIT(1) #define UART_INT_ENABLE_RXFIFO_FULL BIT(0) /* Details for INT_CLEAR register */ #define UART_INT_CLEAR_RXFIFO_TIMEOUT BIT(8) #define UART_INT_CLEAR_BREAK_DETECTED BIT(7) #define UART_INT_CLEAR_CTS_CHANGED BIT(6) #define UART_INT_CLEAR_DSR_CHANGED BIT(5) #define UART_INT_CLEAR_RXFIFO_OVERFLOW BIT(4) #define UART_INT_CLEAR_FRAMING_ERR BIT(3) #define UART_INT_CLEAR_PARITY_ERR BIT(2) #define UART_INT_CLEAR_TXFIFO_EMPTY BIT(1) #define UART_INT_CLEAR_RXFIFO_FULL BIT(0) /* Details for CLOCK_DIVIDER register */ #define UART_CLOCK_DIVIDER_VALUE_M 0x000fffff #define UART_CLOCK_DIVIDER_VALUE_S 0 /* Details for AUTOBAUD register */ #define UART_AUTOBAUD_GLITCH_FILTER_M 0x000000FF #define UART_AUTOBAUD_GLITCH_FILTER_S 8 #define UART_AUTOBAUD_ENABLE BIT(0) /* Details for STATUS register */ #define UART_STATUS_TXD BIT(31) #define UART_STATUS_RTS BIT(30) #define UART_STATUS_DTR BIT(29) #define UART_STATUS_TXFIFO_COUNT_M 0x000000ff #define UART_STATUS_TXFIFO_COUNT_S 16 #define UART_STATUS_RXD BIT(15) #define UART_STATUS_CTS BIT(14) #define UART_STATUS_DSR BIT(13) #define UART_STATUS_RXFIFO_COUNT_M 0x000000ff #define UART_STATUS_RXFIFO_COUNT_S 0 /* Details for CONF0 register */ #define UART_CONF0_DTR_INVERTED BIT(24) #define UART_CONF0_RTS_INVERTED BIT(23) #define UART_CONF0_TXD_INVERTED BIT(22) #define UART_CONF0_DSR_INVERTED BIT(21) #define UART_CONF0_CTS_INVERTED BIT(20) #define UART_CONF0_RXD_INVERTED BIT(19) #define UART_CONF0_TXFIFO_RESET BIT(18) #define UART_CONF0_RXFIFO_RESET BIT(17) #define UART_CONF0_IRDA_ENABLE BIT(16) #define UART_CONF0_TX_FLOW_ENABLE BIT(15) #define UART_CONF0_LOOPBACK BIT(14) #define UART_CONF0_IRDA_RX_INVERTED BIT(13) #define UART_CONF0_IRDA_TX_INVERTED BIT(12) #define UART_CONF0_IRDA_WCTL BIT(11) #define UART_CONF0_IRDA_TX_ENABLE BIT(10) #define UART_CONF0_IRDA_DUPLEX BIT(9) #define UART_CONF0_TXD_BREAK BIT(8) #define UART_CONF0_SW_DTR BIT(7) #define UART_CONF0_SW_RTS BIT(6) #define UART_CONF0_STOP_BITS_M 0x00000003 #define UART_CONF0_STOP_BITS_S 4 #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? /* Details for CONF1 register */ #define UART_CONF1_RX_TIMEOUT_ENABLE BIT(31) #define UART_CONF1_RX_TIMEOUT_THRESHOLD_M 0x0000007f #define UART_CONF1_RX_TIMEOUT_THRESHOLD_S 24 #define UART_CONF1_RX_FLOWCTRL_ENABLE BIT(23) #define UART_CONF1_RX_FLOWCTRL_THRESHOLD_M 0x0000007f #define UART_CONF1_RX_FLOWCTRL_THRESHOLD_S 16 #define UART_CONF1_TXFIFO_EMPTY_THRESHOLD_M 0x0000007f #define UART_CONF1_TXFIFO_EMPTY_THRESHOLD_S 8 #define UART_CONF1_RXFIFO_FULL_THRESHOLD_M 0x0000007f #define UART_CONF1_RXFIFO_FULL_THRESHOLD_S 0 /* Details for LOW_PULSE register */ #define UART_LOW_PULSE_MIN_M 0x000fffff #define UART_LOW_PULSE_MIN_S 0 /* Details for HIGH_PULSE register */ #define UART_HIGH_PULSE_MIN_M 0x000fffff #define UART_HIGH_PULSE_MIN_S 0 /* Details for PULSE_COUNT register */ #define UART_PULSE_COUNT_VALUE_M 0x000003ff #define UART_PULSE_COUNT_VALUE_S 0 #ifdef __cplusplus } #endif #endif // DOXYGEN #endif /* UART_REGS_H */