Hi,
On Saturday 23 May 2015 01:24 AM, Rob Herring wrote:
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.
Generally the order is init and then power on. During init the driver can
perform the various setting for initializing the PHY which includes PLL
programming, calibration etc.. And then power on which actually starts the PHY
so that PHY can now transfer and receive data.
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.
phy-core has a call to try_module_get with this .owner so that the module is
not removed after phy_get. Maybe we can make phy-core to handle it in some
other way. Need to check.
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