Skip to content
Browse files

USB: Prevent system suspend when HSIC device is active

Some buses like HSIC would like to keep device in suspend state
after system resume.  The remote wakeup or interface activity
later will auto resume the device.  This will work only if the
device is auto suspended before system suspend.  If the device
runtime state had been active during system suspend and system
suspend routine put the device in suspend, it will not be resumed
during system resume.  When remote wakeup happen for this device,
the runtime resume will not bring the device to active as runtime
core think it is already active.

The HSIC bus ensure that device is auto suspended prior to system
suspend by holding a wakelock till the bus is suspended.  HSIC bus
is not handling the case where device is auto resumed immediately
after system suspend begins.  HSIC bus simply put the device into
suspend in system suspend routine.

This patch fixes above issue by returning an error code if the device
is not auto suspended during system suspend.  Also add a safe guard
check in HSIC system resume routine to skip device resume only if it
is auto suspended prior to system suspend.

(cherry picked from commit 41d004c4eaa5565cb8d9113862c3cef1e51be648)

Change-Id: If0b84833a7c416794e6f4431d54efcff3354d415
CRs-Fixed: 422876
Signed-off-by: Pavankumar Kondeti <>
Signed-off-by: franciscofranco <>
  • Loading branch information...
1 parent fa6f554 commit 7a3494a3097a1b6bf23bc4ed924aeea5f3d220ff Pavankumar Kondeti committed with
Showing with 10 additions and 3 deletions.
  1. +8 −2 drivers/usb/core/driver.c
  2. +2 −1 drivers/usb/host/ehci-msm-hsic.c
10 drivers/usb/core/driver.c
@@ -1357,8 +1357,14 @@ int usb_suspend(struct device *dev, pm_message_t msg)
struct usb_device *udev = to_usb_device(dev);
- if (udev->bus->skip_resume && udev->state == USB_STATE_SUSPENDED)
- return 0;
+ if (udev->bus->skip_resume) {
+ if (udev->state == USB_STATE_SUSPENDED) {
+ return 0;
+ } else {
+ dev_err(dev, "abort suspend\n");
+ return -EBUSY;
+ }
+ }
3 drivers/usb/host/ehci-msm-hsic.c
@@ -1767,7 +1767,8 @@ static int msm_hsic_pm_resume(struct device *dev)
* when remote wakeup is received or interface driver
* start I/O.
- if (!atomic_read(&mehci->pm_usage_cnt))
+ if (!atomic_read(&mehci->pm_usage_cnt) &&
+ pm_runtime_suspended(dev))
return 0;
ret = msm_hsic_resume(mehci);

0 comments on commit 7a3494a

Please sign in to comment.
Something went wrong with that request. Please try again.