Commit 8ae25a35 authored by Philipp Hachtmann's avatar Philipp Hachtmann Committed by Greg Kroah-Hartman

USB: symbolserial: Correct transferred data size

The scanner (here DS3508) always returns 64 bytes per urb buffer. The first
byte indicates the data length used in the current buffer. There even was
a comment describing this. But the comment also said that we'll send
everything in the buffer to the tty layer. That means sending the actual
barcode data and lots of trailing zeroes. This patch lets the driver only
send the real data.
Signed-off-by: default avatarPhilipp Hachtmann <hachti@hachti.de>
Acked-by: default avatarJohan Hovold <johan@kernel.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 951d3793
...@@ -60,17 +60,15 @@ static void symbol_int_callback(struct urb *urb) ...@@ -60,17 +60,15 @@ static void symbol_int_callback(struct urb *urb)
usb_serial_debug_data(&port->dev, __func__, urb->actual_length, data); usb_serial_debug_data(&port->dev, __func__, urb->actual_length, data);
if (urb->actual_length > 1) {
data_length = urb->actual_length - 1;
/* /*
* Data from the device comes with a 1 byte header: * Data from the device comes with a 1 byte header:
* *
* <size of data>data... * <size of data> <data>...
* This is real data to be sent to the tty layer
* we pretty much just ignore the size and send everything
* else to the tty layer.
*/ */
if (urb->actual_length > 1) {
data_length = data[0];
if (data_length > (urb->actual_length - 1))
data_length = urb->actual_length - 1;
tty_insert_flip_string(&port->port, &data[1], data_length); tty_insert_flip_string(&port->port, &data[1], data_length);
tty_flip_buffer_push(&port->port); tty_flip_buffer_push(&port->port);
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment