summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--c/src/lib/libbsp/or1k/or1ksim/console/uart.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/c/src/lib/libbsp/or1k/or1ksim/console/uart.c b/c/src/lib/libbsp/or1k/or1ksim/console/uart.c
index f1cfa0985f..7ceca816a5 100644
--- a/c/src/lib/libbsp/or1k/or1ksim/console/uart.c
+++ b/c/src/lib/libbsp/or1k/or1ksim/console/uart.c
@@ -86,9 +86,18 @@ static int uart_last_close(int major, int minor, void *arg)
return 0;
}
-static int uart_read_polled(int minor)
+static char uart_read_polled(int minor)
{
- return -1;
+ unsigned char lsr;
+ char c;
+
+ /* Get a character when avaiable */
+ do {
+ lsr = OR1KSIM_REG(OR1KSIM_BSP_UART_REG_LINE_STATUS);
+ } while ((lsr & OR1KSIM_BSP_UART_REG_LINE_STATUS_DR)
+ != OR1KSIM_BSP_UART_REG_LINE_STATUS_DR);
+
+ return OR1KSIM_REG(OR1KSIM_BSP_UART_REG_RX);
}
static void uart_write_polled(int minor, char c)