[PATCH 29/45] usb: cdc-wdm: Fix order in disconnect and fix locking

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Greg Kroah-Hartman
Date: Friday, March 19, 2010 - 8:19 am

From: Oliver Neukum <oliver@neukum.org>

- as the callback can schedule work, URBs must be killed first
- if the driver causes an autoresume, the caller must handle locking

Signed-off-by: Oliver Neukum <neukum@b1-systems.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
---
 drivers/usb/class/cdc-wdm.c |   25 +++++++++++++++++--------
 1 files changed, 17 insertions(+), 8 deletions(-)

diff --git a/drivers/usb/class/cdc-wdm.c b/drivers/usb/class/cdc-wdm.c
index 07c1297..b574905 100644
--- a/drivers/usb/class/cdc-wdm.c
+++ b/drivers/usb/class/cdc-wdm.c
@@ -776,9 +776,9 @@ static void wdm_disconnect(struct usb_interface *intf)
 	/* to terminate pending flushes */
 	clear_bit(WDM_IN_USE, &desc->flags);
 	spin_unlock_irqrestore(&desc->iuspin, flags);
-	cancel_work_sync(&desc->rxwork);
 	mutex_lock(&desc->lock);
 	kill_urbs(desc);
+	cancel_work_sync(&desc->rxwork);
 	mutex_unlock(&desc->lock);
 	wake_up_all(&desc->wait);
 	if (!desc->count)
@@ -786,6 +786,7 @@ static void wdm_disconnect(struct usb_interface *intf)
 	mutex_unlock(&wdm_mutex);
 }
 
+#ifdef CONFIG_PM
 static int wdm_suspend(struct usb_interface *intf, pm_message_t message)
 {
 	struct wdm_device *desc = usb_get_intfdata(intf);
@@ -793,27 +794,30 @@ static int wdm_suspend(struct usb_interface *intf, pm_message_t message)
 
 	dev_dbg(&desc->intf->dev, "wdm%d_suspend\n", intf->minor);
 
-	mutex_lock(&desc->lock);
+	/* if this is an autosuspend the caller does the locking */
+	if (!(message.event & PM_EVENT_AUTO))
+		mutex_lock(&desc->lock);
 	spin_lock_irq(&desc->iuspin);
-#ifdef CONFIG_PM
+
 	if ((message.event & PM_EVENT_AUTO) &&
 			(test_bit(WDM_IN_USE, &desc->flags)
 			|| test_bit(WDM_RESPONDING, &desc->flags))) {
 		spin_unlock_irq(&desc->iuspin);
 		rv = -EBUSY;
 	} else {
-#endif
+
 		set_bit(WDM_SUSPENDING, &desc->flags);
 		spin_unlock_irq(&desc->iuspin);
-		cancel_work_sync(&desc->rxwork);
+		/* callback submits work - order is essential */
 		kill_urbs(desc);
-#ifdef CONFIG_PM
+		cancel_work_sync(&desc->rxwork);
 	}
-#endif
-	mutex_unlock(&desc->lock);
+	if (!(message.event & PM_EVENT_AUTO))
+		mutex_unlock(&desc->lock);
 
 	return rv;
 }
+#endif
 
 static int recover_from_urb_loss(struct wdm_device *desc)
 {
@@ -827,6 +831,8 @@ static int recover_from_urb_loss(struct wdm_device *desc)
 	}
 	return rv;
 }
+
+#ifdef CONFIG_PM
 static int wdm_resume(struct usb_interface *intf)
 {
 	struct wdm_device *desc = usb_get_intfdata(intf);
@@ -839,6 +845,7 @@ static int wdm_resume(struct usb_interface *intf)
 	mutex_unlock(&desc->lock);
 	return rv;
 }
