RE: [PATCH 1/2] usb: host: tegra: don't touch EMC clock

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> -----Original Message-----
> From: linux-tegra-owner@xxxxxxxxxxxxxxx [mailto:linux-tegra-
> owner@xxxxxxxxxxxxxxx] On Behalf Of Stephen Warren
> Sent: Wednesday, January 23, 2013 5:58 AM
> To: Alan Stern; Greg Kroah-Hartman; Stephen Warren
> Cc: Venu Byravarasu; linux-tegra@xxxxxxxxxxxxxxx; linux-arm-
> kernel@xxxxxxxxxxxxxxxxxxx; linux-usb@xxxxxxxxxxxxxxx; Stephen Warren
> Subject: [PATCH 1/2] usb: host: tegra: don't touch EMC clock
> 
> From: Stephen Warren <swarren@xxxxxxxxxx>
> 
> Clock "emc" is for the External Memory Controller. The USB driver has no
> business touching this clock directly. Remove the code that does so.

Stephen,
This was primarily done to make sure that EMC is set to a minimum
frequency, below which data errors may occur during USB transfers.
If we plan to remove this, how should we make sure that the EMC
is programmed for the required frequency during USB transfers?
 
> 
> Signed-off-by: Stephen Warren <swarren@xxxxxxxxxx>
> ---
> Greg, Alan, I'd like to take this patch through the Tegra tree to avoid
> any merge conflicts with the Tegra USB changes that have  recently
> happened there.
> 
> Venu, When creating your patch to convert the Tegra USB PHY driver to a
> platform driver, can you assume these patches are applied first? Thanks.
> I assume that these patches make sense to you; could you ack them if so.
> ---
>  drivers/usb/host/ehci-tegra.c |   17 -----------------
>  1 file changed, 17 deletions(-)
> 
> diff --git a/drivers/usb/host/ehci-tegra.c b/drivers/usb/host/ehci-tegra.c
> index 1f596fb..b02622a 100644
> --- a/drivers/usb/host/ehci-tegra.c
> +++ b/drivers/usb/host/ehci-tegra.c
> @@ -44,7 +44,6 @@ struct tegra_ehci_hcd {
>  	struct ehci_hcd *ehci;
>  	struct tegra_usb_phy *phy;
>  	struct clk *clk;
> -	struct clk *emc_clk;
>  	struct usb_phy *transceiver;
>  	int host_resumed;
>  	int port_resuming;
> @@ -56,7 +55,6 @@ static void tegra_ehci_power_up(struct usb_hcd *hcd)
>  {
>  	struct tegra_ehci_hcd *tegra = dev_get_drvdata(hcd->self.controller);
> 
> -	clk_prepare_enable(tegra->emc_clk);
>  	clk_prepare_enable(tegra->clk);
>  	usb_phy_set_suspend(&tegra->phy->u_phy, 0);
>  	tegra->host_resumed = 1;
> @@ -69,7 +67,6 @@ static void tegra_ehci_power_down(struct usb_hcd
> *hcd)
>  	tegra->host_resumed = 0;
>  	usb_phy_set_suspend(&tegra->phy->u_phy, 1);
>  	clk_disable_unprepare(tegra->clk);
> -	clk_disable_unprepare(tegra->emc_clk);
>  }
> 
>  static int tegra_ehci_internal_port_reset(
> @@ -694,16 +691,6 @@ static int tegra_ehci_probe(struct platform_device
> *pdev)
>  	if (err)
>  		goto fail_clk;
> 
> -	tegra->emc_clk = devm_clk_get(&pdev->dev, "emc");
> -	if (IS_ERR(tegra->emc_clk)) {
> -		dev_err(&pdev->dev, "Can't get emc clock\n");
> -		err = PTR_ERR(tegra->emc_clk);
> -		goto fail_emc_clk;
> -	}
> -
> -	clk_prepare_enable(tegra->emc_clk);
> -	clk_set_rate(tegra->emc_clk, 400000000);
> -
>  	tegra->needs_double_reset = of_property_read_bool(pdev-
> >dev.of_node,
>  		"nvidia,needs-double-reset");
> 
> @@ -813,8 +800,6 @@ fail:
>  #endif
>  	usb_phy_shutdown(&tegra->phy->u_phy);
>  fail_io:
> -	clk_disable_unprepare(tegra->emc_clk);
> -fail_emc_clk:
>  	clk_disable_unprepare(tegra->clk);
>  fail_clk:
>  	usb_put_hcd(hcd);
> @@ -842,8 +827,6 @@ static int tegra_ehci_remove(struct platform_device
> *pdev)
> 
>  	clk_disable_unprepare(tegra->clk);
> 
> -	clk_disable_unprepare(tegra->emc_clk);
> -
>  	return 0;
>  }
> 
> --
> 1.7.10.4
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-tegra" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-tegra" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [ARM Kernel]     [Linux ARM]     [Linux ARM MSM]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux