diff options
author | Dariusz M <D.Marcinkiewicz@elka.pw.edu.pl> | 2005-07-28 12:06:13 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2005-09-08 19:22:28 -0400 |
commit | 1694899fd1af43636351aac97f415fd3c9cefb1d (patch) | |
tree | d849892672ad4441f7539322680158e3f928b1db /drivers/usb/serial | |
parent | ef0840286045fe7ce84cb77e7608f0844c81001c (diff) |
[PATCH] USB: pl2303 driver, makes pl2303HX chip work correctly
This trivial patch makes pl2303 driver work correctly with pl2303HX chip.
Apparently some bug in HX version of pl2303 makes the chip loose some
transmitted bytes or stop working at all after reception of
USB_REQ_CLEAR_FEATURE mesage. Logs generated by UsbSnoop application reveal
that windows driver does not send this type of messages to the converter.
From: "Dariusz M." <D.Marcinkiewicz@elka.pw.edu.pl>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/serial')
-rw-r--r-- | drivers/usb/serial/pl2303.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/usb/serial/pl2303.c b/drivers/usb/serial/pl2303.c index 7eab5d4cf3a8..461474176cfb 100644 --- a/drivers/usb/serial/pl2303.c +++ b/drivers/usb/serial/pl2303.c | |||
@@ -538,8 +538,10 @@ static int pl2303_open (struct usb_serial_port *port, struct file *filp) | |||
538 | 538 | ||
539 | dbg("%s - port %d", __FUNCTION__, port->number); | 539 | dbg("%s - port %d", __FUNCTION__, port->number); |
540 | 540 | ||
541 | usb_clear_halt(serial->dev, port->write_urb->pipe); | 541 | if (priv->type != HX) { |
542 | usb_clear_halt(serial->dev, port->read_urb->pipe); | 542 | usb_clear_halt(serial->dev, port->write_urb->pipe); |
543 | usb_clear_halt(serial->dev, port->read_urb->pipe); | ||
544 | } | ||
543 | 545 | ||
544 | buf = kmalloc(10, GFP_KERNEL); | 546 | buf = kmalloc(10, GFP_KERNEL); |
545 | if (buf==NULL) | 547 | if (buf==NULL) |