+#endif
 
 static int wdm_pre_reset(struct usb_interface *intf)
 {
@@ -862,9 +869,11 @@ static struct usb_driver wdm_driver = {
 	.name =		"cdc_wdm",
 	.probe =	wdm_probe,
 	.disconnect =	wdm_disconnect,
+#ifdef CONFIG_PM
 	.suspend =	wdm_suspend,
 	.resume =	wdm_resume,
 	.reset_resume =	wdm_resume,
+#endif
 	.pre_reset =	wdm_pre_reset,
 	.post_reset =	wdm_post_reset,
 	.id_table =	wdm_ids,
-- 
1.7.0.2

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[GIT PATCH] USB fixes for 2.6.34-git, Greg KH, (Fri Mar 19, 8:13 am)
[PATCH 01/45] USB: fix usbfs regression, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 02/45] USB: serial: fix error message on close in g ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 03/45] USB: serial: fix softint not being called on ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 04/45] USB: serial: use port endpoint size to deter ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 05/45] USB: unusual_devs.h: Fix capacity for SL11R- ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 06/45] USB: Option: Add support for a variant of DL ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 07/45] USB: EHCI: fix ITD list order, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 08/45] USB: EHCI: adjust ehci_iso_stream for change ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 09/45] USB: cdc-acm: Fix stupid NULL pointer in res ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 10/45] USB: qcserial: add new device ids, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 11/45] USB: musb: fix build error introduced by iso ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 12/45] USB: xhci: rename driver to xhci_hcd, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 13/45] USB: xHCI: re-initialize cmd_completion, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 14/45] USB: serial: ftdi: add CONTEC vendor and pro ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 15/45] USB: option: fix incorrect manufacturer name ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 16/45] USB: option: move hardcoded PID to a macro i ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 17/45] USB: option: add support for a new CMOTECH d ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 18/45] USB: Fix documentation for avoid_reset_quirk, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 19/45] usb/gadget: fix compile error on r8a66597-udc.c, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 20/45] usb: musb: Fix compile error for omaps for m ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 21/45] usb: musb: abstract out ULPI_BUSCONTROL regi ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 22/45] USB: musb: fix warnings in Blackfin regs, Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 23/45] usb: musb: core: declare mbase only where it ..., Greg Kroah-Hartman, (Fri Mar 19, 8:18 am)
[PATCH 24/45] usb: cdc-wdm: Fix race between write and dis ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 25/45] usb: cdc-wdm: Fix race between autosuspend a ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 26/45] usb: cdc-wdm: Fix race between disconnect an ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 27/45] usb: cdc-wdm: Fix submission of URB after su ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 28/45] usb: cdc-wdm:Fix loss of data due to autosuspend, Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 29/45] usb: cdc-wdm: Fix order in disconnect and fi ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 30/45] usb: cdc-wdm: Fix deadlock between write and ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 31/45] USB: serial: Fix module name typo for qcaux ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 32/45] USB: option.c: Add Pirelli VID/PID and indic ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 33/45] USB: goku_udc: remove potential null dereference, Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 34/45] USB: gadget: fix Blackfin builds after gadge ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 35/45] USB: g_mass_storage: fix section mismatch wa ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 36/45] USB: gadget: f_mass_storage::fsg_bind(): fix ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 37/45] USB: g_mass_storage: fixed module name in Kc ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 38/45] USB: ftdi_sio: Fix locking for change_speed( ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 39/45] USB: gadget: add gadget controller number fo ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 40/45] USB: Remove last bit of CONFIG_USB_BERRY_CHARGE, Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 41/45] USB: cp210x: Remove double usb_control_msg f ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 42/45] USB: Fix usb_fill_int_urb for SuperSpeed devices, Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 43/45] USB: xhci: Make endpoint interval debugging ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 44/45] usb: r8a66597-hcd: fix removed from an attac ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
[PATCH 45/45] USB: gadget/multi: cdc_do_config: remove red ..., Greg Kroah-Hartman, (Fri Mar 19, 8:19 am)
Re: [PATCH 10/45] USB: qcserial: add new device ids, Matthew Garrett, (Thu Apr 1, 2:14 pm)
Re: [PATCH 10/45] USB: qcserial: add new device ids, Bernhard Rosenkraenzer, (Thu Apr 1, 3:31 pm)
Re: [PATCH 10/45] USB: qcserial: add new device ids, Matthew Garrett, (Thu Apr 1, 4:18 pm)