HID: usbhid: fix recursive deadlock
[firefly-linux-kernel-4.4.55.git] / drivers / hid / usbhid / hid-core.c
index 36712e9f56c26d9ae96ddb5cfa4baada0b681f04..5dd426fee8cc3c1403307c44445e96a9c93e13e9 100644 (file)
@@ -477,8 +477,6 @@ static void hid_ctrl(struct urb *urb)
        struct usbhid_device *usbhid = hid->driver_data;
        int unplug = 0, status = urb->status;
 
-       spin_lock(&usbhid->lock);
-
        switch (status) {
        case 0:                 /* success */
                if (usbhid->ctrl[usbhid->ctrltail].dir == USB_DIR_IN)
@@ -498,6 +496,8 @@ static void hid_ctrl(struct urb *urb)
                hid_warn(urb->dev, "ctrl urb status %d received\n", status);
        }
 
+       spin_lock(&usbhid->lock);
+
        if (unplug) {
                usbhid->ctrltail = usbhid->ctrlhead;
        } else {