tty: serial: lpc32xx_hs: fix missing console boot messages
authorAlexandre Belloni <alexandre.belloni@bootlin.com>
Tue, 15 Jan 2019 17:18:14 +0000 (18:18 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 18 Jan 2019 10:23:00 +0000 (11:23 +0100)
When probing the HSUART, it is put in loopback mode in order to prevent a
potential issue that may happen on RX (Errata HSUART.1).

serial_lpc32xx_startup() moves it out of loopback mode but this is too late
to get the kernel boot messages before userspace opens the device.

Also get out of loopback mode in lpc32xx_hsuart_console_setup().

Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/lpc32xx_hs.c

index d1d7326..f4e27d0 100644 (file)
@@ -151,6 +151,8 @@ static void lpc32xx_hsuart_console_write(struct console *co, const char *s,
        local_irq_restore(flags);
 }
 
+static void lpc32xx_loopback_set(resource_size_t mapbase, int state);
+
 static int __init lpc32xx_hsuart_console_setup(struct console *co,
                                               char *options)
 {
@@ -170,6 +172,8 @@ static int __init lpc32xx_hsuart_console_setup(struct console *co,
        if (options)
                uart_parse_options(options, &baud, &parity, &bits, &flow);
 
+       lpc32xx_loopback_set(port->mapbase, 0); /* get out of loopback mode */
+
        return uart_set_options(port, co, baud, parity, bits, flow);
 }