Skip to content

Commit 74b8fc0

Browse files
rgenoudgregkh
authored andcommitted
tty/serial: atmel: fix race condition (TX+DMA)
commit 31ca2c63fdc0aee725cbd4f207c1256f5deaabde upstream. If uart_flush_buffer() is called between atmel_tx_dma() and atmel_complete_tx_dma(), the circular buffer has been cleared, but not atmel_port->tx_len. That leads to a circular buffer overflow (dumping (UART_XMIT_SIZE - atmel_port->tx_len) bytes). Tested-by: Nicolas Ferre <nicolas.ferre@microchip.com> Signed-off-by: Richard Genoud <richard.genoud@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 566a871 commit 74b8fc0

1 file changed

Lines changed: 5 additions & 0 deletions

File tree

drivers/tty/serial/atmel_serial.c

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1987,6 +1987,11 @@ static void atmel_flush_buffer(struct uart_port *port)
19871987
atmel_uart_writel(port, ATMEL_PDC_TCR, 0);
19881988
atmel_port->pdc_tx.ofs = 0;
19891989
}
1990+
/*
1991+
* in uart_flush_buffer(), the xmit circular buffer has just
1992+
* been cleared, so we have to reset tx_len accordingly.
1993+
*/
1994+
atmel_port->tx_len = 0;
19901995
}
19911996

19921997
/*

0 commit comments

Comments
 (0)