]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
tty: serial: lpuart: fix lpuart32_write usage
authorPeng Fan <peng.fan@nxp.com>
Tue, 29 Sep 2020 09:19:20 +0000 (17:19 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Oct 2020 09:12:21 +0000 (10:12 +0100)
commit 9ea40db477c024dcb87321b7f32bd6ea12130ac2 upstream.

The 2nd and 3rd parameter were wrongly used, and cause kernel abort when
doing kgdb debug.

Fixes: 1da17d7cf8e2 ("tty: serial: fsl_lpuart: Use appropriate lpuart32_* I/O funcs")
Cc: stable <stable@vger.kernel.org>
Signed-off-by: Peng Fan <peng.fan@nxp.com>
Link: https://lore.kernel.org/r/20200929091920.22612-1-peng.fan@nxp.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/fsl_lpuart.c

index 7ca64224922410715cf13921d7393f49b67eb62f..ffaac07cccfbc96b28e87d2e17080acb0c1b66bb 100644 (file)
@@ -649,26 +649,24 @@ static int lpuart32_poll_init(struct uart_port *port)
        spin_lock_irqsave(&sport->port.lock, flags);
 
        /* Disable Rx & Tx */
-       lpuart32_write(&sport->port, UARTCTRL, 0);
+       lpuart32_write(&sport->port, 0, UARTCTRL);
 
        temp = lpuart32_read(&sport->port, UARTFIFO);
 
        /* Enable Rx and Tx FIFO */
-       lpuart32_write(&sport->port, UARTFIFO,
-                      temp | UARTFIFO_RXFE | UARTFIFO_TXFE);
+       lpuart32_write(&sport->port, temp | UARTFIFO_RXFE | UARTFIFO_TXFE, UARTFIFO);
 
        /* flush Tx and Rx FIFO */
-       lpuart32_write(&sport->port, UARTFIFO,
-                      UARTFIFO_TXFLUSH | UARTFIFO_RXFLUSH);
+       lpuart32_write(&sport->port, UARTFIFO_TXFLUSH | UARTFIFO_RXFLUSH, UARTFIFO);
 
        /* explicitly clear RDRF */
        if (lpuart32_read(&sport->port, UARTSTAT) & UARTSTAT_RDRF) {
                lpuart32_read(&sport->port, UARTDATA);
-               lpuart32_write(&sport->port, UARTFIFO, UARTFIFO_RXUF);
+               lpuart32_write(&sport->port, UARTFIFO_RXUF, UARTFIFO);
        }
 
        /* Enable Rx and Tx */
-       lpuart32_write(&sport->port, UARTCTRL, UARTCTRL_RE | UARTCTRL_TE);
+       lpuart32_write(&sport->port, UARTCTRL_RE | UARTCTRL_TE, UARTCTRL);
        spin_unlock_irqrestore(&sport->port.lock, flags);
 
        return 0;
@@ -677,7 +675,7 @@ static int lpuart32_poll_init(struct uart_port *port)
 static void lpuart32_poll_put_char(struct uart_port *port, unsigned char c)
 {
        lpuart32_wait_bit_set(port, UARTSTAT, UARTSTAT_TDRE);
-       lpuart32_write(port, UARTDATA, c);
+       lpuart32_write(port, c, UARTDATA);
 }
 
 static int lpuart32_poll_get_char(struct uart_port *port)