From 9f70a0f15cb41f77c8b678f9d5d52ef3c499b298 Mon Sep 17 00:00:00 2001 From: Nicolas Thill Date: Sun, 2 Sep 2007 14:18:28 +0000 Subject: [PATCH] add high-speed usb serial fix from Junxion to 2.4 kernel too (closes: #2274) SVN-Revision: 8573 --- .../801-usb_serial_endpoint_size.patch | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 target/linux/generic-2.4/patches/801-usb_serial_endpoint_size.patch diff --git a/target/linux/generic-2.4/patches/801-usb_serial_endpoint_size.patch b/target/linux/generic-2.4/patches/801-usb_serial_endpoint_size.patch new file mode 100644 index 0000000000..b0d5facc44 --- /dev/null +++ b/target/linux/generic-2.4/patches/801-usb_serial_endpoint_size.patch @@ -0,0 +1,30 @@ +--- linux-2.4.34-old/drivers/usb/serial/usbserial.c 2007-08-27 15:32:14.000000000 +0200 ++++ linux-2.4.34-new/drivers/usb/serial/usbserial.c 2007-09-02 14:10:52.000000000 +0200 +@@ -331,6 +331,7 @@ + #ifdef CONFIG_USB_SERIAL_GENERIC + static __u16 vendor = 0x05f9; + static __u16 product = 0xffff; ++static int maxSize = 0; + + static struct usb_device_id generic_device_ids[9]; /* Initially all zeroes. */ + +@@ -1557,7 +1558,11 @@ + err("No free urbs available"); + goto probe_error; + } ++#ifdef CONFIG_USB_SERIAL_GENERIC ++ buffer_size = (endpoint->wMaxPacketSize > maxSize) ? endpoint->wMaxPacketSize : maxSize; ++#else + buffer_size = endpoint->wMaxPacketSize; ++#endif + port->bulk_in_endpointAddress = endpoint->bEndpointAddress; + port->bulk_in_buffer = kmalloc (buffer_size, GFP_KERNEL); + if (!port->bulk_in_buffer) { +@@ -1945,4 +1950,7 @@ + + MODULE_PARM(product, "h"); + MODULE_PARM_DESC(product, "User specified USB idProduct"); ++ ++MODULE_PARM(maxSize,"i"); ++MODULE_PARM_DESC(maxSize,"User specified USB endpoint size"); + #endif