Re: [PATCH 4/5] phy: add Marvell HSIC 28nm PHY

From: Kishon Vijay Abraham I
Date: Tue May 26 2015 - 02:07:47 EST


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-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/