Attempt to fix deadlocking USB transfers
Whenever a device is removed, let usb_raw cancel all its pending transfers. Does not seems to help with the issue I'm getting however. Change-Id: Ie2856e68ea402c9f1cc352ac47bbca624e17d3dc Reviewed-on: https://review.haiku-os.org/c/haiku/+/1424 Reviewed-by: waddlesplash <waddlesplash@gmail.com> Reviewed-by: Fredrik Modéen <fredrik@modeen.se> Reviewed-by: Adrien Destugues <pulkomandy@gmail.com>
This commit is contained in:
parent
a77684c96a
commit
61013090a0
@ -95,6 +95,17 @@ usb_raw_device_removed(void *cookie)
|
|||||||
TRACE((DRIVER_NAME": device_removed(0x%p)\n", cookie));
|
TRACE((DRIVER_NAME": device_removed(0x%p)\n", cookie));
|
||||||
raw_device *device = (raw_device *)cookie;
|
raw_device *device = (raw_device *)cookie;
|
||||||
|
|
||||||
|
// cancel all pending transfers to make sure no one keeps waiting forever
|
||||||
|
// in syscalls.
|
||||||
|
const usb_configuration_info *configurationInfo =
|
||||||
|
gUSBModule->get_configuration(device->device);
|
||||||
|
if (configurationInfo != NULL) {
|
||||||
|
struct usb_interface_info* interface
|
||||||
|
= configurationInfo->interface->active;
|
||||||
|
for (unsigned int i = 0; i < interface->endpoint_count; i++)
|
||||||
|
gUSBModule->cancel_queued_transfers(interface->endpoint[i].handle);
|
||||||
|
}
|
||||||
|
|
||||||
mutex_lock(&gDeviceListLock);
|
mutex_lock(&gDeviceListLock);
|
||||||
if (gDeviceList == device) {
|
if (gDeviceList == device) {
|
||||||
gDeviceList = (raw_device *)device->link;
|
gDeviceList = (raw_device *)device->link;
|
||||||
|
Loading…
Reference in New Issue
Block a user