mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-10 12:57:06 +09:00
USB: serial: ftdi_sio: clean up receive processing
[ Upstream commit ce054039ba ]
Clean up receive processing by dropping the character pointer and
keeping the length argument unchanged throughout the function.
Also make it more apparent that sysrq processing can consume a
characters by adding an explicit continue.
Reviewed-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Johan Hovold <johan@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
fe34945c78
commit
e9bca40189
@@ -2040,7 +2040,6 @@ static int ftdi_process_packet(struct usb_serial_port *port,
|
||||
struct ftdi_private *priv, unsigned char *buf, int len)
|
||||
{
|
||||
unsigned char status;
|
||||
unsigned char *ch;
|
||||
int i;
|
||||
char flag;
|
||||
|
||||
@@ -2083,8 +2082,7 @@ static int ftdi_process_packet(struct usb_serial_port *port,
|
||||
else
|
||||
priv->transmit_empty = 0;
|
||||
|
||||
len -= 2;
|
||||
if (!len)
|
||||
if (len == 2)
|
||||
return 0; /* status only */
|
||||
|
||||
/*
|
||||
@@ -2113,19 +2111,20 @@ static int ftdi_process_packet(struct usb_serial_port *port,
|
||||
}
|
||||
}
|
||||
|
||||
port->icount.rx += len;
|
||||
ch = buf + 2;
|
||||
port->icount.rx += len - 2;
|
||||
|
||||
if (port->port.console && port->sysrq) {
|
||||
for (i = 0; i < len; i++, ch++) {
|
||||
if (!usb_serial_handle_sysrq_char(port, *ch))
|
||||
tty_insert_flip_char(&port->port, *ch, flag);
|
||||
for (i = 2; i < len; i++) {
|
||||
if (usb_serial_handle_sysrq_char(port, buf[i]))
|
||||
continue;
|
||||
tty_insert_flip_char(&port->port, buf[i], flag);
|
||||
}
|
||||
} else {
|
||||
tty_insert_flip_string_fixed_flag(&port->port, ch, flag, len);
|
||||
tty_insert_flip_string_fixed_flag(&port->port, buf + 2, flag,
|
||||
len - 2);
|
||||
}
|
||||
|
||||
return len;
|
||||
return len - 2;
|
||||
}
|
||||
|
||||
static void ftdi_process_read_urb(struct urb *urb)
|
||||
|
||||
Reference in New Issue
Block a user