On Thu, May 21, 2015 at 7:51 AM, Kishon Vijay Abraham I <kishon@xxxxxx> wrote: > On Thursday 21 May 2015 06:15 PM, Kishon Vijay Abraham I wrote: >> >> Hi, >> >> On Thursday 14 May 2015 04:18 AM, Rob Herring wrote: >>> >>> Add PHY driver for the Marvell HSIC 28nm PHY. This PHY is found in >>> PXA1928 >>> SOC. [...] >>> + writel(readl(base + PHY_28NM_HSIC_CTRL) & >>> ~PHY_28NM_HSIC_S2H_HSIC_EN, >>> + base + PHY_28NM_HSIC_CTRL); >>> + >>> + clk_disable_unprepare(mv_phy->clk); >>> + return 0; >>> +} >>> + >>> +static const struct phy_ops hsic_ops = { >>> + .init = mv_hsic_phy_init, >>> + .power_on = mv_hsic_phy_power_on, >>> + .power_off = mv_hsic_phy_power_off, >> >> >> exit callback is missing? Shouldn't we turn off the PLLs in exit callback? I really don't understand the division of the ops functions. It seems backwards to me. Don't you need to power on the phy before you can initialize it? Or init is supposed to be s/w init of some kind. AFAICT, all the drivers just call init and power_on back to back. > > Also add the .owner member since this driver can be used as module. Strange. Generally an ops struct just has ops. Rob -- 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