Add missing unlock of USB controller's lock, when

doing shutdown, suspend and resume.

Suggested by:	avg @
MFC after:	3 days
This commit is contained in:
Hans Petter Selasky 2011-12-19 14:53:42 +00:00
parent 1d44b5b9f0
commit 6bd3e53514
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=228709

View File

@ -390,6 +390,8 @@ usb_bus_suspend(struct usb_proc_msg *pm)
if (udev == NULL || bus->bdev == NULL)
return;
USB_BUS_UNLOCK(bus);
bus_generic_shutdown(bus->bdev);
usbd_enum_lock(udev);
@ -410,6 +412,8 @@ usb_bus_suspend(struct usb_proc_msg *pm)
(bus->methods->set_hw_power_sleep) (bus, USB_HW_POWER_SUSPEND);
usbd_enum_unlock(udev);
USB_BUS_LOCK(bus);
}
/*------------------------------------------------------------------------*
@ -430,6 +434,8 @@ usb_bus_resume(struct usb_proc_msg *pm)
if (udev == NULL || bus->bdev == NULL)
return;
USB_BUS_UNLOCK(bus);
usbd_enum_lock(udev);
#if 0
DEVMETHOD(usb_take_controller, NULL); /* dummy */
@ -457,6 +463,8 @@ usb_bus_resume(struct usb_proc_msg *pm)
device_printf(bus->bdev, "Could not configure root HUB\n");
usbd_enum_unlock(udev);
USB_BUS_LOCK(bus);
}
/*------------------------------------------------------------------------*
@ -477,6 +485,8 @@ usb_bus_shutdown(struct usb_proc_msg *pm)
if (udev == NULL || bus->bdev == NULL)
return;
USB_BUS_UNLOCK(bus);
bus_generic_shutdown(bus->bdev);
usbd_enum_lock(udev);
@ -497,6 +507,8 @@ usb_bus_shutdown(struct usb_proc_msg *pm)
(bus->methods->set_hw_power_sleep) (bus, USB_HW_POWER_SHUTDOWN);
usbd_enum_unlock(udev);
USB_BUS_LOCK(bus);
}
static void