serial: fsl_lpuart: disable DMA for console and fix sysrq
authorMichael Walle <michael@walle.cc>
Wed, 12 May 2021 14:12:55 +0000 (16:12 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 20 Jul 2021 14:05:38 +0000 (16:05 +0200)
[ Upstream commit 8cac2f6eb8548245e6f8fb893fc7f2a714952654 ]

SYSRQ doesn't work with DMA. This is because there is no error
indication whether a symbol had a framing error or not. Actually,
this is not completely correct, there is a bit in the data register
which is set in this case, but we'd have to read change the DMA access
to 16 bit and we'd need to post process the data, thus make the DMA
pointless in the first place.

Signed-off-by: Michael Walle <michael@walle.cc>
Link: https://lore.kernel.org/r/20210512141255.18277-10-michael@walle.cc
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/tty/serial/fsl_lpuart.c

index 36f270261a57a832d009902f2de1b68c01ab26bb..2e74c88808db676e7fb32523b4e4b4076ba998f4 100644 (file)
@@ -1571,6 +1571,9 @@ static void lpuart_tx_dma_startup(struct lpuart_port *sport)
        u32 uartbaud;
        int ret;
 
+       if (uart_console(&sport->port))
+               goto err;
+
        if (!sport->dma_tx_chan)
                goto err;
 
@@ -1600,6 +1603,9 @@ static void lpuart_rx_dma_startup(struct lpuart_port *sport)
        int ret;
        unsigned char cr3;
 
+       if (uart_console(&sport->port))
+               goto err;
+
        if (!sport->dma_rx_chan)
                goto err;