Prev: MMC: atmel-mci: fix two parameters swapped
Next: [PATCHv9 2.6.34-rc5 1/5] mxc: Update GPIO for USB support on Freescale MX51 Babbage HW
From: Nguyen Dinh-R00091 on 27 Apr 2010 11:30 Hi Daniel, I appreciate your feedback. With PATCHv8 2.6.34-rc5 3/5, I did indeed test that we needed to move mxc_initialize_usb_hw before setting the USBMODE as the reset and restart would clear out the UBSMODE. With PATCHv9, I tested mxc_initialize_usb_hw to see if we really need to reset and restart the USB core, and found that we do not. It must have been from earlier cores that we may have needed to do that. So with PATCHv9, I kept the call to mxc_initialize_usb_hw in the same place as the previous call to usb_control, and remove the reset/restart in mxc_initialize_usb_hw(). I have tested this on my MX51 Babbage board. Thanks, Dinh -----Original Message----- From: Daniel Mack [mailto:daniel(a)caiaq.de] Sent: Monday, April 26, 2010 4:02 PM To: Nguyen Dinh-R00091 Cc: linux-kernel(a)vger.kernel.org; linux-arm-kernel(a)lists.infradead.org; linux(a)arm.linux.org.uk; s.hauer(a)pengutronix.de; valentin.longchamp(a)epfl.ch; grant.likely(a)secretlab.ca; bryan.wu(a)canonical.com; amit.kucheria(a)canonical.com; Li Jun-R65092; Zhang Lily-R58066 Subject: Re: [PATCHv8 2.6.34-rc5 4/5] mxc: Add generic USB HW initialization for MX51 On Thu, Apr 22, 2010 at 11:51:16PM -0500, Dinh.Nguyen(a)freescale.com wrote: [...] > diff --git a/arch/arm/plat-mxc/include/mach/mxc_ehci.h > b/arch/arm/plat-mxc/include/mach/mxc_ehci.h > index 4b9b836..7fc5f99 100644 > --- a/arch/arm/plat-mxc/include/mach/mxc_ehci.h > +++ b/arch/arm/plat-mxc/include/mach/mxc_ehci.h > @@ -25,6 +25,18 @@ > #define MXC_EHCI_INTERNAL_PHY (1 << 7) > #define MXC_EHCI_IPPUE_DOWN (1 << 8) > #define MXC_EHCI_IPPUE_UP (1 << 9) > +#define MXC_EHCI_WAKEUP_ENABLED (1 << 10) > +#define MXC_EHCI_ITC_NO_THRESHOLD (1 << 11) > + > +#define MXC_USBCTRL_OFFSET 0 > +#define MXC_USB_PHY_CTR_FUNC_OFFSET 0x8 > +#define MXC_USB_PHY_CTR_FUNC2_OFFSET 0xc > + > +#define MX5_USBOTHER_REGS_OFFSET 0x800 > + > +/* USB_PHY_CTRL_FUNC2*/ > +#define MX5_USB_UTMI_PHYCTRL1_PLLDIV_MASK 0x3 > +#define MX5_USB_UTMI_PHYCTRL1_PLLDIV_SHIFT 0 > > struct mxc_usbh_platform_data { > int (*init)(struct platform_device *pdev); @@ -35,7 +47,7 @@ struct > mxc_usbh_platform_data { > struct otg_transceiver *otg; > }; > > -int mxc_set_usbcontrol(int port, unsigned int flags); > +int mxc_initialize_usb_hw(int port, unsigned int flags); > > #endif /* __INCLUDE_ASM_ARCH_MXC_EHCI_H */ > > diff --git a/drivers/usb/host/ehci-mxc.c b/drivers/usb/host/ehci-mxc.c > index ead59f4..bb8d092 100644 > --- a/drivers/usb/host/ehci-mxc.c > +++ b/drivers/usb/host/ehci-mxc.c > @@ -191,6 +191,11 @@ static int ehci_mxc_drv_probe(struct platform_device *pdev) > clk_enable(priv->ahbclk); > } > > + /* setup specific usb hw */ > + ret = mxc_initialize_usb_hw(pdev->id, pdata->flags); > + if (ret < 0) > + goto err_init; > + > /* set USBMODE to host mode */ > temp = readl(hcd->regs + USBMODE_OFFSET); > writel(temp | USBMODE_CM_HOST, hcd->regs + USBMODE_OFFSET); @@ > -199,11 +204,6 @@ static int ehci_mxc_drv_probe(struct platform_device *pdev) > writel(pdata->portsc, hcd->regs + PORTSC_OFFSET); > mdelay(10); > > - /* setup USBCONTROL. */ > - ret = mxc_set_usbcontrol(pdev->id, pdata->flags); > - if (ret < 0) > - goto err_init; > - > /* Initialize the transceiver */ > if (pdata->otg) { > pdata->otg->io_priv = hcd->regs + ULPI_VIEWPORT_OFFSET; I think there's still one concern left for the move of this function block, right? Dinh, is this actually necessary? Could you try calling mxc_initialize_usb_hw() from the location where mxc_set_usbcontrol() was used to be called? Or is there anything I overlook? This might look like nit-picking to you, but as Sascha explained, there is a certain risk of breaking functionality for existing boards, and if we can avoid that, we should. Meanwhile, I prepared a patch to clean up plat-mxc/ehci.c. I'll send it out once this series is accepted. Thanks, Daniel -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |