diff options
author | Sergei Shtylyov <sshtylyov@ru.mvista.com> | 2011-07-06 15:19:38 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2011-07-08 17:55:47 -0400 |
commit | 81463c1d707186adbbe534016cd1249edeab0dac (patch) | |
tree | 28ebdec53e33efce94b8a3d6be1f804e5d43a3d3 /drivers/usb | |
parent | 8dec92b24064f1ffbb6537ba97729b633b400c28 (diff) |
EHCI: only power off port if over-current is active
MAX4967 USB power supply chip we use on our boards signals over-current when
power is not enabled; once it's enabled, over-current signal returns to normal.
That unfortunately caused the endless stream of "over-current change on port"
messages. The EHCI root hub code reacts on every over-current signal change
with powering off the port -- such change event is generated the moment the
port power is enabled, so once enabled the power is immediately cut off.
I think we should only cut off power when we're seeing the active over-current
signal, so I'm adding such check to that code. I also think that the fact that
we've cut off the port power should be reflected in the result of GetPortStatus
request immediately, hence I'm adding a PORTSCn register readback after write...
Signed-off-by: Sergei Shtylyov <sshtylyov@ru.mvista.com>
Cc: stable@kernel.org
Acked-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/ehci-hub.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/usb/host/ehci-hub.c b/drivers/usb/host/ehci-hub.c index d9e8d713f485..bf2c8f65e1ae 100644 --- a/drivers/usb/host/ehci-hub.c +++ b/drivers/usb/host/ehci-hub.c | |||
@@ -816,10 +816,11 @@ static int ehci_hub_control ( | |||
816 | * power switching; they're allowed to just limit the | 816 | * power switching; they're allowed to just limit the |
817 | * current. khubd will turn the power back on. | 817 | * current. khubd will turn the power back on. |
818 | */ | 818 | */ |
819 | if (HCS_PPC (ehci->hcs_params)){ | 819 | if ((temp & PORT_OC) && HCS_PPC(ehci->hcs_params)) { |
820 | ehci_writel(ehci, | 820 | ehci_writel(ehci, |
821 | temp & ~(PORT_RWC_BITS | PORT_POWER), | 821 | temp & ~(PORT_RWC_BITS | PORT_POWER), |
822 | status_reg); | 822 | status_reg); |
823 | temp = ehci_readl(ehci, status_reg); | ||
823 | } | 824 | } |
824 | } | 825 | } |
825 | 826 | ||