aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/core
diff options
context:
space:
mode:
authorAlan Stern <stern@rowland.harvard.edu>2012-04-24 14:07:22 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2012-05-07 11:56:36 -0400
commita8eaeff79eb97662e2d06cc1919d902fc251e9da (patch)
treeedb27c73cf9d063e144d5ef5331ec270963d2ba7 /drivers/usb/core
parent197d1155b07b582d9969f456f61ee07d632af7e1 (diff)
USB: EHCI: fix crash during suspend on ASUS computers
commit 151b61284776be2d6f02d48c23c3625678960b97 upstream. This patch (as1545) fixes a problem affecting several ASUS computers: The machine crashes or corrupts memory when going into suspend if the ehci-hcd driver is bound to any controllers. Users have been forced to unbind or unload ehci-hcd before putting their systems to sleep. After extensive testing, it was determined that the machines don't like going into suspend when any EHCI controllers are in the PCI D3 power state. Presumably this is a firmware bug, but there's nothing we can do about it except to avoid putting the controllers in D3 during system sleep. The patch adds a new flag to indicate whether the problem is present, and avoids changing the controller's power state if the flag is set. Runtime suspend is unaffected; this matters only for system suspend. However as a side effect, the controller will not respond to remote wakeup requests while the system is asleep. Hence USB wakeup is not functional -- but of course, this is already true in the current state of affairs. This fixes Bugzilla #42728. Signed-off-by: Alan Stern <stern@rowland.harvard.edu> Tested-by: Steven Rostedt <rostedt@goodmis.org> Tested-by: Andrey Rahmatullin <wrar@wrar.name> Tested-by: Oleksij Rempel (fishor) <bug-track@fisher-privat.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/core')
-rw-r--r--drivers/usb/core/hcd-pci.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/drivers/usb/core/hcd-pci.c b/drivers/usb/core/hcd-pci.c
index 6c1642b382f..aa7bbbcf9d8 100644
--- a/drivers/usb/core/hcd-pci.c
+++ b/drivers/usb/core/hcd-pci.c
@@ -495,6 +495,15 @@ static int hcd_pci_suspend_noirq(struct device *dev)
495 495
496 pci_save_state(pci_dev); 496 pci_save_state(pci_dev);
497 497
498 /*
499 * Some systems crash if an EHCI controller is in D3 during
500 * a sleep transition. We have to leave such controllers in D0.
501 */
502 if (hcd->broken_pci_sleep) {
503 dev_dbg(dev, "Staying in PCI D0\n");
504 return retval;
505 }
506
498 /* If the root hub is dead rather than suspended, disallow remote 507 /* If the root hub is dead rather than suspended, disallow remote
499 * wakeup. usb_hc_died() should ensure that both hosts are marked as 508 * wakeup. usb_hc_died() should ensure that both hosts are marked as
500 * dying, so we only need to check the primary roothub. 509 * dying, so we only need to check the primary roothub.