aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/host/ehci-hcd.c
diff options
context:
space:
mode:
authorDavid Brownell <david-b@pacbell.net>2005-08-31 13:55:38 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2005-09-12 15:23:42 -0400
commit10f6524a8ef1413a8cbd952673997013183fe2a9 (patch)
treed5702bdccbeb57a7158643f978e47bcd2106e71f /drivers/usb/host/ehci-hcd.c
parent198b95170f2c7ad56b4ba92fe3d4d896f5be5c7e (diff)
[PATCH] USB: EHCI port tweaks
One change may improve some S1 or S3 resume cases, and the other seems mostly to explain some strange state "lsusb" would show. Two fixes: - On resume, don't think about resuming any unpowered port, or resetting any port with OWNER set to the OHCI/UHCI companion. This will make some S1 and S3 resume scenarios work better. - PORT_CSC was not being cleared correctly in ehci_hub_status_data. This was visible at least through current versions of "lsusb", and might have caused some other hub related strangeness. The fix addresses all three write-to-clear bits, using the same approach that UHCI happens to use: a mask of bits that are cleared in most writes to that port status register. Original patch seems to have been from from William.Morrow@amd.com and this version (from David) finishes the write-to-clear changes. Signed-off-by: Jordan Crouse <jordan.crouse@amd.com> Signed-off-by: David Brownell <dbrownell@users.sourceforge.net> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/host/ehci-hcd.c')
-rw-r--r--drivers/usb/host/ehci-hcd.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/usb/host/ehci-hcd.c b/drivers/usb/host/ehci-hcd.c
index 2507e898af09..2f7037c62e88 100644
--- a/drivers/usb/host/ehci-hcd.c
+++ b/drivers/usb/host/ehci-hcd.c
@@ -759,12 +759,16 @@ static int ehci_resume (struct usb_hcd *hcd)
759 if (time_before (jiffies, ehci->next_statechange)) 759 if (time_before (jiffies, ehci->next_statechange))
760 msleep (100); 760 msleep (100);
761 761
762 /* If any port is suspended, we know we can/must resume the HC. */ 762 /* If any port is suspended (or owned by the companion),
763 * we know we can/must resume the HC (and mustn't reset it).
764 */
763 for (port = HCS_N_PORTS (ehci->hcs_params); port > 0; ) { 765 for (port = HCS_N_PORTS (ehci->hcs_params); port > 0; ) {
764 u32 status; 766 u32 status;
765 port--; 767 port--;
766 status = readl (&ehci->regs->port_status [port]); 768 status = readl (&ehci->regs->port_status [port]);
767 if (status & PORT_SUSPEND) { 769 if (!(status & PORT_POWER))
770 continue;
771 if (status & (PORT_SUSPEND | PORT_OWNER)) {
768 down (&hcd->self.root_hub->serialize); 772 down (&hcd->self.root_hub->serialize);
769 retval = ehci_hub_resume (hcd); 773 retval = ehci_hub_resume (hcd);
770 up (&hcd->self.root_hub->serialize); 774 up (&hcd->self.root_hub->serialize);