summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSeongho Joo <sjoo@nvidia.com>2011-08-26 00:01:23 +0900
committerVarun Colbert <vcolbert@nvidia.com>2011-09-02 17:55:39 -0700
commitc2d98e286f6e4082d723f7cef45f9c87d12dcb7a (patch)
tree77d78b9fe85e9286ad7c22a80607997ed1013943
parent08d70a350e6171b4f774b4293af9557ef1f3ce36 (diff)
arm: tegra: usb_phy: check gpio if it is valid
only reset gpio is checked if it is valid. additionally check enable gpio. gpio validation is checked by gpio_request. Bug 851098 Change-Id: I5b27310e7126074020ab5bdedc33bb62b14351cc Reviewed-on: http://git-master/r/49239 Reviewed-by: Varun Colbert <vcolbert@nvidia.com> Tested-by: Varun Colbert <vcolbert@nvidia.com>
-rwxr-xr-x[-rw-r--r--]arch/arm/mach-tegra/usb_phy.c21
1 files changed, 12 insertions, 9 deletions
diff --git a/arch/arm/mach-tegra/usb_phy.c b/arch/arm/mach-tegra/usb_phy.c
index ef22c89e59f5..adf7a4f3aad1 100644..100755
--- a/arch/arm/mach-tegra/usb_phy.c
+++ b/arch/arm/mach-tegra/usb_phy.c
@@ -1923,6 +1923,7 @@ struct tegra_usb_phy *tegra_usb_phy_open(int instance, void __iomem *regs,
unsigned long parent_rate;
int i;
int err;
+ int reset_gpio, enable_gpio;
phy = kzalloc(sizeof(struct tegra_usb_phy), GFP_KERNEL);
if (!phy)
@@ -2005,27 +2006,29 @@ struct tegra_usb_phy *tegra_usb_phy_open(int instance, void __iomem *regs,
#ifndef CONFIG_ARCH_TEGRA_2x_SOC
else if (phy->usb_phy_type == TEGRA_USB_PHY_TYPE_HSIC) {
uhsic_config = config;
- gpio_request(uhsic_config->enable_gpio,
+ enable_gpio = gpio_request(uhsic_config->enable_gpio,
"uhsic_enable");
- if (uhsic_config->reset_gpio != -1)
- gpio_request(uhsic_config->reset_gpio,
+ reset_gpio = gpio_request(uhsic_config->reset_gpio,
"uhsic_reset");
/* hsic enable signal deasserted, hsic reset asserted */
- gpio_direction_output(uhsic_config->enable_gpio,
+ if (!enable_gpio)
+ gpio_direction_output(uhsic_config->enable_gpio,
0 /* deasserted */);
- if (uhsic_config->reset_gpio != -1)
+ if (!reset_gpio)
gpio_direction_output(uhsic_config->reset_gpio,
0 /* asserted */);
- tegra_gpio_enable(uhsic_config->enable_gpio);
- if (uhsic_config->reset_gpio != -1)
+ if (!enable_gpio)
+ tegra_gpio_enable(uhsic_config->enable_gpio);
+ if (!reset_gpio)
tegra_gpio_enable(uhsic_config->reset_gpio);
/* keep hsic reset asserted for 1 ms */
udelay(1000);
/* enable (power on) hsic */
- gpio_set_value_cansleep(uhsic_config->enable_gpio, 1);
+ if (!enable_gpio)
+ gpio_set_value_cansleep(uhsic_config->enable_gpio, 1);
udelay(1000);
/* deassert reset */
- if (uhsic_config->reset_gpio != -1)
+ if (!reset_gpio)
gpio_set_value_cansleep(uhsic_config->reset_gpio, 1);
}
#endif