On Friday 19 July 2013 06:04 PM, George Cherian wrote: > Remove usb phy control module access from platform glue. > The same is now done using amxxxx phy driver and phy-omap-control. > Adapt the driver to the split dt nodes. This patch should be split. > > Signed-off-by: Sebastian Andrzej Siewior <bigeasy@xxxxxxxxxxxxx> > Signed-off-by: George Cherian <george.cherian@xxxxxx> > --- > drivers/usb/musb/musb_dsps.c | 150 ++++++++++++++++--------------------------- > 1 file changed, 55 insertions(+), 95 deletions(-) > > diff --git a/drivers/usb/musb/musb_dsps.c b/drivers/usb/musb/musb_dsps.c > index 41f135a..6bec458 100644 > --- a/drivers/usb/musb/musb_dsps.c > +++ b/drivers/usb/musb/musb_dsps.c > @@ -43,6 +43,7 @@ > #include <linux/of.h> > #include <linux/of_device.h> > #include <linux/of_address.h> > +#include <linux/of_irq.h> > > #include "musb_core.h" > > @@ -110,8 +111,6 @@ struct dsps_musb_wrapper { > /* miscellaneous stuff */ > u32 musb_core_offset; > u8 poll_seconds; > - /* number of musb instances */ > - u8 instances; > }; > > /** > @@ -123,49 +122,11 @@ struct dsps_glue { > const struct dsps_musb_wrapper *wrp; /* wrapper register offsets */ > struct timer_list timer[2]; /* otg_workaround timer */ > unsigned long last_timer[2]; /* last timer data for each instance */ > - u32 __iomem *usb_ctrl[2]; > }; > > -#define DSPS_AM33XX_CONTROL_MODULE_PHYS_0 0x44e10620 > -#define DSPS_AM33XX_CONTROL_MODULE_PHYS_1 0x44e10628 > +#define glue_to_musb(g, i) platform_get_drvdata(g->musb[i]) > > -static const resource_size_t dsps_control_module_phys[] = { > - DSPS_AM33XX_CONTROL_MODULE_PHYS_0, > - DSPS_AM33XX_CONTROL_MODULE_PHYS_1, > -}; > - > -#define USBPHY_CM_PWRDN (1 << 0) > -#define USBPHY_OTG_PWRDN (1 << 1) > -#define USBPHY_OTGVDET_EN (1 << 19) > -#define USBPHY_OTGSESSEND_EN (1 << 20) > - > -/** > - * musb_dsps_phy_control - phy on/off > - * @glue: struct dsps_glue * > - * @id: musb instance > - * @on: flag for phy to be switched on or off > - * > - * This is to enable the PHY using usb_ctrl register in system control > - * module space. > - * > - * XXX: This function will be removed once we have a seperate driver for > - * control module > - */ > -static void musb_dsps_phy_control(struct dsps_glue *glue, u8 id, u8 on) > -{ > - u32 usbphycfg; > - > - usbphycfg = readl(glue->usb_ctrl[id]); > - > - if (on) { > - usbphycfg &= ~(USBPHY_CM_PWRDN | USBPHY_OTG_PWRDN); > - usbphycfg |= USBPHY_OTGVDET_EN | USBPHY_OTGSESSEND_EN; > - } else { > - usbphycfg |= USBPHY_CM_PWRDN | USBPHY_OTG_PWRDN; > - } > > - writel(usbphycfg, glue->usb_ctrl[id]); > -} > /** > * dsps_musb_enable - enable interrupts > */ > @@ -411,16 +372,28 @@ static int dsps_musb_init(struct musb *musb) > void __iomem *reg_base = musb->ctrl_base; > u32 rev, val; > int status; > + char phyname[12]; > > /* mentor core register starts at offset of 0x400 from musb base */ > musb->mregs += wrp->musb_core_offset; > > - /* NOP driver needs change if supporting dual instance */ > - usb_nop_xceiv_register(); > - musb->xceiv = usb_get_phy(USB_PHY_TYPE_USB2); > + snprintf(phyname , 12, "am335x-usb%d", pdev->id); > + > + if (dev->of_node) { > + musb->phy = devm_phy_get(dev, phyname); > + musb->xceiv = devm_usb_get_phy_by_phandle(dev, > + "phys", 0); > + } else { > + musb->phy = devm_phy_get(dev, musb->phy_label); > + musb->xceiv = devm_usb_get_phy_dev(dev, pdev->id); > + } > + > if (IS_ERR_OR_NULL(musb->xceiv)) > return -EPROBE_DEFER; > > + if (IS_ERR_OR_NULL(musb->phy)) > + return -EPROBE_DEFER; > + > /* Returns zero if e.g. not clocked */ > rev = dsps_readl(reg_base, wrp->revision); > if (!rev) { > @@ -434,7 +407,8 @@ static int dsps_musb_init(struct musb *musb) > dsps_writel(reg_base, wrp->control, (1 << wrp->reset)); > > /* Start the on-chip PHY and its PLL. */ > - musb_dsps_phy_control(glue, pdev->id, 1); > + phy_init(musb->phy); > + phy_power_on(musb->phy); > > musb->isr = dsps_interrupt; > > @@ -448,8 +422,7 @@ static int dsps_musb_init(struct musb *musb) > > return 0; > err0: > - usb_put_phy(musb->xceiv); > - usb_nop_xceiv_unregister(); > + devm_phy_put(dev->parent, musb->phy); > return status; > } > > @@ -462,11 +435,8 @@ static int dsps_musb_exit(struct musb *musb) > del_timer_sync(&glue->timer[pdev->id]); > > /* Shutdown the on-chip PHY and its PLL. */ > - musb_dsps_phy_control(glue, pdev->id, 0); > - > - /* NOP driver needs change if supporting dual instance */ > - usb_put_phy(musb->xceiv); > - usb_nop_xceiv_unregister(); > + phy_power_off(musb->phy); > + phy_exit(musb->phy); > > return 0; > } > @@ -483,49 +453,34 @@ static struct musb_platform_ops dsps_ops = { > > static u64 musb_dmamask = DMA_BIT_MASK(32); > > -static int dsps_create_musb_pdev(struct dsps_glue *glue, u8 id) > +static int dsps_create_musb_pdev(struct dsps_glue *glue, u8 id, > + struct device_node *np) > { > struct device *dev = glue->dev; > struct platform_device *pdev = to_platform_device(dev); > struct musb_hdrc_platform_data *pdata = dev->platform_data; > - struct device_node *np = pdev->dev.of_node; > struct musb_hdrc_config *config; > struct platform_device *musb; > - struct resource *res; > struct resource resources[2]; > char res_name[11]; res_name should be removed. > int ret; > > - resources[0].start = dsps_control_module_phys[id]; > - resources[0].end = resources[0].start + SZ_4 - 1; > - resources[0].flags = IORESOURCE_MEM; > - > - glue->usb_ctrl[id] = devm_ioremap_resource(&pdev->dev, resources); > - if (IS_ERR(glue->usb_ctrl[id])) { > - ret = PTR_ERR(glue->usb_ctrl[id]); > - goto err0; > - } > - > - /* first resource is for usbss, so start index from 1 */ > - res = platform_get_resource(pdev, IORESOURCE_MEM, id + 1); > - if (!res) { > + ret = of_address_to_resource(np, 0, &resources[0]); > + if (ret) { > dev_err(dev, "failed to get memory for instance %d\n", id); > - ret = -ENODEV; > goto err0; > } > - res->parent = NULL; > - resources[0] = *res; > > /* first resource is for usbss, so start index from 1 */ > - res = platform_get_resource(pdev, IORESOURCE_IRQ, id + 1); > - if (!res) { > + ret = of_irq_to_resource(np, 0, &resources[1]); > + if (ret == 0) { > dev_err(dev, "failed to get irq for instance %d\n", id); > - ret = -ENODEV; > + ret = -EINVAL; > goto err0; > } > - res->parent = NULL; > - resources[1] = *res; > - resources[1].name = "mc"; > + resources[0].parent = NULL; > + resources[1].parent = NULL; What's the significance of setting parent to NULL? > + > > /* allocate the child platform device */ > musb = platform_device_alloc("musb-hdrc", PLATFORM_DEVID_AUTO); > @@ -538,6 +493,7 @@ static int dsps_create_musb_pdev(struct dsps_glue *glue, u8 id) > musb->dev.parent = dev; > musb->dev.dma_mask = &musb_dmamask; > musb->dev.coherent_dma_mask = musb_dmamask; > + musb->dev.of_node = of_node_get(np); Do you have a corresponding of_node_put? Thanks Kishon -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html