|
@@ -685,10 +685,8 @@ static int ulpi_phy_power_off(struct tegra_usb_phy *phy)
|
|
|
return gpio_direction_output(phy->reset_gpio, 0);
|
|
|
}
|
|
|
|
|
|
-static void tegra_usb_phy_close(struct usb_phy *x)
|
|
|
+static void tegra_usb_phy_close(struct tegra_usb_phy *phy)
|
|
|
{
|
|
|
- struct tegra_usb_phy *phy = container_of(x, struct tegra_usb_phy, u_phy);
|
|
|
-
|
|
|
if (!IS_ERR(phy->vbus))
|
|
|
regulator_disable(phy->vbus);
|
|
|
|
|
@@ -1060,14 +1058,13 @@ static int tegra_usb_phy_probe(struct platform_device *pdev)
|
|
|
if (err < 0)
|
|
|
return err;
|
|
|
|
|
|
- tegra_phy->u_phy.shutdown = tegra_usb_phy_close;
|
|
|
tegra_phy->u_phy.set_suspend = tegra_usb_phy_suspend;
|
|
|
|
|
|
platform_set_drvdata(pdev, tegra_phy);
|
|
|
|
|
|
err = usb_add_phy_dev(&tegra_phy->u_phy);
|
|
|
if (err < 0) {
|
|
|
- tegra_usb_phy_close(&tegra_phy->u_phy);
|
|
|
+ tegra_usb_phy_close(tegra_phy);
|
|
|
return err;
|
|
|
}
|
|
|
|
|
@@ -1079,6 +1076,7 @@ static int tegra_usb_phy_remove(struct platform_device *pdev)
|
|
|
struct tegra_usb_phy *tegra_phy = platform_get_drvdata(pdev);
|
|
|
|
|
|
usb_remove_phy(&tegra_phy->u_phy);
|
|
|
+ tegra_usb_phy_close(tegra_phy);
|
|
|
|
|
|
return 0;
|
|
|
}
|