Skip to content

Commit 65d7e25

Browse files
author
Izabela Bakollari
committed
r8169: add PHY c45 ops for MDIO_MMD_VENDOR2 registers
JIRA: https://issues.redhat.com/browse/RHEL-75590 commit 853e803 Author: Heiner Kallweit <hkallweit1@gmail.com> Date: Thu Feb 13 20:15:42 2025 +0100 r8169: add PHY c45 ops for MDIO_MMD_VENDOR2 registers The integrated PHYs on chip versions from RTL8168g allow to address MDIO_MMD_VEND2 registers. All c22 standard registers are mapped to MDIO_MMD_VEND2 registers. So far the paging mechanism is used to address PHY registers. Add support for c45 ops to address MDIO_MMD_VEND2 registers directly, w/o the paging. Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Link: https://patch.msgid.link/d6f97eaa-0f13-468f-89cb-75a41087bc4a@gmail.com Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Izabela Bakollari <ibakolla@redhat.com>
1 parent 49ffa8f commit 65d7e25

File tree

1 file changed

+32
-0
lines changed

1 file changed

+32
-0
lines changed

drivers/net/ethernet/realtek/r8169_main.c

Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5209,6 +5209,33 @@ static int r8169_mdio_write_reg(struct mii_bus *mii_bus, int phyaddr,
52095209
return 0;
52105210
}
52115211

5212+
static int r8169_mdio_read_reg_c45(struct mii_bus *mii_bus, int addr,
5213+
int devnum, int regnum)
5214+
{
5215+
struct rtl8169_private *tp = mii_bus->priv;
5216+
5217+
if (addr > 0)
5218+
return -ENODEV;
5219+
5220+
if (devnum == MDIO_MMD_VEND2 && regnum > MDIO_STAT2)
5221+
return r8168_phy_ocp_read(tp, regnum);
5222+
5223+
return 0;
5224+
}
5225+
5226+
static int r8169_mdio_write_reg_c45(struct mii_bus *mii_bus, int addr,
5227+
int devnum, int regnum, u16 val)
5228+
{
5229+
struct rtl8169_private *tp = mii_bus->priv;
5230+
5231+
if (addr > 0 || devnum != MDIO_MMD_VEND2 || regnum <= MDIO_STAT2)
5232+
return -ENODEV;
5233+
5234+
r8168_phy_ocp_write(tp, regnum, val);
5235+
5236+
return 0;
5237+
}
5238+
52125239
static int r8169_mdio_register(struct rtl8169_private *tp)
52135240
{
52145241
struct pci_dev *pdev = tp->pci_dev;
@@ -5239,6 +5266,11 @@ static int r8169_mdio_register(struct rtl8169_private *tp)
52395266
new_bus->read = r8169_mdio_read_reg;
52405267
new_bus->write = r8169_mdio_write_reg;
52415268

5269+
if (tp->mac_version >= RTL_GIGA_MAC_VER_40) {
5270+
new_bus->read_c45 = r8169_mdio_read_reg_c45;
5271+
new_bus->write_c45 = r8169_mdio_write_reg_c45;
5272+
}
5273+
52425274
ret = devm_mdiobus_register(&pdev->dev, new_bus);
52435275
if (ret)
52445276
return ret;

0 commit comments

Comments
 (0)