serial: Fix send_xchar() handlers
authorPeter Hurley <peter@hurleysoftware.com>
Tue, 2 Sep 2014 21:39:15 +0000 (17:39 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 8 Sep 2014 23:22:42 +0000 (16:22 -0700)
START_CHAR() & STOP_CHAR() can be disabled if set to '\0'
(__DISABLED_CHAR).  UART drivers which define a send_xchar()
handler must not transmit __DISABLED_CHAR.

Document requirement.

Affected drivers:
sunsab
sunhv

cc: David S. Miller <davem@davemloft.net>
cc: <sparclinux@vger.kernel.org>
Signed-off-by: Peter Hurley <peter@hurleysoftware.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Documentation/serial/driver
drivers/tty/serial/sunhv.c
drivers/tty/serial/sunsab.c

index 3bba1ae..ba64e4b 100644 (file)
@@ -140,6 +140,8 @@ hardware.
        will append the character to the circular buffer and then call
        start_tx() / stop_tx() to flush the data out.
 
+       Do not transmit if ch == '\0' (__DISABLED_CHAR).
+
        Locking: none.
        Interrupts: caller dependent.
 
index 20521db..25d43ce 100644 (file)
@@ -268,6 +268,9 @@ static void sunhv_send_xchar(struct uart_port *port, char ch)
        unsigned long flags;
        int limit = 10000;
 
+       if (ch == __DISABLED_CHAR)
+               return;
+
        spin_lock_irqsave(&port->lock, flags);
 
        while (limit-- > 0) {
index b9598b2..0af75f8 100644 (file)
@@ -468,6 +468,9 @@ static void sunsab_send_xchar(struct uart_port *port, char ch)
        struct uart_sunsab_port *up = (struct uart_sunsab_port *) port;
        unsigned long flags;
 
+       if (ch == __DISABLED_CHAR)
+               return;
+
        spin_lock_irqsave(&up->port.lock, flags);
 
        sunsab_tec_wait(up);