From 50331bba385d880f74dd9dcbce8a32d6f4e49f8c Mon Sep 17 00:00:00 2001 From: Krishna Yarlagadda Date: Wed, 18 Jul 2012 17:04:33 +0530 Subject: ARM: tegra: usb: regulator on during lp0 on T20 Tegra 2 requires regulator to be on during lp0 Bug 1012273 Change-Id: I750892fd391be327e617c70b7da4c984019a32fa Signed-off-by: Krishna Yarlagadda Reviewed-on: http://git-master/r/116743 Reviewed-by: Simone Willett Tested-by: Simone Willett --- arch/arm/mach-tegra/usb_phy.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/arch/arm/mach-tegra/usb_phy.c b/arch/arm/mach-tegra/usb_phy.c index 62884df14269..4cc80e68d89c 100644 --- a/arch/arm/mach-tegra/usb_phy.c +++ b/arch/arm/mach-tegra/usb_phy.c @@ -405,6 +405,8 @@ void tegra_usb_phy_close(struct tegra_usb_phy *phy) } if (phy->vdd_reg) { + if (phy->vdd_reg_on) + regulator_disable(phy->vdd_reg); regulator_put(phy->vdd_reg); } @@ -470,17 +472,12 @@ int tegra_usb_phy_power_off(struct tegra_usb_phy *phy) } } - if (phy->vdd_reg && phy->vdd_reg_on) { -#ifndef CONFIG_ARCH_TEGRA_2x_SOC - regulator_disable(phy->vdd_reg); - phy->vdd_reg_on = false; -#else - if (tegra_get_revision() >= TEGRA_REVISION_A03) { + if (phy->vdd_reg && phy->vdd_reg_on) + if (phy->pdata->has_hostpc || + phy->pdata->builtin_host_disabled) { regulator_disable(phy->vdd_reg); phy->vdd_reg_on = false; } -#endif - } phy->phy_power_on = false; -- cgit v1.2.3