1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/cc26x0/vendor/inc/hw_uart.h

1045 lines
52 KiB
C
Raw Normal View History

2020-10-30 06:02:31 +01:00
/******************************************************************************
* Filename: hw_uart_h
* Revised: 2017-01-31 09:37:48 +0100 (Tue, 31 Jan 2017)
* Revision: 48345
*
* Copyright (c) 2015 - 2017, Texas Instruments Incorporated
* 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 ORGANIZATION 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 __HW_UART_H__
#define __HW_UART_H__
//*****************************************************************************
//
// This section defines the register offsets of
// UART component
//
//*****************************************************************************
// Data
#define UART_O_DR 0x00000000
// Status
#define UART_O_RSR 0x00000004
// Error Clear
#define UART_O_ECR 0x00000004
// Flag
#define UART_O_FR 0x00000018
// Integer Baud-Rate Divisor
#define UART_O_IBRD 0x00000024
// Fractional Baud-Rate Divisor
#define UART_O_FBRD 0x00000028
// Line Control
#define UART_O_LCRH 0x0000002C
// Control
#define UART_O_CTL 0x00000030
// Interrupt FIFO Level Select
#define UART_O_IFLS 0x00000034
// Interrupt Mask Set/Clear
#define UART_O_IMSC 0x00000038
// Raw Interrupt Status
#define UART_O_RIS 0x0000003C
// Masked Interrupt Status
#define UART_O_MIS 0x00000040
// Interrupt Clear
#define UART_O_ICR 0x00000044
// DMA Control
#define UART_O_DMACTL 0x00000048
//*****************************************************************************
//
// Register: UART_O_DR
//
//*****************************************************************************
// Field: [11] OE
//
// UART Overrun Error:
// This bit is set to 1 if data is received and the receive FIFO is already
// full. The FIFO contents remain valid because no more data is written when
// the FIFO is full, , only the contents of the shift register are overwritten.
// This is cleared to 0 once there is an empty space in the FIFO and a new
// character can be written to it.
#define UART_DR_OE 0x00000800
#define UART_DR_OE_BITN 11
#define UART_DR_OE_M 0x00000800
#define UART_DR_OE_S 11
// Field: [10] BE
//
// UART Break Error:
// This bit is set to 1 if a break condition was detected, indicating that the
// received data input (UARTRXD input pin) was held LOW for longer than a
// full-word transmission time (defined as start, data, parity and stop bits).
// In FIFO mode, this error is associated with the character at the top of the
// FIFO (i.e., the oldest received data character since last read). When a
// break occurs, a 0 character is loaded into the FIFO. The next character is
// enabled after the receive data input (UARTRXD input pin) goes to a 1
// (marking state), and the next valid start bit is received.
#define UART_DR_BE 0x00000400
#define UART_DR_BE_BITN 10
#define UART_DR_BE_M 0x00000400
#define UART_DR_BE_S 10
// Field: [9] PE
//
// UART Parity Error:
// When set to 1, it indicates that the parity of the received data character
// does not match the parity that the LCRH.EPS and LCRH.SPS select.
// In FIFO mode, this error is associated with the character at the top of the
// FIFO (i.e., the oldest received data character since last read).
#define UART_DR_PE 0x00000200
#define UART_DR_PE_BITN 9
#define UART_DR_PE_M 0x00000200
#define UART_DR_PE_S 9
// Field: [8] FE
//
// UART Framing Error:
// When set to 1, it indicates that the received character did not have a valid
// stop bit (a valid stop bit is 1).
// In FIFO mode, this error is associated with the character at the top of the
// FIFO (i.e., the oldest received data character since last read).
#define UART_DR_FE 0x00000100
#define UART_DR_FE_BITN 8
#define UART_DR_FE_M 0x00000100
#define UART_DR_FE_S 8
// Field: [7:0] DATA
//
// Data transmitted or received:
// On writes, the transmit data character is pushed into the FIFO.
// On reads, the oldest received data character since the last read is
// returned.
#define UART_DR_DATA_W 8
#define UART_DR_DATA_M 0x000000FF
#define UART_DR_DATA_S 0
//*****************************************************************************
//
// Register: UART_O_RSR
//
//*****************************************************************************
// Field: [3] OE
//
// UART Overrun Error:
// This bit is set to 1 if data is received and the receive FIFO is already
// full. The FIFO contents remain valid because no more data is written when
// the FIFO is full, , only the contents of the shift register are overwritten.
// This is cleared to 0 once there is an empty space in the FIFO and a new
// character can be written to it.
#define UART_RSR_OE 0x00000008
#define UART_RSR_OE_BITN 3
#define UART_RSR_OE_M 0x00000008
#define UART_RSR_OE_S 3
// Field: [2] BE
//
// UART Break Error:
// This bit is set to 1 if a break condition was detected, indicating that the
// received data input (UARTRXD input pin) was held LOW for longer than a
// full-word transmission time (defined as start, data, parity and stop bits).
// When a break occurs, a 0 character is loaded into the FIFO. The next
// character is enabled after the receive data input (UARTRXD input pin) goes
// to a 1 (marking state), and the next valid start bit is received.
#define UART_RSR_BE 0x00000004
#define UART_RSR_BE_BITN 2
#define UART_RSR_BE_M 0x00000004
#define UART_RSR_BE_S 2
// Field: [1] PE
//
// UART Parity Error:
// When set to 1, it indicates that the parity of the received data character
// does not match the parity that the LCRH.EPS and LCRH.SPS select.
#define UART_RSR_PE 0x00000002
#define UART_RSR_PE_BITN 1
#define UART_RSR_PE_M 0x00000002
#define UART_RSR_PE_S 1
// Field: [0] FE
//
// UART Framing Error:
// When set to 1, it indicates that the received character did not have a valid
// stop bit (a valid stop bit is 1).
#define UART_RSR_FE 0x00000001
#define UART_RSR_FE_BITN 0
#define UART_RSR_FE_M 0x00000001
#define UART_RSR_FE_S 0
//*****************************************************************************
//
// Register: UART_O_ECR
//
//*****************************************************************************
// Field: [3] OE
//
// The framing (FE), parity (PE), break (BE) and overrun (OE) errors are
// cleared to 0 by any write to this register.
#define UART_ECR_OE 0x00000008
#define UART_ECR_OE_BITN 3
#define UART_ECR_OE_M 0x00000008
#define UART_ECR_OE_S 3
// Field: [2] BE
//
// The framing (FE), parity (PE), break (BE) and overrun (OE) errors are
// cleared to 0 by any write to this register.
#define UART_ECR_BE 0x00000004
#define UART_ECR_BE_BITN 2
#define UART_ECR_BE_M 0x00000004
#define UART_ECR_BE_S 2
// Field: [1] PE
//
// The framing (FE), parity (PE), break (BE) and overrun (OE) errors are
// cleared to 0 by any write to this register.
#define UART_ECR_PE 0x00000002
#define UART_ECR_PE_BITN 1
#define UART_ECR_PE_M 0x00000002
#define UART_ECR_PE_S 1
// Field: [0] FE
//
// The framing (FE), parity (PE), break (BE) and overrun (OE) errors are
// cleared to 0 by any write to this register.
#define UART_ECR_FE 0x00000001
#define UART_ECR_FE_BITN 0
#define UART_ECR_FE_M 0x00000001
#define UART_ECR_FE_S 0
//*****************************************************************************
//
// Register: UART_O_FR
//
//*****************************************************************************
// Field: [7] TXFE
//
// UART Transmit FIFO Empty:
// The meaning of this bit depends on the state of LCRH.FEN .
// - If the FIFO is disabled, this bit is set when the transmit holding
// register is empty.
// - If the FIFO is enabled, this bit is set when the transmit FIFO is empty.
// This bit does not indicate if there is data in the transmit shift register.
#define UART_FR_TXFE 0x00000080
#define UART_FR_TXFE_BITN 7
#define UART_FR_TXFE_M 0x00000080
#define UART_FR_TXFE_S 7
// Field: [6] RXFF
//
// UART Receive FIFO Full:
// The meaning of this bit depends on the state of LCRH.FEN.
// - If the FIFO is disabled, this bit is set when the receive holding
// register is full.
// - If the FIFO is enabled, this bit is set when the receive FIFO is full.
#define UART_FR_RXFF 0x00000040
#define UART_FR_RXFF_BITN 6
#define UART_FR_RXFF_M 0x00000040
#define UART_FR_RXFF_S 6
// Field: [5] TXFF
//
// UART Transmit FIFO Full:
// Transmit FIFO full. The meaning of this bit depends on the state of
// LCRH.FEN.
// - If the FIFO is disabled, this bit is set when the transmit holding
// register is full.
// - If the FIFO is enabled, this bit is set when the transmit FIFO is full.
#define UART_FR_TXFF 0x00000020
#define UART_FR_TXFF_BITN 5
#define UART_FR_TXFF_M 0x00000020
#define UART_FR_TXFF_S 5
// Field: [4] RXFE
//
// UART Receive FIFO Empty:
// Receive FIFO empty. The meaning of this bit depends on the state of
// LCRH.FEN.
// - If the FIFO is disabled, this bit is set when the receive holding
// register is empty.
// - If the FIFO is enabled, this bit is set when the receive FIFO is empty.
#define UART_FR_RXFE 0x00000010
#define UART_FR_RXFE_BITN 4
#define UART_FR_RXFE_M 0x00000010
#define UART_FR_RXFE_S 4
// Field: [3] BUSY
//
// UART Busy:
// If this bit is set to 1, the UART is busy transmitting data. This bit
// remains set until the complete byte, including all the stop bits, has been
// sent from the shift register.
// This bit is set as soon as the transmit FIFO becomes non-empty, regardless
// of whether the UART is enabled or not.
#define UART_FR_BUSY 0x00000008
#define UART_FR_BUSY_BITN 3
#define UART_FR_BUSY_M 0x00000008
#define UART_FR_BUSY_S 3
// Field: [0] CTS
//
// Clear To Send:
// This bit is the complement of the active-low UART CTS input pin.
// That is, the bit is 1 when CTS input pin is LOW.
#define UART_FR_CTS 0x00000001
#define UART_FR_CTS_BITN 0
#define UART_FR_CTS_M 0x00000001
#define UART_FR_CTS_S 0
//*****************************************************************************
//
// Register: UART_O_IBRD
//
//*****************************************************************************
// Field: [15:0] DIVINT
//
// The integer baud rate divisor:
// The baud rate divisor is calculated using the formula below:
// Baud rate divisor = (UART reference clock frequency) / (16 * Baud rate)
// Baud rate divisor must be minimum 1 and maximum 65535.
// That is, DIVINT=0 does not give a valid baud rate.
// Similarly, if DIVINT=0xFFFF, any non-zero values in FBRD.DIVFRAC will be
// illegal.
// A valid value must be written to this field before the UART can be used for
// RX or TX operations.
#define UART_IBRD_DIVINT_W 16
#define UART_IBRD_DIVINT_M 0x0000FFFF
#define UART_IBRD_DIVINT_S 0
//*****************************************************************************
//
// Register: UART_O_FBRD
//
//*****************************************************************************
// Field: [5:0] DIVFRAC
//
// Fractional Baud-Rate Divisor:
// The baud rate divisor is calculated using the formula below:
// Baud rate divisor = (UART reference clock frequency) / (16 * Baud rate)
// Baud rate divisor must be minimum 1 and maximum 65535.
// That is, IBRD.DIVINT=0 does not give a valid baud rate.
// Similarly, if IBRD.DIVINT=0xFFFF, any non-zero values in DIVFRAC will be
// illegal.
// A valid value must be written to this field before the UART can be used for
// RX or TX operations.
#define UART_FBRD_DIVFRAC_W 6
#define UART_FBRD_DIVFRAC_M 0x0000003F
#define UART_FBRD_DIVFRAC_S 0
//*****************************************************************************
//
// Register: UART_O_LCRH
//
//*****************************************************************************
// Field: [7] SPS
//
// UART Stick Parity Select:
//
// 0: Stick parity is disabled
// 1: The parity bit is transmitted and checked as invert of EPS field (i.e.
// the parity bit is transmitted and checked as 1 when EPS = 0).
//
// This bit has no effect when PEN disables parity checking and generation.
#define UART_LCRH_SPS 0x00000080
#define UART_LCRH_SPS_BITN 7
#define UART_LCRH_SPS_M 0x00000080
#define UART_LCRH_SPS_S 7
// Field: [6:5] WLEN
//
// UART Word Length:
// These bits indicate the number of data bits transmitted or received in a
// frame.
// ENUMs:
// 8 Word Length 8 bits
// 7 Word Length 7 bits
// 6 Word Length 6 bits
// 5 Word Length 5 bits
#define UART_LCRH_WLEN_W 2
#define UART_LCRH_WLEN_M 0x00000060
#define UART_LCRH_WLEN_S 5
#define UART_LCRH_WLEN_8 0x00000060
#define UART_LCRH_WLEN_7 0x00000040
#define UART_LCRH_WLEN_6 0x00000020
#define UART_LCRH_WLEN_5 0x00000000
// Field: [4] FEN
//
// UART Enable FIFOs
// ENUMs:
// EN Transmit and receive FIFO buffers are enabled
// (FIFO mode)
// DIS FIFOs are disabled (character mode) that is, the
// FIFOs become 1-byte-deep holding registers.
#define UART_LCRH_FEN 0x00000010
#define UART_LCRH_FEN_BITN 4
#define UART_LCRH_FEN_M 0x00000010
#define UART_LCRH_FEN_S 4
#define UART_LCRH_FEN_EN 0x00000010
#define UART_LCRH_FEN_DIS 0x00000000
// Field: [3] STP2
//
// UART Two Stop Bits Select:
// If this bit is set to 1, two stop bits are transmitted at the end of the
// frame. The receive logic does not check for two stop bits being received.
#define UART_LCRH_STP2 0x00000008
#define UART_LCRH_STP2_BITN 3
#define UART_LCRH_STP2_M 0x00000008
#define UART_LCRH_STP2_S 3
// Field: [2] EPS
//
// UART Even Parity Select
// ENUMs:
// EVEN Even parity: The UART generates or checks for an
// even number of 1s in the data and parity bits.
// ODD Odd parity: The UART generates or checks for an
// odd number of 1s in the data and parity bits.
#define UART_LCRH_EPS 0x00000004
#define UART_LCRH_EPS_BITN 2
#define UART_LCRH_EPS_M 0x00000004
#define UART_LCRH_EPS_S 2
#define UART_LCRH_EPS_EVEN 0x00000004
#define UART_LCRH_EPS_ODD 0x00000000
// Field: [1] PEN
//
// UART Parity Enable
// This bit controls generation and checking of parity bit.
// ENUMs:
// EN Parity checking and generation is enabled.
// DIS Parity is disabled and no parity bit is added to
// the data frame
#define UART_LCRH_PEN 0x00000002
#define UART_LCRH_PEN_BITN 1
#define UART_LCRH_PEN_M 0x00000002
#define UART_LCRH_PEN_S 1
#define UART_LCRH_PEN_EN 0x00000002
#define UART_LCRH_PEN_DIS 0x00000000
// Field: [0] BRK
//
// UART Send Break
// If this bit is set to 1, a low-level is continually output on the UARTTXD
// output pin, after completing transmission of the current character. For the
// proper execution of the break command, the
// software must set this bit for at least two complete frames. For normal use,
// this bit must be cleared to 0.
#define UART_LCRH_BRK 0x00000001
#define UART_LCRH_BRK_BITN 0
#define UART_LCRH_BRK_M 0x00000001
#define UART_LCRH_BRK_S 0
//*****************************************************************************
//
// Register: UART_O_CTL
//
//*****************************************************************************
// Field: [15] CTSEN
//
// CTS hardware flow control enable
// ENUMs:
// EN CTS hardware flow control enabled
// DIS CTS hardware flow control disabled
#define UART_CTL_CTSEN 0x00008000
#define UART_CTL_CTSEN_BITN 15
#define UART_CTL_CTSEN_M 0x00008000
#define UART_CTL_CTSEN_S 15
#define UART_CTL_CTSEN_EN 0x00008000
#define UART_CTL_CTSEN_DIS 0x00000000
// Field: [14] RTSEN
//
// RTS hardware flow control enable
// ENUMs:
// EN RTS hardware flow control enabled
// DIS RTS hardware flow control disabled
#define UART_CTL_RTSEN 0x00004000
#define UART_CTL_RTSEN_BITN 14
#define UART_CTL_RTSEN_M 0x00004000
#define UART_CTL_RTSEN_S 14
#define UART_CTL_RTSEN_EN 0x00004000
#define UART_CTL_RTSEN_DIS 0x00000000
// Field: [11] RTS
//
// Request to Send
// This bit is the complement of the active-low UART RTS output. That is, when
// the bit is programmed to a 1 then RTS output on the pins is LOW.
#define UART_CTL_RTS 0x00000800
#define UART_CTL_RTS_BITN 11
#define UART_CTL_RTS_M 0x00000800
#define UART_CTL_RTS_S 11
// Field: [9] RXE
//
// UART Receive Enable
// If the UART is disabled in the middle of reception, it completes the current
// character before stopping.
// ENUMs:
// EN UART Receive enabled
// DIS UART Receive disabled
#define UART_CTL_RXE 0x00000200
#define UART_CTL_RXE_BITN 9
#define UART_CTL_RXE_M 0x00000200
#define UART_CTL_RXE_S 9
#define UART_CTL_RXE_EN 0x00000200
#define UART_CTL_RXE_DIS 0x00000000
// Field: [8] TXE
//
// UART Transmit Enable
// If the UART is disabled in the middle of transmission, it completes the
// current character before stopping.
// ENUMs:
// EN UART Transmit enabled
// DIS UART Transmit disabled
#define UART_CTL_TXE 0x00000100
#define UART_CTL_TXE_BITN 8
#define UART_CTL_TXE_M 0x00000100
#define UART_CTL_TXE_S 8
#define UART_CTL_TXE_EN 0x00000100
#define UART_CTL_TXE_DIS 0x00000000
// Field: [7] LBE
//
// UART Loop Back Enable:
// Enabling the loop-back mode connects the UARTTXD output from the UART to
// UARTRXD input of the UART.
// ENUMs:
// EN Loop Back enabled
// DIS Loop Back disabled
#define UART_CTL_LBE 0x00000080
#define UART_CTL_LBE_BITN 7
#define UART_CTL_LBE_M 0x00000080
#define UART_CTL_LBE_S 7
#define UART_CTL_LBE_EN 0x00000080
#define UART_CTL_LBE_DIS 0x00000000
// Field: [0] UARTEN
//
// UART Enable
// ENUMs:
// EN UART enabled
// DIS UART disabled
#define UART_CTL_UARTEN 0x00000001
#define UART_CTL_UARTEN_BITN 0
#define UART_CTL_UARTEN_M 0x00000001
#define UART_CTL_UARTEN_S 0
#define UART_CTL_UARTEN_EN 0x00000001
#define UART_CTL_UARTEN_DIS 0x00000000
//*****************************************************************************
//
// Register: UART_O_IFLS
//
//*****************************************************************************
// Field: [5:3] RXSEL
//
// Receive interrupt FIFO level select:
// This field sets the trigger points for the receive interrupt. Values
// 0b101-0b111 are reserved.
// ENUMs:
// 7_8 Receive FIFO becomes >= 7/8 full
// 6_8 Receive FIFO becomes >= 3/4 full
// 4_8 Receive FIFO becomes >= 1/2 full
// 2_8 Receive FIFO becomes >= 1/4 full
// 1_8 Receive FIFO becomes >= 1/8 full
#define UART_IFLS_RXSEL_W 3
#define UART_IFLS_RXSEL_M 0x00000038
#define UART_IFLS_RXSEL_S 3
#define UART_IFLS_RXSEL_7_8 0x00000020
#define UART_IFLS_RXSEL_6_8 0x00000018
#define UART_IFLS_RXSEL_4_8 0x00000010
#define UART_IFLS_RXSEL_2_8 0x00000008
#define UART_IFLS_RXSEL_1_8 0x00000000
// Field: [2:0] TXSEL
//
// Transmit interrupt FIFO level select:
// This field sets the trigger points for the transmit interrupt. Values
// 0b101-0b111 are reserved.
// ENUMs:
// 7_8 Transmit FIFO becomes <= 7/8 full
// 6_8 Transmit FIFO becomes <= 3/4 full
// 4_8 Transmit FIFO becomes <= 1/2 full
// 2_8 Transmit FIFO becomes <= 1/4 full
// 1_8 Transmit FIFO becomes <= 1/8 full
#define UART_IFLS_TXSEL_W 3
#define UART_IFLS_TXSEL_M 0x00000007
#define UART_IFLS_TXSEL_S 0
#define UART_IFLS_TXSEL_7_8 0x00000004
#define UART_IFLS_TXSEL_6_8 0x00000003
#define UART_IFLS_TXSEL_4_8 0x00000002
#define UART_IFLS_TXSEL_2_8 0x00000001
#define UART_IFLS_TXSEL_1_8 0x00000000
//*****************************************************************************
//
// Register: UART_O_IMSC
//
//*****************************************************************************
// Field: [10] OEIM
//
// Overrun error interrupt mask. A read returns the current mask for UART's
// overrun error interrupt. On a write of 1, the mask of the overrun error
// interrupt is set which means the interrupt state will be reflected in
// MIS.OEMIS. A write of 0 clears the mask which means MIS.OEMIS will not
// reflect the interrupt.
#define UART_IMSC_OEIM 0x00000400
#define UART_IMSC_OEIM_BITN 10
#define UART_IMSC_OEIM_M 0x00000400
#define UART_IMSC_OEIM_S 10
// Field: [9] BEIM
//
// Break error interrupt mask. A read returns the current mask for UART's break
// error interrupt. On a write of 1, the mask of the overrun error interrupt is
// set which means the interrupt state will be reflected in MIS.BEMIS. A write
// of 0 clears the mask which means MIS.BEMIS will not reflect the interrupt.
#define UART_IMSC_BEIM 0x00000200
#define UART_IMSC_BEIM_BITN 9
#define UART_IMSC_BEIM_M 0x00000200
#define UART_IMSC_BEIM_S 9
// Field: [8] PEIM
//
// Parity error interrupt mask. A read returns the current mask for UART's
// parity error interrupt. On a write of 1, the mask of the overrun error
// interrupt is set which means the interrupt state will be reflected in
// MIS.PEMIS. A write of 0 clears the mask which means MIS.PEMIS will not
// reflect the interrupt.
#define UART_IMSC_PEIM 0x00000100
#define UART_IMSC_PEIM_BITN 8
#define UART_IMSC_PEIM_M 0x00000100
#define UART_IMSC_PEIM_S 8
// Field: [7] FEIM
//
// Framing error interrupt mask. A read returns the current mask for UART's
// framing error interrupt. On a write of 1, the mask of the overrun error
// interrupt is set which means the interrupt state will be reflected in
// MIS.FEMIS. A write of 0 clears the mask which means MIS.FEMIS will not
// reflect the interrupt.
#define UART_IMSC_FEIM 0x00000080
#define UART_IMSC_FEIM_BITN 7
#define UART_IMSC_FEIM_M 0x00000080
#define UART_IMSC_FEIM_S 7
// Field: [6] RTIM
//
// Receive timeout interrupt mask. A read returns the current mask for UART's
// receive timeout interrupt. On a write of 1, the mask of the overrun error
// interrupt is set which means the interrupt state will be reflected in
// MIS.RTMIS. A write of 0 clears the mask which means this bitfield will not
// reflect the interrupt.
// The raw interrupt for receive timeout RIS.RTRIS cannot be set unless the
// mask is set (RTIM = 1). This is because the mask acts as an enable for power
// saving. That is, the same status can be read from MIS.RTMIS and RIS.RTRIS.
#define UART_IMSC_RTIM 0x00000040
#define UART_IMSC_RTIM_BITN 6
#define UART_IMSC_RTIM_M 0x00000040
#define UART_IMSC_RTIM_S 6
// Field: [5] TXIM
//
// Transmit interrupt mask. A read returns the current mask for UART's transmit
// interrupt. On a write of 1, the mask of the overrun error interrupt is set
// which means the interrupt state will be reflected in MIS.TXMIS. A write of 0
// clears the mask which means MIS.TXMIS will not reflect the interrupt.
#define UART_IMSC_TXIM 0x00000020
#define UART_IMSC_TXIM_BITN 5
#define UART_IMSC_TXIM_M 0x00000020
#define UART_IMSC_TXIM_S 5
// Field: [4] RXIM
//
// Receive interrupt mask. A read returns the current mask for UART's receive
// interrupt. On a write of 1, the mask of the overrun error interrupt is set
// which means the interrupt state will be reflected in MIS.RXMIS. A write of 0
// clears the mask which means MIS.RXMIS will not reflect the interrupt.
#define UART_IMSC_RXIM 0x00000010
#define UART_IMSC_RXIM_BITN 4
#define UART_IMSC_RXIM_M 0x00000010
#define UART_IMSC_RXIM_S 4
// Field: [1] CTSMIM
//
// Clear to Send (CTS) modem interrupt mask. A read returns the current mask
// for UART's clear to send interrupt. On a write of 1, the mask of the overrun
// error interrupt is set which means the interrupt state will be reflected in
// MIS.CTSMMIS. A write of 0 clears the mask which means MIS.CTSMMIS will not
// reflect the interrupt.
#define UART_IMSC_CTSMIM 0x00000002
#define UART_IMSC_CTSMIM_BITN 1
#define UART_IMSC_CTSMIM_M 0x00000002
#define UART_IMSC_CTSMIM_S 1
//*****************************************************************************
//
// Register: UART_O_RIS
//
//*****************************************************************************
// Field: [10] OERIS
//
// Overrun error interrupt status:
// This field returns the raw interrupt state of UART's overrun error
// interrupt. Overrun error occurs if data is received and the receive FIFO is
// full.
#define UART_RIS_OERIS 0x00000400
#define UART_RIS_OERIS_BITN 10
#define UART_RIS_OERIS_M 0x00000400
#define UART_RIS_OERIS_S 10
// Field: [9] BERIS
//
// Break error interrupt status:
// This field returns the raw interrupt state of UART's break error interrupt.
// Break error is set when a break condition is detected, indicating that the
// received data input (UARTRXD input pin) was held LOW for longer than a
// full-word transmission time (defined as start, data, parity and stop bits).
#define UART_RIS_BERIS 0x00000200
#define UART_RIS_BERIS_BITN 9
#define UART_RIS_BERIS_M 0x00000200
#define UART_RIS_BERIS_S 9
// Field: [8] PERIS
//
// Parity error interrupt status:
// This field returns the raw interrupt state of UART's parity error interrupt.
// Parity error is set if the parity of the received data character does not
// match the parity that the LCRH.EPS and LCRH.SPS select.
#define UART_RIS_PERIS 0x00000100
#define UART_RIS_PERIS_BITN 8
#define UART_RIS_PERIS_M 0x00000100
#define UART_RIS_PERIS_S 8
// Field: [7] FERIS
//
// Framing error interrupt status:
// This field returns the raw interrupt state of UART's framing error
// interrupt. Framing error is set if the received character does not have a
// valid stop bit (a valid stop bit is 1).
#define UART_RIS_FERIS 0x00000080
#define UART_RIS_FERIS_BITN 7
#define UART_RIS_FERIS_M 0x00000080
#define UART_RIS_FERIS_S 7
// Field: [6] RTRIS
//
// Receive timeout interrupt status:
// This field returns the raw interrupt state of UART's receive timeout
// interrupt. The receive timeout interrupt is asserted when the receive FIFO
// is not empty, and no more data is received during a 32-bit period. The
// receive timeout interrupt is cleared either when the FIFO becomes empty
// through reading all the data, or when a 1 is written to ICR.RTIC.
// The raw interrupt for receive timeout cannot be set unless the mask is set
// (IMSC.RTIM = 1). This is because the mask acts as an enable for power
// saving. That is, the same status can be read from MIS.RTMIS and RTRIS.
#define UART_RIS_RTRIS 0x00000040
#define UART_RIS_RTRIS_BITN 6
#define UART_RIS_RTRIS_M 0x00000040
#define UART_RIS_RTRIS_S 6
// Field: [5] TXRIS
//
// Transmit interrupt status:
// This field returns the raw interrupt state of UART's transmit interrupt.
// When FIFOs are enabled (LCRH.FEN = 1), the transmit interrupt is asserted if
// the number of bytes in transmit FIFO is equal to or lower than the
// programmed trigger level (IFLS.TXSEL). The transmit interrupt is cleared by
// writing data to the transmit FIFO until it becomes greater than the trigger
// level, or by clearing the interrupt through ICR.TXIC.
// When FIFOs are disabled (LCRH.FEN = 0), that is they have a depth of one
// location, the transmit interrupt is asserted if there is no data present in
// the transmitters single location. It is cleared by performing a single write
// to the transmit FIFO, or by clearing the interrupt through ICR.TXIC.
#define UART_RIS_TXRIS 0x00000020
#define UART_RIS_TXRIS_BITN 5
#define UART_RIS_TXRIS_M 0x00000020
#define UART_RIS_TXRIS_S 5
// Field: [4] RXRIS
//
// Receive interrupt status:
// This field returns the raw interrupt state of UART's receive interrupt.
// When FIFOs are enabled (LCRH.FEN = 1), the receive interrupt is asserted if
// the receive FIFO reaches the programmed trigger
// level (IFLS.RXSEL). The receive interrupt is cleared by reading data from
// the receive FIFO until it becomes less than the trigger level, or by
// clearing the interrupt through ICR.RXIC.
// When FIFOs are disabled (LCRH.FEN = 0), that is they have a depth of one
// location, the receive interrupt is asserted if data is received
// thereby filling the location. The receive interrupt is cleared by performing
// a single read of the receive FIFO, or by clearing the interrupt through
// ICR.RXIC.
#define UART_RIS_RXRIS 0x00000010
#define UART_RIS_RXRIS_BITN 4
#define UART_RIS_RXRIS_M 0x00000010
#define UART_RIS_RXRIS_S 4
// Field: [1] CTSRMIS
//
// Clear to Send (CTS) modem interrupt status:
// This field returns the raw interrupt state of UART's clear to send
// interrupt.
#define UART_RIS_CTSRMIS 0x00000002
#define UART_RIS_CTSRMIS_BITN 1
#define UART_RIS_CTSRMIS_M 0x00000002
#define UART_RIS_CTSRMIS_S 1
//*****************************************************************************
//
// Register: UART_O_MIS
//
//*****************************************************************************
// Field: [10] OEMIS
//
// Overrun error masked interrupt status:
// This field returns the masked interrupt state of the overrun interrupt which
// is the AND product of raw interrupt state RIS.OERIS and the mask setting
// IMSC.OEIM.
#define UART_MIS_OEMIS 0x00000400
#define UART_MIS_OEMIS_BITN 10
#define UART_MIS_OEMIS_M 0x00000400
#define UART_MIS_OEMIS_S 10
// Field: [9] BEMIS
//
// Break error masked interrupt status:
// This field returns the masked interrupt state of the break error interrupt
// which is the AND product of raw interrupt state RIS.BERIS and the mask
// setting IMSC.BEIM.
#define UART_MIS_BEMIS 0x00000200
#define UART_MIS_BEMIS_BITN 9
#define UART_MIS_BEMIS_M 0x00000200
#define UART_MIS_BEMIS_S 9
// Field: [8] PEMIS
//
// Parity error masked interrupt status:
// This field returns the masked interrupt state of the parity error interrupt
// which is the AND product of raw interrupt state RIS.PERIS and the mask
// setting IMSC.PEIM.
#define UART_MIS_PEMIS 0x00000100
#define UART_MIS_PEMIS_BITN 8
#define UART_MIS_PEMIS_M 0x00000100
#define UART_MIS_PEMIS_S 8
// Field: [7] FEMIS
//
// Framing error masked interrupt status: Returns the masked interrupt state of
// the framing error interrupt which is the AND product of raw interrupt state
// RIS.FERIS and the mask setting IMSC.FEIM.
#define UART_MIS_FEMIS 0x00000080
#define UART_MIS_FEMIS_BITN 7
#define UART_MIS_FEMIS_M 0x00000080
#define UART_MIS_FEMIS_S 7
// Field: [6] RTMIS
//
// Receive timeout masked interrupt status:
// Returns the masked interrupt state of the receive timeout interrupt.
// The raw interrupt for receive timeout cannot be set unless the mask is set
// (IMSC.RTIM = 1). This is because the mask acts as an enable for power
// saving. That is, the same status can be read from RTMIS and RIS.RTRIS.
#define UART_MIS_RTMIS 0x00000040
#define UART_MIS_RTMIS_BITN 6
#define UART_MIS_RTMIS_M 0x00000040
#define UART_MIS_RTMIS_S 6
// Field: [5] TXMIS
//
// Transmit masked interrupt status:
// This field returns the masked interrupt state of the transmit interrupt
// which is the AND product of raw interrupt state RIS.TXRIS and the mask
// setting IMSC.TXIM.
#define UART_MIS_TXMIS 0x00000020
#define UART_MIS_TXMIS_BITN 5
#define UART_MIS_TXMIS_M 0x00000020
#define UART_MIS_TXMIS_S 5
// Field: [4] RXMIS
//
// Receive masked interrupt status:
// This field returns the masked interrupt state of the receive interrupt
// which is the AND product of raw interrupt state RIS.RXRIS and the mask
// setting IMSC.RXIM.
#define UART_MIS_RXMIS 0x00000010
#define UART_MIS_RXMIS_BITN 4
#define UART_MIS_RXMIS_M 0x00000010
#define UART_MIS_RXMIS_S 4
// Field: [1] CTSMMIS
//
// Clear to Send (CTS) modem masked interrupt status:
// This field returns the masked interrupt state of the clear to send interrupt
// which is the AND product of raw interrupt state RIS.CTSRMIS and the mask
// setting IMSC.CTSMIM.
#define UART_MIS_CTSMMIS 0x00000002
#define UART_MIS_CTSMMIS_BITN 1
#define UART_MIS_CTSMMIS_M 0x00000002
#define UART_MIS_CTSMMIS_S 1
//*****************************************************************************
//
// Register: UART_O_ICR
//
//*****************************************************************************
// Field: [10] OEIC
//
// Overrun error interrupt clear:
// Writing 1 to this field clears the overrun error interrupt (RIS.OERIS).
// Writing 0 has no effect.
#define UART_ICR_OEIC 0x00000400
#define UART_ICR_OEIC_BITN 10
#define UART_ICR_OEIC_M 0x00000400
#define UART_ICR_OEIC_S 10
// Field: [9] BEIC
//
// Break error interrupt clear:
// Writing 1 to this field clears the break error interrupt (RIS.BERIS).
// Writing 0 has no effect.
#define UART_ICR_BEIC 0x00000200
#define UART_ICR_BEIC_BITN 9
#define UART_ICR_BEIC_M 0x00000200
#define UART_ICR_BEIC_S 9
// Field: [8] PEIC
//
// Parity error interrupt clear:
// Writing 1 to this field clears the parity error interrupt (RIS.PERIS).
// Writing 0 has no effect.
#define UART_ICR_PEIC 0x00000100
#define UART_ICR_PEIC_BITN 8
#define UART_ICR_PEIC_M 0x00000100
#define UART_ICR_PEIC_S 8
// Field: [7] FEIC
//
// Framing error interrupt clear:
// Writing 1 to this field clears the framing error interrupt (RIS.FERIS).
// Writing 0 has no effect.
#define UART_ICR_FEIC 0x00000080
#define UART_ICR_FEIC_BITN 7
#define UART_ICR_FEIC_M 0x00000080
#define UART_ICR_FEIC_S 7
// Field: [6] RTIC
//
// Receive timeout interrupt clear:
// Writing 1 to this field clears the receive timeout interrupt (RIS.RTRIS).
// Writing 0 has no effect.
#define UART_ICR_RTIC 0x00000040
#define UART_ICR_RTIC_BITN 6
#define UART_ICR_RTIC_M 0x00000040
#define UART_ICR_RTIC_S 6
// Field: [5] TXIC
//
// Transmit interrupt clear:
// Writing 1 to this field clears the transmit interrupt (RIS.TXRIS). Writing 0
// has no effect.
#define UART_ICR_TXIC 0x00000020
#define UART_ICR_TXIC_BITN 5
#define UART_ICR_TXIC_M 0x00000020
#define UART_ICR_TXIC_S 5
// Field: [4] RXIC
//
// Receive interrupt clear:
// Writing 1 to this field clears the receive interrupt (RIS.RXRIS). Writing 0
// has no effect.
#define UART_ICR_RXIC 0x00000010
#define UART_ICR_RXIC_BITN 4
#define UART_ICR_RXIC_M 0x00000010
#define UART_ICR_RXIC_S 4
// Field: [1] CTSMIC
//
// Clear to Send (CTS) modem interrupt clear:
// Writing 1 to this field clears the clear to send interrupt (RIS.CTSRMIS).
// Writing 0 has no effect.
#define UART_ICR_CTSMIC 0x00000002
#define UART_ICR_CTSMIC_BITN 1
#define UART_ICR_CTSMIC_M 0x00000002
#define UART_ICR_CTSMIC_S 1
//*****************************************************************************
//
// Register: UART_O_DMACTL
//
//*****************************************************************************
// Field: [2] DMAONERR
//
// DMA on error. If this bit is set to 1, the DMA receive request outputs (for
// single and burst requests) are disabled when the UART error interrupt is
// asserted (more specifically if any of the error interrupts RIS.PERIS,
// RIS.BERIS, RIS.FERIS or RIS.OERIS are asserted).
#define UART_DMACTL_DMAONERR 0x00000004
#define UART_DMACTL_DMAONERR_BITN 2
#define UART_DMACTL_DMAONERR_M 0x00000004
#define UART_DMACTL_DMAONERR_S 2
// Field: [1] TXDMAE
//
// Transmit DMA enable. If this bit is set to 1, DMA for the transmit FIFO is
// enabled.
#define UART_DMACTL_TXDMAE 0x00000002
#define UART_DMACTL_TXDMAE_BITN 1
#define UART_DMACTL_TXDMAE_M 0x00000002
#define UART_DMACTL_TXDMAE_S 1
// Field: [0] RXDMAE
//
// Receive DMA enable. If this bit is set to 1, DMA for the receive FIFO is
// enabled.
#define UART_DMACTL_RXDMAE 0x00000001
#define UART_DMACTL_RXDMAE_BITN 0
#define UART_DMACTL_RXDMAE_M 0x00000001
#define UART_DMACTL_RXDMAE_S 0
#endif // __UART__