diff options
| author | 2016-12-12 09:18:28 +1100 | |
|---|---|---|
| committer | 2017-01-11 08:35:17 +0100 | |
| commit | 2bed8a8e70729f996af92042d3ad0f11870acc1f (patch) | |
| tree | bef2d20e174c126ea18ad33cb4f7c0a9790b08a2 /net/unix/sysctl_net_unix.c | |
| parent | 8250_pci: Fix potential use-after-free in error path (diff) | |
| download | wireguard-linux-2bed8a8e70729f996af92042d3ad0f11870acc1f.tar.xz wireguard-linux-2bed8a8e70729f996af92042d3ad0f11870acc1f.zip | |
Clearing FIFOs in RS485 emulation mode causes subsequent transmits to break
When in RS485 emulation mode, __do_stop_tx_rs485() calls
serial8250_clear_fifos().  This not only clears the FIFOs, but also sets
all bits in their control register (UART_FCR) to 0.
One of the effects of this is the disabling of the FIFOs, which turns
them into single-byte holding registers.  The rest of the driver doesn't
know this, which results in the lions share of characters passed into a
write call to be dropped.
(I can supply logic analyzer screenshots if necessary)
This fix replaces the serial8250_clear_fifos() call to
serial8250_clear_and_reinit_fifos() - this prevents the "dropped
characters" issue from manifesting again while retaining the requirement
of clearing the RX FIFO after transmission if the SER_RS485_RX_DURING_TX
flag is disabled.
Signed-off-by: Daniel Jedrychowski <avistel@gmail.com>
Cc: stable <stable@vger.kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'net/unix/sysctl_net_unix.c')
0 files changed, 0 insertions, 0 deletions
