diff options
author | Patrick Georgi <pgeorgi@chromium.org> | 2015-04-21 09:28:39 +0200 |
---|---|---|
committer | Patrick Georgi <pgeorgi@google.com> | 2015-04-21 17:49:52 +0200 |
commit | 1abb6002ddc84dd6f2dc01e76475480445fa4271 (patch) | |
tree | 7947eb726c6e54c3259fb451810f8837d84fa85a /src/soc/broadcom/cygnus | |
parent | 7ab46f8085146db57699001462da871f2e4d9965 (diff) | |
download | coreboot-1abb6002ddc84dd6f2dc01e76475480445fa4271.tar.xz |
broadcom/cygnus: Fix missing writel->write32 transformation
cygnus' serial driver wasn't part of the tree when the
big transformation was done, so follow up.
Change-Id: Ic1a53bea9bcaf1e568b50b9c2ad7782e65e36328
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Reviewed-on: http://review.coreboot.org/9852
Tested-by: build bot (Jenkins)
Reviewed-by: Stefan Reinauer <stefan.reinauer@coreboot.org>
Diffstat (limited to 'src/soc/broadcom/cygnus')
-rw-r--r-- | src/soc/broadcom/cygnus/ns16550.c | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/src/soc/broadcom/cygnus/ns16550.c b/src/soc/broadcom/cygnus/ns16550.c index d1ef843c87..3005ad2331 100644 --- a/src/soc/broadcom/cygnus/ns16550.c +++ b/src/soc/broadcom/cygnus/ns16550.c @@ -50,39 +50,39 @@ static void ns16550_init(void) { int baud_divisor = calc_divisor(); - while (!(readl(®s->lsr) & UART_LSR_TEMT)) + while (!(read32(®s->lsr) & UART_LSR_TEMT)) ; - writel(0, ®s->ier); - writel(UART_LCR_BKSE | UART_LCR_8N1, ®s->lcr); - writel(0, ®s->dll); - writel(0, ®s->dlm); - writel(UART_LCR_8N1, ®s->lcr); - writel(UART_MCR_DTR | UART_MCR_RTS, ®s->mcr); + write32(®s->ier, 0); + write32(®s->lcr, UART_LCR_BKSE | UART_LCR_8N1); + write32(®s->dll, 0); + write32(®s->dlm, 0); + write32(®s->lcr, UART_LCR_8N1); + write32(®s->mcr, UART_MCR_DTR | UART_MCR_RTS); /* clear & enable FIFOs */ - writel(UART_FCR_FIFO_EN | UART_FCR_RXSR | UART_FCR_TXSR, ®s->fcr); - writel(UART_LCR_BKSE | UART_LCR_8N1, ®s->lcr); - writel(baud_divisor & 0xff, ®s->dll); - writel((baud_divisor >> 8) & 0xff, ®s->dlm); - writel(UART_LCR_8N1, ®s->lcr); + write32(®s->fcr, UART_FCR_FIFO_EN | UART_FCR_RXSR | UART_FCR_TXSR); + write32(®s->lcr, UART_LCR_BKSE | UART_LCR_8N1); + write32(®s->dll, baud_divisor & 0xff); + write32(®s->dlm, (baud_divisor >> 8) & 0xff); + write32(®s->lcr, UART_LCR_8N1); } static void ns16550_tx_byte(unsigned char data) { - while ((readl(®s->lsr) & UART_LSR_THRE) == 0) + while ((read32(®s->lsr) & UART_LSR_THRE) == 0) ; - writel(data, ®s->thr); + write32(®s->thr, data); } static void ns16550_tx_flush(void) { - while (!(readl(®s->lsr) & UART_LSR_TEMT)) + while (!(read32(®s->lsr) & UART_LSR_TEMT)) ; } static int ns16550_tst_byte(void) { - return (readl(®s->lsr) & UART_LSR_DR) != 0; + return (read32(®s->lsr) & UART_LSR_DR) != 0; } static unsigned char ns16550_rx_byte(void) @@ -91,7 +91,7 @@ static unsigned char ns16550_rx_byte(void) while (i-- && !ns16550_tst_byte()) udelay(1); if (i) - return readl(®s->rbr); + return read32(®s->rbr); else return 0x0; } |