diff options
author | Tuomas Tynkkynen <ttynkkynen@nvidia.com> | 2014-07-04 03:09:38 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2014-07-10 01:25:46 +0200 |
commit | a47cc24cd1e5a55ef0b240180ce7ec6a9afc939d (patch) | |
tree | 24f95f64767af802319d14bb02ab6e060ab5dfca /drivers/usb/phy/phy-tegra-usb.c | |
parent | ARM: tegra: Add resets & has-utmi-pad-registers flag to all USB PHYs (diff) | |
download | linux-a47cc24cd1e5a55ef0b240180ce7ec6a9afc939d.tar.xz linux-a47cc24cd1e5a55ef0b240180ce7ec6a9afc939d.zip |
USB: EHCI: tegra: Fix probe order issue leading to broken USB
The Tegra USB complex has a particularly annoying misdesign: some of the
UTMI pad configuration registers are global for all the 3 USB controllers
on the chip, but those registers are located in the first controller's
register space and will be cleared when the reset to the first
controller is asserted. Currently, this means that if the 1st controller
were to finish probing after the 2nd or 3rd controller, USB would not
work at all.
Fix this situation by always resetting the 1st controller before doing
any other setup to any of the controllers, and then never ever reset the
first controller again. As the UTMI registers are related to the PHY,
the PHY driver should probably reset the Tegra controllers instead,
but since old device trees only have reset phandles in the EHCI nodes,
do it here, which means a bit of device tree groveling. Those old DTs
also won't get the reset fix from this commit, so we'll dev_warn() them,
but the driver will still keep probing successfully.
Signed-off-by: Tuomas Tynkkynen <ttynkkynen@nvidia.com>
Acked-by: Alan Stern <stern@rowland.harvard.edu>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/usb/phy/phy-tegra-usb.c')
0 files changed, 0 insertions, 0 deletions