sifive_uart: Implement interrupt pending register

The watermark bits are set in the interrupt pending register according
to the configuration of txcnt and rxcnt in the txctrl and rxctrl
registers.

Since the UART TX does not implement a FIFO, the txwm bit is set as long
as the TX watermark level is greater than zero.

Signed-off-by: Nathaniel Graff <nathaniel.graff@sifive.com>
Reviewed-by: Michael Clark <mjc@sifive.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
This commit is contained in:
Nathaniel Graff 2018-12-14 00:19:12 +00:00 committed by Palmer Dabbelt
parent 194eef09d0
commit 40061ac0bc
No known key found for this signature in database
GPG Key ID: EF4CA1502CCBAB41
2 changed files with 22 additions and 5 deletions

View File

@ -28,12 +28,26 @@
* Not yet implemented: * Not yet implemented:
* *
* Transmit FIFO using "qemu/fifo8.h" * Transmit FIFO using "qemu/fifo8.h"
* SIFIVE_UART_IE_TXWM interrupts
* SIFIVE_UART_IE_RXWM interrupts must honor fifo watermark
* Rx FIFO watermark interrupt trigger threshold
* Tx FIFO watermark interrupt trigger threshold.
*/ */
/* Returns the state of the IP (interrupt pending) register */
static uint64_t uart_ip(SiFiveUARTState *s)
{
uint64_t ret = 0;
uint64_t txcnt = SIFIVE_UART_GET_TXCNT(s->txctrl);
uint64_t rxcnt = SIFIVE_UART_GET_RXCNT(s->rxctrl);
if (txcnt != 0) {
ret |= SIFIVE_UART_IP_TXWM;
}
if (s->rx_fifo_len > rxcnt) {
ret |= SIFIVE_UART_IP_RXWM;
}
return ret;
}
static void update_irq(SiFiveUARTState *s) static void update_irq(SiFiveUARTState *s)
{ {
int cond = 0; int cond = 0;
@ -69,7 +83,7 @@ uart_read(void *opaque, hwaddr addr, unsigned int size)
case SIFIVE_UART_IE: case SIFIVE_UART_IE:
return s->ie; return s->ie;
case SIFIVE_UART_IP: case SIFIVE_UART_IP:
return s->rx_fifo_len ? SIFIVE_UART_IP_RXWM : 0; return uart_ip(s);
case SIFIVE_UART_TXCTRL: case SIFIVE_UART_TXCTRL:
return s->txctrl; return s->txctrl;
case SIFIVE_UART_RXCTRL: case SIFIVE_UART_RXCTRL:

View File

@ -43,6 +43,9 @@ enum {
SIFIVE_UART_IP_RXWM = 2 /* Receive watermark interrupt pending */ SIFIVE_UART_IP_RXWM = 2 /* Receive watermark interrupt pending */
}; };
#define SIFIVE_UART_GET_TXCNT(txctrl) ((txctrl >> 16) & 0x7)
#define SIFIVE_UART_GET_RXCNT(rxctrl) ((rxctrl >> 16) & 0x7)
#define TYPE_SIFIVE_UART "riscv.sifive.uart" #define TYPE_SIFIVE_UART "riscv.sifive.uart"
#define SIFIVE_UART(obj) \ #define SIFIVE_UART(obj) \