Commit 8fefcfdd authored by Thierry Reding's avatar Thierry Reding Committed by Greg Kroah-Hartman

USB: EHCI: tegra: Fix oops in error cleanup

Under some circumstances it happens that the connected PHY can't be
powered up properly, in which case the cleanup path currently crashes
because it checks the tegra->transceiver field using !IS_ERR(), which
will succeed because it is in fact NULL. Dereferencing that pointer
causes an oops in tegra_ehci_probe().

This patch fixes the issue by adding an additional label into the
cleanup path to separately take down the PHY and the transceiver.
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
Reviewed-by: default avatarStephen Warren <swarren@nvidia.com>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c19d14d6
...@@ -478,15 +478,15 @@ static int tegra_ehci_probe(struct platform_device *pdev) ...@@ -478,15 +478,15 @@ static int tegra_ehci_probe(struct platform_device *pdev)
err = usb_add_hcd(hcd, irq, IRQF_SHARED); err = usb_add_hcd(hcd, irq, IRQF_SHARED);
if (err) { if (err) {
dev_err(&pdev->dev, "Failed to add USB HCD\n"); dev_err(&pdev->dev, "Failed to add USB HCD\n");
goto cleanup_phy; goto cleanup_transceiver;
} }
return err; return err;
cleanup_phy: cleanup_transceiver:
if (!IS_ERR(tegra->transceiver)) if (!IS_ERR(tegra->transceiver))
otg_set_host(tegra->transceiver->otg, NULL); otg_set_host(tegra->transceiver->otg, NULL);
cleanup_phy:
usb_phy_shutdown(hcd->phy); usb_phy_shutdown(hcd->phy);
cleanup_clk_en: cleanup_clk_en:
clk_disable_unprepare(tegra->clk); clk_disable_unprepare(tegra->clk);
......
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