]> git.karo-electronics.de Git - mv-sheeva.git/blobdiff - drivers/serial/imx.c
Merge branch 'master' into csb1725
[mv-sheeva.git] / drivers / serial / imx.c
index 66ecc7ab6daba803c5c74f8fa06a6a6b105b8f8c..dfcf4b1878aa3f2596fc9d6a8ffa21722bb2224e 100644 (file)
@@ -327,14 +327,13 @@ static inline void imx_transmit_buffer(struct imx_port *sport)
 {
        struct circ_buf *xmit = &sport->port.state->xmit;
 
-       while (!(readl(sport->port.membase + UTS) & UTS_TXFULL)) {
+       while (!uart_circ_empty(xmit) &&
+                       !(readl(sport->port.membase + UTS) & UTS_TXFULL)) {
                /* send xmit->buf[xmit->tail]
                 * out the port here */
                writel(xmit->buf[xmit->tail], sport->port.membase + URTX0);
                xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1);
                sport->port.icount.tx++;
-               if (uart_circ_empty(xmit))
-                       break;
        }
 
        if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS)