Commit af1c51fc authored by Marcelo Tosatti's avatar Marcelo Tosatti Committed by Greg Kroah-Hartman

USB: EHCI restart speedup

It is not necessary to powerdown the ports on ehci_pci_reinit() when the
chip reset already did that.  Removing this saves 20ms during restart
after poweroff paths (which OLPC uses a lot).

To ensure driver startup then behaves consistently, force a reset during
driver startup.  (Not doing this was an accident of some previous changes
to the init sequence.)

Make the corresponding change in the PS3 support.  It's not clear what
ehci-fsl should do here; it has similar code to the PS3.
Signed-off-by: default avatarMarcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Cc: <rvinson@mvista.com>
Acked-by: default avatarGeoff Levand <geoffrey.levand@am.sony.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 0eb0226c
...@@ -58,8 +58,6 @@ static int ehci_pci_reinit(struct ehci_hcd *ehci, struct pci_dev *pdev) ...@@ -58,8 +58,6 @@ static int ehci_pci_reinit(struct ehci_hcd *ehci, struct pci_dev *pdev)
if (!retval) if (!retval)
ehci_dbg(ehci, "MWI active\n"); ehci_dbg(ehci, "MWI active\n");
ehci_port_power(ehci, 0);
return 0; return 0;
} }
...@@ -156,7 +154,6 @@ static int ehci_pci_setup(struct usb_hcd *hcd) ...@@ -156,7 +154,6 @@ static int ehci_pci_setup(struct usb_hcd *hcd)
break; break;
} }
if (ehci_is_TDI(ehci))
ehci_reset(ehci); ehci_reset(ehci);
/* at least the Genesys GL880S needs fixup here */ /* at least the Genesys GL880S needs fixup here */
......
...@@ -47,7 +47,7 @@ static int ps3_ehci_hc_reset(struct usb_hcd *hcd) ...@@ -47,7 +47,7 @@ static int ps3_ehci_hc_reset(struct usb_hcd *hcd)
if (result) if (result)
return result; return result;
ehci_port_power(ehci, 0); ehci_reset(ehci);
return result; return result;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment