diff options
author | Alan Stern <stern@rowland.harvard.edu> | 2007-05-04 11:57:00 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2007-06-08 16:24:31 -0700 |
commit | 6fd75b19483b2f6e6619602a535b4939e46921c1 (patch) | |
tree | b558ebc17728b2f92763f3ddc2fa94f54796e8a0 /drivers/usb | |
parent | 615ae11b3b4af7a5adb0819ff11b3b764eb92268 (diff) | |
download | op-kernel-dev-6fd75b19483b2f6e6619602a535b4939e46921c1.zip op-kernel-dev-6fd75b19483b2f6e6619602a535b4939e46921c1.tar.gz |
OHCI: Fix machine check in ohci_hub_status_data
This patch (as901) fixes an oversight in ohci-hcd. The
hub_status_data routine must not try to access the controller's
memory-mapped registers if the controller is in a low-power state;
such attempts will cause a crash on some architectures (such as PPC).
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/host/ohci-hub.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/usb/host/ohci-hub.c b/drivers/usb/host/ohci-hub.c index 216c9c9..bb9cc59 100644 --- a/drivers/usb/host/ohci-hub.c +++ b/drivers/usb/host/ohci-hub.c @@ -417,6 +417,8 @@ ohci_hub_status_data (struct usb_hcd *hcd, char *buf) unsigned long flags; spin_lock_irqsave (&ohci->lock, flags); + if (!test_bit(HCD_FLAG_HW_ACCESSIBLE, &hcd->flags)) + goto done; /* undocumented erratum seen on at least rev D */ if ((ohci->flags & OHCI_QUIRK_AMD756) |