mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-03-06 03:32:05 +00:00
USB: ftdi_sio: Keep going when write errors are encountered.
The use of urb->actual_length to update tx_outstanding_bytes implicitly assumes that the number of bytes actually written is the same as the number of bytes we tried to write. On error that assumption is violated so just use transfer_buffer_length the number of bytes we intended to write to the device. If an error occurs we need to fall through and call usb_serial_port_softint to wake up processes waiting in tty_wait_until_sent. Signed-off-by: Eric W. Biederman <ebiederm@aristanetworks.com> Cc: stable <stable@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
cea83241b3
commit
0de6ab8b91
@ -1937,7 +1937,7 @@ static void ftdi_write_bulk_callback(struct urb *urb)
|
||||
return;
|
||||
}
|
||||
/* account for transferred data */
|
||||
countback = urb->actual_length;
|
||||
countback = urb->transfer_buffer_length;
|
||||
data_offset = priv->write_offset;
|
||||
if (data_offset > 0) {
|
||||
/* Subtract the control bytes */
|
||||
@ -1950,7 +1950,6 @@ static void ftdi_write_bulk_callback(struct urb *urb)
|
||||
|
||||
if (status) {
|
||||
dbg("nonzero write bulk status received: %d", status);
|
||||
return;
|
||||
}
|
||||
|
||||
usb_serial_port_softint(port);
|
||||
|
Loading…
x
Reference in New Issue
Block a user