diff options
Diffstat (limited to 'drivers/usb/host/uhci-hcd.c')
| -rw-r--r-- | drivers/usb/host/uhci-hcd.c | 15 | 
1 files changed, 14 insertions, 1 deletions
| diff --git a/drivers/usb/host/uhci-hcd.c b/drivers/usb/host/uhci-hcd.c index 274751b4409c..eb37d86bafef 100644 --- a/drivers/usb/host/uhci-hcd.c +++ b/drivers/usb/host/uhci-hcd.c @@ -749,7 +749,20 @@ static int uhci_rh_suspend(struct usb_hcd *hcd)  	spin_lock_irq(&uhci->lock);  	if (!test_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags))  		rc = -ESHUTDOWN; -	else if (!uhci->dead) +	else if (uhci->dead) +		;		/* Dead controllers tell no tales */ + +	/* Once the controller is stopped, port resumes that are already +	 * in progress won't complete.  Hence if remote wakeup is enabled +	 * for the root hub and any ports are in the middle of a resume or +	 * remote wakeup, we must fail the suspend. +	 */ +	else if (hcd->self.root_hub->do_remote_wakeup && +			uhci->resuming_ports) { +		dev_dbg(uhci_dev(uhci), "suspend failed because a port " +				"is resuming\n"); +		rc = -EBUSY; +	} else  		suspend_rh(uhci, UHCI_RH_SUSPENDED);  	spin_unlock_irq(&uhci->lock);  	return rc; | 
