summaryrefslogtreecommitdiff
path: root/drivers/usb
diff options
context:
space:
mode:
authorToby Gray <toby.gray@realvnc.com>2010-09-02 10:46:20 +0100
committerPaul Gortmaker <paul.gortmaker@windriver.com>2011-01-06 18:07:44 -0500
commit008f9efc13497e0b6cd7b2b11ea82d08b0d47ec9 (patch)
treedbaad34106953f3846d13bc8736d8f1fd683c2c6 /drivers/usb
parent1b6cc1718a9a203daad668fff39f8f4ba0ae1459 (diff)
downloadlwn-008f9efc13497e0b6cd7b2b11ea82d08b0d47ec9.tar.gz
lwn-008f9efc13497e0b6cd7b2b11ea82d08b0d47ec9.zip
USB: cdc-acm: Fixing crash when ACM probing interfaces with no endpoint descriptors.
commit 577045c0a76e34294f902a7d5d60e90b04d094d0 upstream. Certain USB devices, such as the Nokia X6 mobile phone, don't expose any endpoint descriptors on some of their interfaces. If the ACM driver is forced to probe all interfaces on a device the a NULL pointer dereference will occur when the ACM driver attempts to use the endpoint of the alternative settings. One way to get the ACM driver to probe all the interfaces is by using the /sys/bus/usb/drivers/cdc_acm/new_id interface. This patch checks that the endpoint pointer for the current alternate settings is non-NULL before using it. Signed-off-by: Toby Gray <toby.gray@realvnc.com> Cc: Oliver Neukum <oliver@neukum.name> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de> Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
Diffstat (limited to 'drivers/usb')
-rw-r--r--drivers/usb/class/cdc-acm.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/usb/class/cdc-acm.c b/drivers/usb/class/cdc-acm.c
index ffbf1aa91196..f1accc85eeb5 100644
--- a/drivers/usb/class/cdc-acm.c
+++ b/drivers/usb/class/cdc-acm.c
@@ -971,7 +971,8 @@ static int acm_probe(struct usb_interface *intf,
}
if (!buflen) {
- if (intf->cur_altsetting->endpoint->extralen &&
+ if (intf->cur_altsetting->endpoint &&
+ intf->cur_altsetting->endpoint->extralen &&
intf->cur_altsetting->endpoint->extra) {
dev_dbg(&intf->dev,
"Seeking extra descriptors on endpoint\n");