uartpsv
Vitis Drivers API Documentation
|
Macros | |
#define | XUARTPSV_HW_H |
by using protection macros More... | |
#define | XUartPsv_ReadReg(BaseAddress, RegOffset) Xil_In32((BaseAddress) + (u32)(RegOffset)) |
Read a UART register. More... | |
#define | XUartPsv_WriteReg(BaseAddress, RegOffset, RegisterValue) |
Write a UART register. More... | |
#define | XUartPsv_IsReceiveData(BaseAddress) |
Determine if there is receive data in the receiver and/or FIFO. More... | |
#define | XUartPsv_IsTransmitFull(BaseAddress) |
Determine if a byte of data can be sent with the transmitter. More... | |
#define | XUartPsv_IsTransmitbusy(BaseAddress) |
Determine if a byte of data can be sent with the transmitter. More... | |
Register Map | |
Register offsets for the UART. | |
#define | XUARTPSV_UARTDR_OFFSET 0x0000U |
Data. More... | |
#define | XUARTPSV_UARTRSR_OFFSET 0x0004U |
Receive Status Register/Error Clear. More... | |
#define | XUARTPSV_UARTFR_OFFSET 0x0018U |
Flag Register. More... | |
#define | XUARTPSV_UARTILPR_OFFSET 0x0020U |
IrDA Low-Power Counter. More... | |
#define | XUARTPSV_UARTIBRD_OFFSET 0x0024U |
Integer Baud Rate. More... | |
#define | XUARTPSV_UARTFBRD_OFFSET 0x0028U |
Fractional Baud Rate. More... | |
#define | XUARTPSV_UARTLCR_OFFSET 0x002CU |
Line Control. More... | |
#define | XUARTPSV_UARTCR_OFFSET 0x0030U |
Control. More... | |
#define | XUARTPSV_UARTIFLS_OFFSET 0x0034U |
Interrupt FIFO Level Select. More... | |
#define | XUARTPSV_UARTIMSC_OFFSET 0x0038U |
Interrupt Mask Set/Clear. More... | |
#define | XUARTPSV_UARTRIS_OFFSET 0x003CU |
Raw interrupt Status. More... | |
#define | XUARTPSV_UARTMIS_OFFSET 0x0040U |
Mask interrupt Status. More... | |
#define | XUARTPSV_UARTICR_OFFSET 0x0044U |
Interrupt Clear. More... | |
#define | XUARTPSV_UARTDMACR_OFFSET 0x0048U |
DMA Control. More... | |
Receive status register/error clear register | |
The Receive status register/error clear register (UARTRSR) gives the status of break, frame, parity and overrun. Receive status register/error clear register Bit Definition | |
#define | XUARTPSV_UARTRSR_OE 0x00000008U |
Overrun error. More... | |
Flag Register | |
The Flag register (UARTFR) Flag Register Bit Definition | |
#define | XUARTPSV_UARTFR_RI 0x00000100U |
Ring indicator. More... | |
#define | XUARTPSV_UARTFR_TXFE 0x00000080U |
Transmit FIFO empty. More... | |
#define | XUARTPSV_UARTFR_RXFF 0x00000040U |
Receive FIFO full. More... | |
#define | XUARTPSV_UARTFR_TXFF 0x00000020U |
Transmit FIFO full. More... | |
#define | XUARTPSV_UARTFR_RXFE 0x00000010U |
Receive FIFO empty. More... | |
#define | XUARTPSV_UARTFR_BUSY 0x00000008U |
UART Busy. More... | |
#define | XUARTPSV_UARTFR_DCD 0x00000004U |
Data carrier detect. More... | |
#define | XUARTPSV_UARTFR_DSR 0x00000002U |
Data set ready. More... | |
#define | XUARTPSV_UARTFR_CTS 0x00000001U |
Clear to send. More... | |
Line Control Register | |
The Line Control register (UARTLCR) controls the functions of the device. Line Control Register Bit Definition | |
#define | XUARTPSV_UARTLCR_SPS 0x00000080U |
Stick parity select. More... | |
#define | XUARTPSV_UARTLCR_FEN 0x00000010U |
Enable FIFOs. More... | |
#define | XUARTPSV_UARTLCR_STP2 0x00000008U |
Two stop bits selected. More... | |
#define | XUARTPSV_UARTLCR_EPS 0x00000004U |
Even parity select. More... | |
#define | XUARTPSV_UARTLCR_PEN 0x00000002U |
Parity enable. More... | |
#define | XUARTPSV_UARTLCR_BRK 0x00000001U |
Send break. More... | |
#define | XUARTPSV_UARTLCR_WLEN_MASK 0x00000060U |
Word length mask. More... | |
#define | XUARTPSV_UARTLCR_WLEN_SHIFT 0x00000005U |
Word length shift. More... | |
#define | XUARTPSV_UARTLCR_WLEN_5_BIT 0x00000000U |
5 bits data More... | |
#define | XUARTPSV_UARTLCR_WLEN_6_BIT 0x00000020U |
6 bits data More... | |
#define | XUARTPSV_UARTLCR_WLEN_7_BIT 0x00000040U |
7 bits data More... | |
#define | XUARTPSV_UARTLCR_WLEN_8_BIT 0x00000060U |
8 bits data More... | |
#define | XUARTPSV_UARTLCR_STP_1_BIT 0x00000000U |
One stop bits selected. More... | |
#define | XUARTPSV_UARTLCR_STP_MASK 0x00000008U |
Stop bits mask. More... | |
#define | XUARTPSV_UARTLCR_STP_SHIFT 0x00000003U |
Stop bits shift. More... | |
#define | XUARTPSV_UARTLCR_PARITY_EVEN 0x00000004U |
Even parity mode. More... | |
#define | XUARTPSV_UARTLCR_PARITY_MASK 0x00000002U |
Parity mask. More... | |
#define | XUARTPSV_UARTLCR_PARITY_SHIFT 0x00000001U |
Parity shift. More... | |
#define | XUARTPSV_UARTLCR_PARITY_NONE 0x00000000U |
No parity mode. More... | |
#define | XUARTPSV_UARTLCR_PARITY_ODD 0x00000000U |
Odd parity mode. More... | |
Control Register | |
The Control register (UARTCR) controls the major functions of the device. Control Register Bit Definition | |
#define | XUARTPSV_UARTCR_CTSEN 0x00008000U |
CTS hardware flow control enable. More... | |
#define | XUARTPSV_UARTCR_RTSEN 0x00004000U |
RTS hardware flow control enable. More... | |
#define | XUARTPSV_UARTCR_OUT2 0x00002000U |
UART Out2 modem status output. More... | |
#define | XUARTPSV_UARTCR_OUT1 0x00001000U |
UART Out1 modem status output. More... | |
#define | XUARTPSV_UARTCR_RTS 0x00000800U |
Request to send. More... | |
#define | XUARTPSV_UARTCR_DTR 0x00000400U |
Data transmit ready. More... | |
#define | XUARTPSV_UARTCR_RXE 0x00000200U |
Receive enable. More... | |
#define | XUARTPSV_UARTCR_TXE 0x00000100U |
Transmit enable. More... | |
#define | XUARTPSV_UARTCR_LBE 0x00000080U |
Loop back enable. More... | |
#define | XUARTPSV_UARTCR_SIRLP 0x00000004U |
SIR low-power IrDA mode. More... | |
#define | XUARTPSV_UARTCR_SIREN 0x00000002U |
SIR enable. More... | |
#define | XUARTPSV_UARTCR_UARTEN 0x00000001U |
UART enable. More... | |
#define | XUARTPSV_UARTCR_MODE_MASK 0x00000080U |
Mode mask. More... | |
#define | XUARTPSV_UARTCR_MODE_SHIFT 0x00000007U |
Mode shift. More... | |
#define | XUARTPSV_UARTCR_MODE_NORMAL 0x00000000U |
Normal Mode. More... | |
Interrupt FIFO Level Select Register | |
The UARTIFLS Register is the interrupt FIFO level select register. You can use this register to define the FIFO level that triggers the assertion of UARTTXINTR and UARTRXINTR. Interrupt FIFO Level Select Register Register Bit Definition | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_MASK 0x00000038U |
Receive interrupt FIFO level select mask. More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_SHIFT 0x00000003U |
Transmit interrupt FIFO level select shift. More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_MASK 0x00000007U |
Receive interrupt FIFO level select mask. More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_SHIFT 0x00000000U |
Transmit interrupt FIFO level select shift. More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_1_8 0x00000000U |
Receive FIFO becomes . More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_1_4 0x00000008U |
Receive FIFO becomes . More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_1_2 0x00000010U |
Receive FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_3_4 0x00000018U |
Receive FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_RXIFLSEL_7_8 0x00000020U |
Receive FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_1_8 0x00000000U |
Transmit FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_1_4 0x00000001U |
Transmit FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_1_2 0x00000002U |
Transmit FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_3_4 0x00000003U |
Transmit FIFO becomes * . More... | |
#define | XUARTPSV_UARTIFLS_TXIFLSEL_7_8 0x00000004U |
Transmit FIFO becomes * . More... | |
Interrupt Mask Set/Clear Register | |
The UARTIMSC Register is the interrupt mask set/clear register. It is a read/write register. On a read this register returns the current value of the mask on the relevant interrupt. On a write of 1 to the particular bit, it sets the corresponding mask of that interrupt. A write of 0 clears the corresponding mask. Interrupt Mask Set/Clear Register Bit Definition | |
#define | XUARTPSV_UARTIMSC_OEIM 0x00000400U |
Overrun Error Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_BEIM 0x00000200U |
Break Error Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_PEIM 0x00000100U |
Parity Error Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_FEIM 0x00000080U |
Framing Error Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_RTIM 0x00000040U |
Receive Timeout Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_TXIM 0x00000020U |
Transmit Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_RXIM 0x00000010U |
Receive Interrupt. More... | |
#define | XUARTPSV_UARTIMSC_DSRMIM 0x00000008U |
nUARTDSR modem interrupt More... | |
#define | XUARTPSV_UARTIMSC_DCDMIM 0x00000004U |
nUARTDCD modem interrupt More... | |
#define | XUARTPSV_UARTIMSC_CTSMIM 0x00000002U |
nUARTCTS modem interrupt More... | |
#define | XUARTPSV_UARTIMSC_RIMIM 0x00000001U |
nUARTRI modem interrupt More... | |
#define | XUARTPSV_UARTIMSC_MASK 0x000007FFU |
Valid bit mask. More... | |
Raw Interrupt Status Register | |
The raw interrupt status register (UARTRIS) is a read-only register. This register returns the current raw status value, prior to masking, of the corresponding interrupt. A write has no effect. Raw Interrupt Status Register Bit Definition | |
#define | XUARTPSV_UARTRIS_OERIS 0x00000400U |
Overrun Error Interrupt. More... | |
#define | XUARTPSV_UARTRIS_BERIS 0x00000200U |
Break Error Interrupt. More... | |
#define | XUARTPSV_UARTRIS_PERIS 0x00000100U |
Parity Error Interrupt. More... | |
#define | XUARTPSV_UARTRIS_FERIS 0x00000080U |
Framing Error Interrupt. More... | |
#define | XUARTPSV_UARTRIS_RTRIS 0x00000040U |
Receive Timeout Interrupt. More... | |
#define | XUARTPSV_UARTRIS_TXRIS 0x00000020U |
Transmit Interrupt. More... | |
#define | XUARTPSV_UARTRIS_RXRIS 0x00000010U |
Receive Interrupt. More... | |
#define | XUARTPSV_UARTRIS_DSRRMIS 0x00000008U |
nUARTDSR modem interrupt More... | |
#define | XUARTPSV_UARTRIS_DCDRMIS 0x00000004U |
nUARTDCD modem interrupt More... | |
#define | XUARTPSV_UARTRIS_CTSRMIS 0x00000002U |
nUARTCTS modem interrupt More... | |
#define | XUARTPSV_UARTRIS_RIRMIS 0x00000001U |
nUARTRI modem interrupt More... | |
Masked Interrupt Status Register | |
The UARTMIS Register is the masked interrupt status register. It is a read-only register. This register returns the current masked status value of the corresponding interrupt. A write has no effect. Masked Interrupt Status Register Bit Definition | |
#define | XUARTPSV_UARTMIS_OEMIS 0x00000400U |
Overrun Error Interrupt. More... | |
#define | XUARTPSV_UARTMIS_BEMIS 0x00000200U |
Break Error Interrupt. More... | |
#define | XUARTPSV_UARTMIS_PEMIS 0x00000100U |
Parity Error Interrupt. More... | |
#define | XUARTPSV_UARTMIS_FEMIS 0x00000080U |
Framing Error Interrupt. More... | |
#define | XUARTPSV_UARTMIS_RTMIS 0x00000040U |
Receive Timeout Interrupt. More... | |
#define | XUARTPSV_UARTMIS_TXMIS 0x00000020U |
Transmit Interrupt. More... | |
#define | XUARTPSV_UARTMIS_RXMIS 0x00000010U |
Receive Interrupt. More... | |
#define | XUARTPSV_UARTMIS_DSRMMIS 0x00000008U |
nUARTDSR modem interrupt More... | |
#define | XUARTPSV_UARTMIS_DCDMMIS 0x00000004U |
nUARTDCD modem interrupt More... | |
#define | XUARTPSV_UARTMIS_CTSMMIS 0x00000002U |
nUARTCTS modem interrupt More... | |
#define | XUARTPSV_UARTMIS_RIRMMIS 0x00000001U |
nUARTRI modem interrupt More... | |
Interrupt Clear Register | |
The UARTICR Register is the interrupt clear register and is write-only. On a write of 1, the corresponding interrupt is cleared. A write of 0 has no effect. Interrupt Clear Register Bit Definition | |
#define | XUARTPSV_UARTICR_OEIC 0x00000400U |
Overrun Error Interrupt. More... | |
#define | XUARTPSV_UARTICR_BEIC 0x00000200U |
Break Error Interrupt. More... | |
#define | XUARTPSV_UARTICR_PEIC 0x00000100U |
Parity Error Interrupt. More... | |
#define | XUARTPSV_UARTICR_FEIC 0x00000080U |
Framing Error Interrupt. More... | |
#define | XUARTPSV_UARTICR_RTIC 0x00000040U |
Receive Timeout Interrupt. More... | |
#define | XUARTPSV_UARTICR_TXIC 0x00000020U |
Transmit Interrupt. More... | |
#define | XUARTPSV_UARTICR_RXIC 0x00000010U |
Receive Interrupt. More... | |
#define | XUARTPSV_UARTICR_DSRMIC 0x00000008U |
nUARTDSR modem interrupt More... | |
#define | XUARTPSV_UARTICR_DCDMIC 0x00000004U |
nUARTDCD modem interrupt More... | |
#define | XUARTPSV_UARTICR_CTSMIC 0x00000002U |
nUARTCTS modem interrupt More... | |
#define | XUARTPSV_UARTICR_RIMIC 0x00000001U |
nUARTRI modem interrupt More... | |
DMA Control Register | |
The UARTDMACR Register is the DMA control register. It is a read/write register. All the bits are cleared to 0 on reset. DMA Control Register Bit Definition | |
#define | XUARTPSV_UARTDMACR_DMAONERR 0x00000004U |
DMA on error. More... | |
#define | XUARTPSV_UARTDMACR_TXDMAE 0x00000002U |
Transmit DMA enable. More... | |
#define | XUARTPSV_UARTDMACR_RXDMAE 0x00000001U |
Receive DMA enable. More... | |
Integer Baud Rate Register | |
The UARTIBRD Register is the integer part of the baud rate divisor value | |
#define | XUARTPSV_UARTIBRD_BAUD_DIVINT_MASK 0x0000FFFFU |
16 UARTIBRD bit mask More... | |
#define | XUARTPSV_UARTIBRD_BAUD_DIVINT_RESET_VAL 0x00000000U |
Reset value. More... | |
Fractional Baud Rate Register | |
The UARTFBRD Register is the fractional part of the baud rate divisor value Baud rate divisor BAUDDIV = (FUARTCLK/(16xBaud rate)) where FUARTCLK is the UART reference clock frequency The BAUDDIV is comprised of the integer value (BAUD DIVINT) and the fractional value (BAUD DIVFRAC) | |
#define | XUARTPSV_UARTFBRD_BAUD_DIVFRAC_MASK 0x0000003FU |
6 UARTFBRD bit mask More... | |
#define | XUARTPSV_UARTFBRD_BAUD_DIVFRAC_RESET_VAL 0x00000000U |
Reset value. More... | |
Receiver Timeout Register | |
Use the receiver timeout register (RTR) to detect an idle condition on the receiver data line. | |
#define | XUARTPSV_RXTOUT_DISABLE 0x00000000U |
Disable time out. More... | |
#define | XUARTPSV_RXTOUT_MASK 0x000000FFU |
Valid bits mask. More... | |
Receiver FIFO Trigger Level Register | |
Use the Receiver FIFO Trigger Level Register (RTRIG) to set the value at which the RX FIFO triggers an interrupt event. | |
#define | XUARTPSV_RXWM_DISABLE 0x00000000U |
Disable RX trigger interrupt. More... | |
#define | XUARTPSV_RXWM_MASK 0x0000003FU |
Valid bits mask. More... | |
#define | XUARTPSV_RXWM_RESET_VAL 0x00000020U |
Reset value. More... | |
Transmit FIFO Trigger Level Register | |
Use the Transmit FIFO Trigger Level Register (TTRIG) to set the value at which the TX FIFO triggers an interrupt event. | |
#define | XUARTPSV_TXWM_MASK 0x0000003FU |
Valid bits mask. More... | |
#define | XUARTPSV_TXWM_RESET_VAL 0x00000020U |
Reset value. More... | |
Modem Control Register | |
This register (MODEMCR) controls the interface with the modem or data set, or a peripheral device emulating a modem. | |
#define | XUARTPSV_MODEMCR_FCM 0x00000010U |
Flow control mode. More... | |
#define | XUARTPSV_MODEMCR_RTS 0x00000002U |
Request to send. More... | |
#define | XUARTPSV_MODEMCR_DTR 0x00000001U |
Data terminal ready. More... | |
Modem Status Register | |
This register (MODEMSR) indicates the current state of the control lines from a modem, or another peripheral device, to the CPU. In addition, four bits of the modem status register provide change information. These bits are set to a logic 1 whenever a control input from the modem changes state. Note: Whenever the DCTS, DDSR, TERI, or DDCD bit is set to logic 1, a modem status interrupt is generated and this is reflected in the modem status register. | |
#define | XUARTPSV_MODEMSR_FCMS 0x00000100U |
Flow control mode (FCMS) More... | |
#define | XUARTPSV_MODEMSR_DCD 0x00000080U |
Complement of DCD input. More... | |
#define | XUARTPSV_MODEMSR_RI 0x00000040U |
Complement of RI input. More... | |
#define | XUARTPSV_MODEMSR_DSR 0x00000020U |
Complement of DSR input. More... | |
#define | XUARTPSV_MODEMSR_CTS 0x00000010U |
Complement of CTS input. More... | |
#define | XUARTPSV_MODEMSR_DDCD 0x00000008U |
Delta DCD indicator. More... | |
#define | XUARTPSV_MODEMSR_TERI 0x00000004U |
Trailing Edge Ring Indicator. More... | |
#define | XUARTPSV_MODEMSR_DDSR 0x00000002U |
Change of DSR. More... | |
#define | XUARTPSV_MODEMSR_DCTS 0x00000001U |
Change of CTS. More... | |
Flow Delay Register | |
Operation of the flow delay register (FLOWDEL) is very similar to the receive FIFO trigger register. An internal trigger signal activates when the FIFO is filled to the level set by this register. This trigger will not cause an interrupt, although it can be read through the channel status register. In hardware flow control mode, RTS is deactivated when the trigger becomes active. RTS only resets when the FIFO level is four less than the level of the flow delay trigger and the flow delay trigger is not activated. A value less than 4 disables the flow delay. | |
#define | XUARTPSV_FLOWDEL_MASK XUARTPSV_RXWM_MASK |
Valid bit mask. More... | |
Receiver FIFO Byte Status Register | |
The Receiver FIFO Status register is used to have a continuous monitoring of the raw unmasked byte status information. The register contains frame, parity and break status information for the top four bytes in the RX FIFO. Receiver FIFO Byte Status Register Bit Definition | |
#define | XUARTPSV_RXBS_BYTE3_BRKE 0x00000800U |
Byte3 Break Error. More... | |
#define | XUARTPSV_RXBS_BYTE3_FRME 0x00000400U |
Byte3 Frame Error. More... | |
#define | XUARTPSV_RXBS_BYTE3_PARE 0x00000200U |
Byte3 Parity Error. More... | |
#define | XUARTPSV_RXBS_BYTE2_BRKE 0x00000100U |
Byte2 Break Error. More... | |
#define | XUARTPSV_RXBS_BYTE2_FRME 0x00000080U |
Byte2 Frame Error. More... | |
#define | XUARTPSV_RXBS_BYTE2_PARE 0x00000040U |
Byte2 Parity Error. More... | |
#define | XUARTPSV_RXBS_BYTE1_BRKE 0x00000020U |
Byte1 Break Error. More... | |
#define | XUARTPSV_RXBS_BYTE1_FRME 0x00000010U |
Byte1 Frame Error. More... | |
#define | XUARTPSV_RXBS_BYTE1_PARE 0x00000008U |
Byte1 Parity Error. More... | |
#define | XUARTPSV_RXBS_BYTE0_BRKE 0x00000004U |
Byte0 Break Error. More... | |
#define | XUARTPSV_RXBS_BYTE0_FRME 0x00000002U |
Byte0 Frame Error. More... | |
#define | XUARTPSV_RXBS_BYTE0_PARE 0x00000001U |
Byte0 Parity Error. More... | |
#define | XUARTPSV_RXBS_MASK 0x0000000FU |
3 bit RX byte status mask More... | |
Functions | |
void | XUartPsv_SendByte (UINTPTR BaseAddress, u8 Data) |
This function sends one byte using the device. More... | |
u8 | XUartPsv_RecvByte (UINTPTR BaseAddress) |
This function receives a byte from the device. More... | |
void | XUartPsv_ResetHw (UINTPTR BaseAddress) |
This function resets UART. More... | |