From: Franck Bui-Huu Date: Mon, 15 May 2006 17:23:53 +0000 (+0200) Subject: [PATCH] Fix a deadlock in usbtest X-Git-Tag: v2.6.18-rc1~858^2~72 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=caa2a1226741e023a103e091a7f6dce7c42e82ee;p=linux-2.6-omap-h63xx.git [PATCH] Fix a deadlock in usbtest ctrl_complete functions acquires ctx->lock and tries to unlink all queued urbs in case of errors through usb_unlink_urb func. In its turn usb_unlink_urb calls, through the hcd driver, usb_hcd_giveback_urb which calls ctrl_complete again. At this time, ctx->lock is already taken by the same function. Signed-off-by: Franck Bui-Huu Cc: David Brownell Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/usb/misc/usbtest.c b/drivers/usb/misc/usbtest.c index ccc5e8238bd..b42ae6bfb12 100644 --- a/drivers/usb/misc/usbtest.c +++ b/drivers/usb/misc/usbtest.c @@ -802,7 +802,9 @@ error: if (u == urb || !u->dev) continue; + spin_unlock(&ctx->lock); status = usb_unlink_urb (u); + spin_lock(&ctx->lock); switch (status) { case -EINPROGRESS: case -EBUSY: