[U-Boot] [PATCH v3 07/10] usb: mxs: Adapt code for i.MX23 support
Marek Vasut
marex at denx.de
Sun Feb 17 22:21:24 CET 2013
Dear Otavio Salvador,
> The i.MX23 just one USB port so we shouldn't mess up with PLL1CTRL and
> USB1 port when building for i.MX23.
>
> Signed-off-by: Otavio Salvador <otavio at ossystems.com.br>
> ---
> Changes in v3:
> - Improve commit log
> - Move code to enable/disable clock to soc_ehci_hcd_{enable,disable}_clock
> - Proper use mx23 clock registers
>
> Changes in v2:
> - Avoid wrong clock setting in MX23
>
> drivers/usb/host/ehci-mxs.c | 78
> ++++++++++++++++++++++++++++++++------------- 1 file changed, 56
> insertions(+), 22 deletions(-)
>
> diff --git a/drivers/usb/host/ehci-mxs.c b/drivers/usb/host/ehci-mxs.c
> index 5062af5..5e41a38 100644
> --- a/drivers/usb/host/ehci-mxs.c
> +++ b/drivers/usb/host/ehci-mxs.c
> @@ -23,7 +23,11 @@
> #include <asm/io.h>
> #include <asm/arch/regs-common.h>
> #include <asm/arch/regs-base.h>
> +#if defined(CONFIG_MX23)
> +#include <asm/arch/regs-clkctrl-mx23.h>
> +#elif defined(CONFIG_MX28)
> #include <asm/arch/regs-clkctrl-mx28.h>
> +#endif
> #include <asm/arch/regs-usb.h>
> #include <asm/arch/regs-usbphy.h>
>
> @@ -50,10 +54,12 @@ int mxs_ehci_get_port(struct ehci_mxs *mxs_usb, int
> port) usb_base = MXS_USBCTRL0_BASE;
> phy_base = MXS_USBPHY0_BASE;
> break;
> +#ifdef CONFIG_MX28
> case 1:
> usb_base = MXS_USBCTRL1_BASE;
> phy_base = MXS_USBPHY1_BASE;
> break;
> +#endif
> default:
> printf("CONFIG_EHCI_MXS_PORT (port = %d)\n", port);
> return -1;
> @@ -67,18 +73,63 @@ int mxs_ehci_get_port(struct ehci_mxs *mxs_usb, int
> port) /* This DIGCTL register ungates clock to USB */
> #define HW_DIGCTL_CTRL 0x8001c000
> #define HW_DIGCTL_CTRL_USB0_CLKGATE (1 << 2)
> +#ifdef CONFIG_MX28
> #define HW_DIGCTL_CTRL_USB1_CLKGATE (1 << 16)
> +#endif
>
> -int ehci_hcd_init(int index, struct ehci_hccr **hccr, struct ehci_hcor
> **hcor) +static void soc_ehci_hcd_enable_clock(void)
> {
> + struct mxs_register_32 *digctl_ctrl =
> + (struct mxs_register_32 *)HW_DIGCTL_CTRL;
> + struct mxs_clkctrl_regs *clkctrl_regs =
> + (struct mxs_clkctrl_regs *)MXS_CLKCTRL_BASE;
>
> - int ret;
> - uint32_t usb_base, cap_base;
> +#if defined(CONFIG_MX23)
> + writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS | CLKCTRL_PLL0CTRL0_POWER,
> + &clkctrl_regs->hw_clkctrl_pll0ctrl0_set);
This stuff above ^
> + writel(HW_DIGCTL_CTRL_USB0_CLKGATE, &digctl_ctrl->reg_clr);
> +#elif defined(CONFIG_MX28)
> + writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS | CLKCTRL_PLL0CTRL0_POWER,
> + &clkctrl_regs->hw_clkctrl_pll0ctrl0_set);
And here ^ looks like the same code, no?
btw. can this not be nicely factored away one simple ifdef CONFIG_MX28 ?
> + writel(CLKCTRL_PLL1CTRL0_EN_USB_CLKS | CLKCTRL_PLL1CTRL0_POWER,
> + &clkctrl_regs->hw_clkctrl_pll1ctrl0_set);
> +
> + writel(HW_DIGCTL_CTRL_USB0_CLKGATE | HW_DIGCTL_CTRL_USB1_CLKGATE,
> + &digctl_ctrl->reg_clr);
> +#endif
> +}
> +
> +static void soc_ehci_hcd_disable_clock(void)
> +{
> struct mxs_register_32 *digctl_ctrl =
> (struct mxs_register_32 *)HW_DIGCTL_CTRL;
> struct mxs_clkctrl_regs *clkctrl_regs =
> (struct mxs_clkctrl_regs *)MXS_CLKCTRL_BASE;
>
> +#if defined(CONFIG_MX23)
> + writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS,
> + &clkctrl_regs->hw_clkctrl_pll0ctrl0_clr);
> +
> + /* Gate off the USB clock */
> + writel(HW_DIGCTL_CTRL_USB0_CLKGATE, &digctl_ctrl->reg_set);
> +#elif defined(CONFIG_MX28)
> + writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS,
> + &clkctrl_regs->hw_clkctrl_pll0ctrl0_clr);
> + writel(CLKCTRL_PLL1CTRL0_EN_USB_CLKS,
> + &clkctrl_regs->hw_clkctrl_pll1ctrl0_clr);
> +
> + /* Gate off the USB clock */
> + writel(HW_DIGCTL_CTRL_USB0_CLKGATE | HW_DIGCTL_CTRL_USB1_CLKGATE,
> + &digctl_ctrl->reg_set);
> +#endif
> +}
> +
> +int ehci_hcd_init(int index, struct ehci_hccr **hccr, struct ehci_hcor
> **hcor) +{
> + int ret;
> + uint32_t usb_base, cap_base;
> +
> ret = mxs_ehci_get_port(&ehci_mxs, CONFIG_EHCI_MXS_PORT);
> if (ret)
> return ret;
> @@ -90,13 +141,7 @@ int ehci_hcd_init(int index, struct ehci_hccr **hccr,
> struct ehci_hcor **hcor) &ehci_mxs.phy_regs->hw_usbphy_ctrl_clr);
>
> /* Enable USB clock */
> - writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS | CLKCTRL_PLL0CTRL0_POWER,
> - &clkctrl_regs->hw_clkctrl_pll0ctrl0_set);
> - writel(CLKCTRL_PLL1CTRL0_EN_USB_CLKS | CLKCTRL_PLL1CTRL0_POWER,
> - &clkctrl_regs->hw_clkctrl_pll1ctrl0_set);
> -
> - writel(HW_DIGCTL_CTRL_USB0_CLKGATE | HW_DIGCTL_CTRL_USB1_CLKGATE,
> - &digctl_ctrl->reg_clr);
> + soc_ehci_hcd_enable_clock();
>
> /* Start USB PHY */
> writel(0, &ehci_mxs.phy_regs->hw_usbphy_pwd);
> @@ -118,10 +163,6 @@ int ehci_hcd_stop(int index)
> {
> int ret;
> uint32_t usb_base, cap_base, tmp;
> - struct mxs_register_32 *digctl_ctrl =
> - (struct mxs_register_32 *)HW_DIGCTL_CTRL;
> - struct mxs_clkctrl_regs *clkctrl_regs =
> - (struct mxs_clkctrl_regs *)MXS_CLKCTRL_BASE;
> struct ehci_hccr *hccr;
> struct ehci_hcor *hcor;
>
> @@ -147,14 +188,7 @@ int ehci_hcd_stop(int index)
> writel(tmp, &ehci_mxs.phy_regs->hw_usbphy_pwd);
>
> /* Disable USB clock */
> - writel(CLKCTRL_PLL0CTRL0_EN_USB_CLKS,
> - &clkctrl_regs->hw_clkctrl_pll0ctrl0_clr);
> - writel(CLKCTRL_PLL1CTRL0_EN_USB_CLKS,
> - &clkctrl_regs->hw_clkctrl_pll1ctrl0_clr);
> -
> - /* Gate off the USB clock */
> - writel(HW_DIGCTL_CTRL_USB0_CLKGATE | HW_DIGCTL_CTRL_USB1_CLKGATE,
> - &digctl_ctrl->reg_set);
> + soc_ehci_hcd_disable_clock();
>
> return 0;
> }
More information about the U-Boot
mailing list