diff options
author | Tobias Klauser <tklauser@distanz.ch> | 2010-05-25 11:00:08 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-06-04 16:37:18 -0400 |
commit | fadf34f0f05ca5ea02ffcd89544cd372bbdb739b (patch) | |
tree | 741ccde7886e05a0e6b0d21fd144453124af78e8 /drivers/serial/altera_uart.c | |
parent | d8d721f4c005f9a69bd1b5d5c6ba99b7e1d464de (diff) |
altera_uart: Simplify altera_uart_console_putc
The check for the TRDY flag after writing the character is not needed.
Also do a cpu_relax() inside the loop.
Pass a struct uart_port to altera_uart_console_putc, so we do not need
to get it (and dereference pointers) for every character.
Cc: Thomas Chou <thomas@wytron.com.tw>
Signed-off-by: Tobias Klauser <tklauser@distanz.ch>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/serial/altera_uart.c')
-rw-r--r-- | drivers/serial/altera_uart.c | 23 |
1 files changed, 8 insertions, 15 deletions
diff --git a/drivers/serial/altera_uart.c b/drivers/serial/altera_uart.c index b1609cca0ec4..7d6afc9755d5 100644 --- a/drivers/serial/altera_uart.c +++ b/drivers/serial/altera_uart.c | |||
@@ -391,31 +391,24 @@ int __init early_altera_uart_setup(struct altera_uart_platform_uart *platp) | |||
391 | return 0; | 391 | return 0; |
392 | } | 392 | } |
393 | 393 | ||
394 | static void altera_uart_console_putc(struct console *co, const char c) | 394 | static void altera_uart_console_putc(struct uart_port *port, const char c) |
395 | { | 395 | { |
396 | struct uart_port *port = &(altera_uart_ports + co->index)->port; | 396 | while (!(readl(port->membase + ALTERA_UART_STATUS_REG) & |
397 | int i; | 397 | ALTERA_UART_STATUS_TRDY_MSK)) |
398 | cpu_relax(); | ||
398 | 399 | ||
399 | for (i = 0; i < 0x10000; i++) { | ||
400 | if (readl(port->membase + ALTERA_UART_STATUS_REG) & | ||
401 | ALTERA_UART_STATUS_TRDY_MSK) | ||
402 | break; | ||
403 | } | ||
404 | writel(c, port->membase + ALTERA_UART_TXDATA_REG); | 400 | writel(c, port->membase + ALTERA_UART_TXDATA_REG); |
405 | for (i = 0; i < 0x10000; i++) { | ||
406 | if (readl(port->membase + ALTERA_UART_STATUS_REG) & | ||
407 | ALTERA_UART_STATUS_TRDY_MSK) | ||
408 | break; | ||
409 | } | ||
410 | } | 401 | } |
411 | 402 | ||
412 | static void altera_uart_console_write(struct console *co, const char *s, | 403 | static void altera_uart_console_write(struct console *co, const char *s, |
413 | unsigned int count) | 404 | unsigned int count) |
414 | { | 405 | { |
406 | struct uart_port *port = &(altera_uart_ports + co->index)->port; | ||
407 | |||
415 | for (; count; count--, s++) { | 408 | for (; count; count--, s++) { |
416 | altera_uart_console_putc(co, *s); | 409 | altera_uart_console_putc(port, *s); |
417 | if (*s == '\n') | 410 | if (*s == '\n') |
418 | altera_uart_console_putc(co, '\r'); | 411 | altera_uart_console_putc(port, '\r'); |
419 | } | 412 | } |
420 | } | 413 | } |
421 | 414 | ||