aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/tty/serial/xilinx_uartps.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/tty/serial/xilinx_uartps.c b/drivers/tty/serial/xilinx_uartps.c
index 2c98c357d9a0..6a7cd4e057ae 100644
--- a/drivers/tty/serial/xilinx_uartps.c
+++ b/drivers/tty/serial/xilinx_uartps.c
@@ -512,7 +512,7 @@ static void cdns_uart_start_tx(struct uart_port *port)
512{ 512{
513 unsigned int status, numbytes = port->fifosize; 513 unsigned int status, numbytes = port->fifosize;
514 514
515 if (uart_circ_empty(&port->state->xmit) || uart_tx_stopped(port)) 515 if (uart_tx_stopped(port))
516 return; 516 return;
517 517
518 /* 518 /*
@@ -524,6 +524,9 @@ static void cdns_uart_start_tx(struct uart_port *port)
524 status |= CDNS_UART_CR_TX_EN; 524 status |= CDNS_UART_CR_TX_EN;
525 writel(status, port->membase + CDNS_UART_CR_OFFSET); 525 writel(status, port->membase + CDNS_UART_CR_OFFSET);
526 526
527 if (uart_circ_empty(&port->state->xmit))
528 return;
529
527 while (numbytes-- && ((readl(port->membase + CDNS_UART_SR_OFFSET) & 530 while (numbytes-- && ((readl(port->membase + CDNS_UART_SR_OFFSET) &
528 CDNS_UART_SR_TXFULL)) != CDNS_UART_SR_TXFULL) { 531 CDNS_UART_SR_TXFULL)) != CDNS_UART_SR_TXFULL) {
529 /* Break if no more data available in the UART buffer */ 532 /* Break if no more data available in the UART buffer */