openwrt/target/linux/ar71xx/patches-3.10/424-net-phy-add-phy_mmd_rea...

41 lines
1.3 KiB
Diff

--- a/drivers/net/phy/phy.c
+++ b/drivers/net/phy/phy.c
@@ -1009,6 +1009,12 @@ static int phy_read_mmd_indirect(struct
return ret;
}
+int phy_read_mmd(struct phy_device *phydev, int prtad, int devad, int addr)
+{
+ return phy_read_mmd_indirect(phydev->bus, prtad, devad, phydev->addr);
+}
+EXPORT_SYMBOL(phy_read_mmd);
+
/**
* phy_write_mmd_indirect - writes data to the MMD registers
* @bus: the target MII bus
@@ -1034,6 +1040,12 @@ static void phy_write_mmd_indirect(struc
bus->write(bus, addr, MII_MMD_DATA, data);
}
+void phy_write_mmd(struct phy_device *phydev, int prtad, int devad, u16 data)
+{
+ phy_write_mmd_indirect(phydev->bus, prtad, devad, phydev->addr, data);
+}
+EXPORT_SYMBOL(phy_write_mmd);
+
/**
* phy_init_eee - init and check the EEE feature
* @phydev: target phy_device struct
--- a/include/linux/phy.h
+++ b/include/linux/phy.h
@@ -580,6 +580,9 @@ int phy_register_fixup_for_uid(u32 phy_u
int (*run)(struct phy_device *));
int phy_scan_fixups(struct phy_device *phydev);
+int phy_read_mmd(struct phy_device *phydev, int prtad, int devad, int addr);
+void phy_write_mmd(struct phy_device *phydev, int prtad, int devad, u16 data);
+
int phy_init_eee(struct phy_device *phydev, bool clk_stop_enable);
int phy_get_eee_err(struct phy_device *phydev);
int phy_ethtool_set_eee(struct phy_device *phydev, struct ethtool_eee *data);