Commit ab137d04 authored by Venu Byravarasu's avatar Venu Byravarasu Committed by Stephen Warren

usb: host: tegra: make use of PHY pointer of HCD

As pointer to PHY structure can be stored in struct usb_hcd
making use of it, to call Tegra PHY APIs.

Call to usb_phy_shutdown() is moved up in tegra_ehci_remove(),
so that to avoid dereferencing of hcd after its freed up.
Signed-off-by: default avatarVenu Byravarasu <vbyravarasu@nvidia.com>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Acked-by: default avatarFelipe Balbi <balbi@ti.com>
Acked-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarStephen Warren <swarren@nvidia.com>
parent 40e8b3a6
...@@ -56,7 +56,7 @@ static void tegra_ehci_power_up(struct usb_hcd *hcd) ...@@ -56,7 +56,7 @@ static void tegra_ehci_power_up(struct usb_hcd *hcd)
struct tegra_ehci_hcd *tegra = dev_get_drvdata(hcd->self.controller); struct tegra_ehci_hcd *tegra = dev_get_drvdata(hcd->self.controller);
clk_prepare_enable(tegra->clk); clk_prepare_enable(tegra->clk);
usb_phy_set_suspend(&tegra->phy->u_phy, 0); usb_phy_set_suspend(hcd->phy, 0);
tegra->host_resumed = 1; tegra->host_resumed = 1;
} }
...@@ -65,7 +65,7 @@ static void tegra_ehci_power_down(struct usb_hcd *hcd) ...@@ -65,7 +65,7 @@ static void tegra_ehci_power_down(struct usb_hcd *hcd)
struct tegra_ehci_hcd *tegra = dev_get_drvdata(hcd->self.controller); struct tegra_ehci_hcd *tegra = dev_get_drvdata(hcd->self.controller);
tegra->host_resumed = 0; tegra->host_resumed = 0;
usb_phy_set_suspend(&tegra->phy->u_phy, 1); usb_phy_set_suspend(hcd->phy, 1);
clk_disable_unprepare(tegra->clk); clk_disable_unprepare(tegra->clk);
} }
...@@ -159,7 +159,7 @@ static int tegra_ehci_hub_control( ...@@ -159,7 +159,7 @@ static int tegra_ehci_hub_control(
if (tegra->port_resuming && !(temp & PORT_SUSPEND)) { if (tegra->port_resuming && !(temp & PORT_SUSPEND)) {
/* Resume completed, re-enable disconnect detection */ /* Resume completed, re-enable disconnect detection */
tegra->port_resuming = 0; tegra->port_resuming = 0;
tegra_usb_phy_postresume(tegra->phy); tegra_usb_phy_postresume(hcd->phy);
} }
} }
...@@ -212,7 +212,7 @@ static int tegra_ehci_hub_control( ...@@ -212,7 +212,7 @@ static int tegra_ehci_hub_control(
goto done; goto done;
/* Disable disconnect detection during port resume */ /* Disable disconnect detection during port resume */
tegra_usb_phy_preresume(tegra->phy); tegra_usb_phy_preresume(hcd->phy);
ehci->reset_done[wIndex-1] = jiffies + msecs_to_jiffies(25); ehci->reset_done[wIndex-1] = jiffies + msecs_to_jiffies(25);
...@@ -476,7 +476,7 @@ static int controller_resume(struct device *dev) ...@@ -476,7 +476,7 @@ static int controller_resume(struct device *dev)
} }
/* Force the phy to keep data lines in suspend state */ /* Force the phy to keep data lines in suspend state */
tegra_ehci_phy_restore_start(tegra->phy, tegra->port_speed); tegra_ehci_phy_restore_start(hcd->phy, tegra->port_speed);
/* Enable host mode */ /* Enable host mode */
tdi_reset(ehci); tdi_reset(ehci);
...@@ -543,17 +543,17 @@ static int controller_resume(struct device *dev) ...@@ -543,17 +543,17 @@ static int controller_resume(struct device *dev)
} }
} }
tegra_ehci_phy_restore_end(tegra->phy); tegra_ehci_phy_restore_end(hcd->phy);
goto done; goto done;
restart: restart:
if (tegra->port_speed <= TEGRA_USB_PHY_PORT_SPEED_HIGH) if (tegra->port_speed <= TEGRA_USB_PHY_PORT_SPEED_HIGH)
tegra_ehci_phy_restore_end(tegra->phy); tegra_ehci_phy_restore_end(hcd->phy);
tegra_ehci_restart(hcd); tegra_ehci_restart(hcd);
done: done:
tegra_usb_phy_preresume(tegra->phy); tegra_usb_phy_preresume(hcd->phy);
tegra->port_resuming = 1; tegra->port_resuming = 1;
return 0; return 0;
} }
...@@ -740,9 +740,9 @@ static int tegra_ehci_probe(struct platform_device *pdev) ...@@ -740,9 +740,9 @@ static int tegra_ehci_probe(struct platform_device *pdev)
goto fail_io; goto fail_io;
} }
usb_phy_init(&tegra->phy->u_phy);
hcd->phy = u_phy = &tegra->phy->u_phy; hcd->phy = u_phy = &tegra->phy->u_phy;
usb_phy_init(hcd->phy);
u_phy->otg = devm_kzalloc(&pdev->dev, sizeof(struct usb_otg), u_phy->otg = devm_kzalloc(&pdev->dev, sizeof(struct usb_otg),
GFP_KERNEL); GFP_KERNEL);
if (!u_phy->otg) { if (!u_phy->otg) {
...@@ -752,7 +752,7 @@ static int tegra_ehci_probe(struct platform_device *pdev) ...@@ -752,7 +752,7 @@ static int tegra_ehci_probe(struct platform_device *pdev)
} }
u_phy->otg->host = hcd_to_bus(hcd); u_phy->otg->host = hcd_to_bus(hcd);
err = usb_phy_set_suspend(&tegra->phy->u_phy, 0); err = usb_phy_set_suspend(hcd->phy, 0);
if (err) { if (err) {
dev_err(&pdev->dev, "Failed to power on the phy\n"); dev_err(&pdev->dev, "Failed to power on the phy\n");
goto fail; goto fail;
...@@ -798,7 +798,7 @@ static int tegra_ehci_probe(struct platform_device *pdev) ...@@ -798,7 +798,7 @@ static int tegra_ehci_probe(struct platform_device *pdev)
if (!IS_ERR_OR_NULL(tegra->transceiver)) if (!IS_ERR_OR_NULL(tegra->transceiver))
otg_set_host(tegra->transceiver->otg, NULL); otg_set_host(tegra->transceiver->otg, NULL);
#endif #endif
usb_phy_shutdown(&tegra->phy->u_phy); usb_phy_shutdown(hcd->phy);
fail_io: fail_io:
clk_disable_unprepare(tegra->clk); clk_disable_unprepare(tegra->clk);
fail_clk: fail_clk:
...@@ -820,11 +820,10 @@ static int tegra_ehci_remove(struct platform_device *pdev) ...@@ -820,11 +820,10 @@ static int tegra_ehci_remove(struct platform_device *pdev)
otg_set_host(tegra->transceiver->otg, NULL); otg_set_host(tegra->transceiver->otg, NULL);
#endif #endif
usb_phy_shutdown(hcd->phy);
usb_remove_hcd(hcd); usb_remove_hcd(hcd);
usb_put_hcd(hcd); usb_put_hcd(hcd);
usb_phy_shutdown(&tegra->phy->u_phy);
clk_disable_unprepare(tegra->clk); clk_disable_unprepare(tegra->clk);
return 0; return 0;
......
...@@ -759,30 +759,38 @@ struct tegra_usb_phy *tegra_usb_phy_open(struct device *dev, int instance, ...@@ -759,30 +759,38 @@ struct tegra_usb_phy *tegra_usb_phy_open(struct device *dev, int instance,
} }
EXPORT_SYMBOL_GPL(tegra_usb_phy_open); EXPORT_SYMBOL_GPL(tegra_usb_phy_open);
void tegra_usb_phy_preresume(struct tegra_usb_phy *phy) void tegra_usb_phy_preresume(struct usb_phy *x)
{ {
struct tegra_usb_phy *phy = container_of(x, struct tegra_usb_phy, u_phy);
if (!phy->is_ulpi_phy) if (!phy->is_ulpi_phy)
utmi_phy_preresume(phy); utmi_phy_preresume(phy);
} }
EXPORT_SYMBOL_GPL(tegra_usb_phy_preresume); EXPORT_SYMBOL_GPL(tegra_usb_phy_preresume);
void tegra_usb_phy_postresume(struct tegra_usb_phy *phy) void tegra_usb_phy_postresume(struct usb_phy *x)
{ {
struct tegra_usb_phy *phy = container_of(x, struct tegra_usb_phy, u_phy);
if (!phy->is_ulpi_phy) if (!phy->is_ulpi_phy)
utmi_phy_postresume(phy); utmi_phy_postresume(phy);
} }
EXPORT_SYMBOL_GPL(tegra_usb_phy_postresume); EXPORT_SYMBOL_GPL(tegra_usb_phy_postresume);
void tegra_ehci_phy_restore_start(struct tegra_usb_phy *phy, void tegra_ehci_phy_restore_start(struct usb_phy *x,
enum tegra_usb_phy_port_speed port_speed) enum tegra_usb_phy_port_speed port_speed)
{ {
struct tegra_usb_phy *phy = container_of(x, struct tegra_usb_phy, u_phy);
if (!phy->is_ulpi_phy) if (!phy->is_ulpi_phy)
utmi_phy_restore_start(phy, port_speed); utmi_phy_restore_start(phy, port_speed);
} }
EXPORT_SYMBOL_GPL(tegra_ehci_phy_restore_start); EXPORT_SYMBOL_GPL(tegra_ehci_phy_restore_start);
void tegra_ehci_phy_restore_end(struct tegra_usb_phy *phy) void tegra_ehci_phy_restore_end(struct usb_phy *x)
{ {
struct tegra_usb_phy *phy = container_of(x, struct tegra_usb_phy, u_phy);
if (!phy->is_ulpi_phy) if (!phy->is_ulpi_phy)
utmi_phy_restore_end(phy); utmi_phy_restore_end(phy);
} }
......
...@@ -66,14 +66,14 @@ struct tegra_usb_phy { ...@@ -66,14 +66,14 @@ struct tegra_usb_phy {
struct tegra_usb_phy *tegra_usb_phy_open(struct device *dev, int instance, struct tegra_usb_phy *tegra_usb_phy_open(struct device *dev, int instance,
void __iomem *regs, void *config, enum tegra_usb_phy_mode phy_mode); void __iomem *regs, void *config, enum tegra_usb_phy_mode phy_mode);
void tegra_usb_phy_preresume(struct tegra_usb_phy *phy); void tegra_usb_phy_preresume(struct usb_phy *phy);
void tegra_usb_phy_postresume(struct tegra_usb_phy *phy); void tegra_usb_phy_postresume(struct usb_phy *phy);
void tegra_ehci_phy_restore_start(struct tegra_usb_phy *phy, void tegra_ehci_phy_restore_start(struct usb_phy *phy,
enum tegra_usb_phy_port_speed port_speed); enum tegra_usb_phy_port_speed port_speed);
void tegra_ehci_phy_restore_end(struct tegra_usb_phy *phy); void tegra_ehci_phy_restore_end(struct usb_phy *phy);
void tegra_ehci_set_pts(struct usb_phy *x, u8 pts_val); void tegra_ehci_set_pts(struct usb_phy *x, u8 pts_val);
......
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