mirror of https://gitee.com/openkylin/qemu.git
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:
parent
194eef09d0
commit
40061ac0bc
|
@ -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:
|
||||||
|
|
|
@ -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) \
|
||||||
|
|
Loading…
Reference in New Issue