HID: usbhid: initialize interface pointers early enough
Move the initialization of USB interface pointers from _start() over to _probe() callback, which is where it belongs. This fixes case where interface is NULL when parsing of report descriptor fails. LKML-Reference: <20100213135720.603e5f64@neptune.home> Reported-by: Alan Stern <stern@rowland.harvard.edu> Tested-by: Bruno Prémont <bonbons@linux-vserver.org> Signed-off-by: Jiri Kosina <jkosina@suse.cz>
This commit is contained in:
parent
7f978b9bf5
commit
57ab12e418
|
@ -1005,9 +1005,6 @@ static int usbhid_start(struct hid_device *hid)
|
||||||
|
|
||||||
spin_lock_init(&usbhid->lock);
|
spin_lock_init(&usbhid->lock);
|
||||||
|
|
||||||
usbhid->intf = intf;
|
|
||||||
usbhid->ifnum = interface->desc.bInterfaceNumber;
|
|
||||||
|
|
||||||
usbhid->urbctrl = usb_alloc_urb(0, GFP_KERNEL);
|
usbhid->urbctrl = usb_alloc_urb(0, GFP_KERNEL);
|
||||||
if (!usbhid->urbctrl) {
|
if (!usbhid->urbctrl) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
|
@ -1178,6 +1175,8 @@ static int usbhid_probe(struct usb_interface *intf, const struct usb_device_id *
|
||||||
|
|
||||||
hid->driver_data = usbhid;
|
hid->driver_data = usbhid;
|
||||||
usbhid->hid = hid;
|
usbhid->hid = hid;
|
||||||
|
usbhid->intf = intf;
|
||||||
|
usbhid->ifnum = interface->desc.bInterfaceNumber;
|
||||||
|
|
||||||
ret = hid_add_device(hid);
|
ret = hid_add_device(hid);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
|
Loading…
Reference in New Issue