Message ID | 20210630174022.1016525-1-robert.hancock@calian.com |
---|---|
State | New |
Headers | show |
Series | [net-next] net: axienet: Allow phytool access to PCS/PMA PHY | expand |
On Wed, Jun 30, 2021 at 11:40:22AM -0600, Robert Hancock wrote: > Allow phytool ioctl access to read/write registers in the internal > PCS/PMA PHY if it is enabled. I wonder if this is something that should happen in phylink?
On Wed, 2021-06-30 at 18:46 +0100, Russell King (Oracle) wrote: > On Wed, Jun 30, 2021 at 11:40:22AM -0600, Robert Hancock wrote: > > Allow phytool ioctl access to read/write registers in the internal > > PCS/PMA PHY if it is enabled. > > I wonder if this is something that should happen in phylink? > If there are other drivers which have a PCS which could be accessed with phytool etc., it might make sense. Right now phylink core doesn't really have any knowledge that the PCS PHY actually exists as something that can be accessed via MDIO registers, it just talks to it indirectly through the mac_config and mac_pcs_get_state callbacks in the driver which then call back into the c22_pcs helper functions to actually talk to the PCS. I'm not sure phylink could generically assume that the PCS can be accessed over MDIO however, as I believe that the Cadence MACB IP, for example, at least as implemented in the Xilinx ZynqMP parts, exposes its PCS with some PHY-style registers but they are just a portion of the device's register space and not accessed via MDIO, so we'd want to support that kind of setup. I suppose it could implement an emulated MDIO bus to access those registers for that purpose? -- Robert Hancock Senior Hardware Designer, Calian Advanced Technologies www.calian.com
diff --git a/drivers/net/ethernet/xilinx/xilinx_axienet_main.c b/drivers/net/ethernet/xilinx/xilinx_axienet_main.c index 13cd799541aa..41f2c2255118 100644 --- a/drivers/net/ethernet/xilinx/xilinx_axienet_main.c +++ b/drivers/net/ethernet/xilinx/xilinx_axienet_main.c @@ -1213,10 +1213,29 @@ static void axienet_poll_controller(struct net_device *ndev) static int axienet_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) { struct axienet_local *lp = netdev_priv(dev); + struct mii_ioctl_data *mii = if_mii(rq); if (!netif_running(dev)) return -EINVAL; + if (lp->pcs_phy && lp->pcs_phy->addr == mii->phy_id) { + int ret; + + switch (cmd) { + case SIOCGMIIREG: + ret = mdiobus_read(lp->pcs_phy->bus, mii->phy_id, mii->reg_num); + if (ret >= 0) { + mii->val_out = ret; + ret = 0; + } + return ret; + + case SIOCSMIIREG: + return mdiobus_write(lp->pcs_phy->bus, mii->phy_id, + mii->reg_num, mii->val_in); + } + } + return phylink_mii_ioctl(lp->phylink, rq, cmd); }
Allow phytool ioctl access to read/write registers in the internal PCS/PMA PHY if it is enabled. Signed-off-by: Robert Hancock <robert.hancock@calian.com> --- .../net/ethernet/xilinx/xilinx_axienet_main.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+)