summaryrefslogtreecommitdiff
path: root/recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff
diff options
context:
space:
mode:
authorFrans Meulenbroeks <fransmeulenbroeks@gmail.com>2009-03-19 20:56:09 +0100
committerFrans Meulenbroeks <fransmeulenbroeks@gmail.com>2009-03-19 20:56:09 +0100
commit6a21d65d2840c58cfa7cd749a04669d8f7980646 (patch)
tree00b1aa153b69cda8cf9406c4700fd7730c34d3a5 /recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff
parentdcfe7349b369a87881cf1fa43085d9e9c5609fcf (diff)
parent6f854d71c347475d53d5080a5490625345d95d12 (diff)
Merge branch 'org.openembedded.dev' of git@git.openembedded.net:openembedded into org.openembedded.dev
Diffstat (limited to 'recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff')
-rw-r--r--recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff33
1 files changed, 33 insertions, 0 deletions
diff --git a/recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff b/recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff
new file mode 100644
index 0000000000..6a98f76c7a
--- /dev/null
+++ b/recipes/linux/linux-mtx-2-2.4.27/43-usbserial-27-32-backport.diff
@@ -0,0 +1,33 @@
+--- linux/drivers/usb/serial/usbserial.c-27 2006-06-27 10:26:06.294476250 +0200
++++ linux/drivers/usb/serial/usbserial.c 2006-06-27 10:30:31.011020000 +0200
+@@ -528,8 +528,18 @@
+ down(&port->sem);
+ dbg("%s - port %d len %d backlog %d", __FUNCTION__,
+ port->number, job->len, port->write_backlog);
+- if (port->tty != NULL)
+- __serial_write(port, 0, job->buff, job->len);
++ if (port->tty != NULL) {
++ int rc;
++ int sent = 0;
++ while (sent < job->len) {
++ rc = __serial_write(port, 0, job->buff + sent, job->len - sent);
++ if ((rc < 0) || signal_pending(current))
++ break;
++ sent += rc;
++ if ((sent < job->len) && current->need_resched)
++ schedule();
++ }
++ }
+ up(&port->sem);
+
+ spin_lock_irqsave(&post_lock, flags);
+@@ -725,6 +735,9 @@
+ struct usb_serial_port *port = (struct usb_serial_port *) tty->driver_data;
+ int rc;
+
++ if (!port)
++ return -ENODEV;
++
+ if (!in_interrupt()) {
+ /*
+ * Run post_list to reduce a possiblity of reordered writes.