Commit ba9a103f authored by Johan Hovold's avatar Johan Hovold Committed by Dmitry Torokhov

Input: keyspan-remote - fix control-message timeouts

The driver was issuing synchronous uninterruptible control requests
without using a timeout. This could lead to the driver hanging on probe
due to a malfunctioning (or malicious) device until the device is
physically disconnected. While sleeping in probe the driver prevents
other devices connected to the same hub from being added to (or removed
from) the bus.

The USB upper limit of five seconds per request should be more than
enough.

Fixes: 99f83c9c ("[PATCH] USB: add driver for Keyspan Digital Remote")
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
Reviewed-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: stable <stable@vger.kernel.org>     # 2.6.13
Link: https://lore.kernel.org/r/20200113171715.30621-1-johan@kernel.orgSigned-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent ce535a2e
...@@ -336,7 +336,8 @@ static int keyspan_setup(struct usb_device* dev) ...@@ -336,7 +336,8 @@ static int keyspan_setup(struct usb_device* dev)
int retval = 0; int retval = 0;
retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0),
0x11, 0x40, 0x5601, 0x0, NULL, 0, 0); 0x11, 0x40, 0x5601, 0x0, NULL, 0,
USB_CTRL_SET_TIMEOUT);
if (retval) { if (retval) {
dev_dbg(&dev->dev, "%s - failed to set bit rate due to error: %d\n", dev_dbg(&dev->dev, "%s - failed to set bit rate due to error: %d\n",
__func__, retval); __func__, retval);
...@@ -344,7 +345,8 @@ static int keyspan_setup(struct usb_device* dev) ...@@ -344,7 +345,8 @@ static int keyspan_setup(struct usb_device* dev)
} }
retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0),
0x44, 0x40, 0x0, 0x0, NULL, 0, 0); 0x44, 0x40, 0x0, 0x0, NULL, 0,
USB_CTRL_SET_TIMEOUT);
if (retval) { if (retval) {
dev_dbg(&dev->dev, "%s - failed to set resume sensitivity due to error: %d\n", dev_dbg(&dev->dev, "%s - failed to set resume sensitivity due to error: %d\n",
__func__, retval); __func__, retval);
...@@ -352,7 +354,8 @@ static int keyspan_setup(struct usb_device* dev) ...@@ -352,7 +354,8 @@ static int keyspan_setup(struct usb_device* dev)
} }
retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0), retval = usb_control_msg(dev, usb_sndctrlpipe(dev, 0),
0x22, 0x40, 0x0, 0x0, NULL, 0, 0); 0x22, 0x40, 0x0, 0x0, NULL, 0,
USB_CTRL_SET_TIMEOUT);
if (retval) { if (retval) {
dev_dbg(&dev->dev, "%s - failed to turn receive on due to error: %d\n", dev_dbg(&dev->dev, "%s - failed to turn receive on due to error: %d\n",
__func__, retval); __func__, retval);
......
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