Commit 9b420eff authored by Heiner Kallweit's avatar Heiner Kallweit Committed by David S. Miller

net: phy: micrel: use phy_read_mmd and phy_write_mmd

This driver implements open-coded versions of phy_read_mmd() and
phy_write_mmd() for KSZ9031. That's not needed, let's use the
phylib functions directly.

This is compile-tested only because I have no such hardware.
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 43deda54
...@@ -426,9 +426,6 @@ static int ksz9021_config_init(struct phy_device *phydev) ...@@ -426,9 +426,6 @@ static int ksz9021_config_init(struct phy_device *phydev)
return 0; return 0;
} }
#define MII_KSZ9031RN_MMD_CTRL_REG 0x0d
#define MII_KSZ9031RN_MMD_REGDATA_REG 0x0e
#define OP_DATA 1
#define KSZ9031_PS_TO_REG 60 #define KSZ9031_PS_TO_REG 60
/* Extended registers */ /* Extended registers */
...@@ -446,24 +443,6 @@ static int ksz9021_config_init(struct phy_device *phydev) ...@@ -446,24 +443,6 @@ static int ksz9021_config_init(struct phy_device *phydev)
#define MII_KSZ9031RN_EDPD 0x23 #define MII_KSZ9031RN_EDPD 0x23
#define MII_KSZ9031RN_EDPD_ENABLE BIT(0) #define MII_KSZ9031RN_EDPD_ENABLE BIT(0)
static int ksz9031_extended_write(struct phy_device *phydev,
u8 mode, u32 dev_addr, u32 regnum, u16 val)
{
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, dev_addr);
phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, regnum);
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, (mode << 14) | dev_addr);
return phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, val);
}
static int ksz9031_extended_read(struct phy_device *phydev,
u8 mode, u32 dev_addr, u32 regnum)
{
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, dev_addr);
phy_write(phydev, MII_KSZ9031RN_MMD_REGDATA_REG, regnum);
phy_write(phydev, MII_KSZ9031RN_MMD_CTRL_REG, (mode << 14) | dev_addr);
return phy_read(phydev, MII_KSZ9031RN_MMD_REGDATA_REG);
}
static int ksz9031_of_load_skew_values(struct phy_device *phydev, static int ksz9031_of_load_skew_values(struct phy_device *phydev,
const struct device_node *of_node, const struct device_node *of_node,
u16 reg, size_t field_sz, u16 reg, size_t field_sz,
...@@ -484,7 +463,7 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev, ...@@ -484,7 +463,7 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev,
return 0; return 0;
if (matches < numfields) if (matches < numfields)
newval = ksz9031_extended_read(phydev, OP_DATA, 2, reg); newval = phy_read_mmd(phydev, 2, reg);
else else
newval = 0; newval = 0;
...@@ -498,7 +477,7 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev, ...@@ -498,7 +477,7 @@ static int ksz9031_of_load_skew_values(struct phy_device *phydev,
<< (field_sz * i)); << (field_sz * i));
} }
return ksz9031_extended_write(phydev, OP_DATA, 2, reg, newval); return phy_write_mmd(phydev, 2, reg, newval);
} }
/* Center KSZ9031RNX FLP timing at 16ms. */ /* Center KSZ9031RNX FLP timing at 16ms. */
...@@ -506,13 +485,13 @@ static int ksz9031_center_flp_timing(struct phy_device *phydev) ...@@ -506,13 +485,13 @@ static int ksz9031_center_flp_timing(struct phy_device *phydev)
{ {
int result; int result;
result = ksz9031_extended_write(phydev, OP_DATA, 0, result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_HI,
MII_KSZ9031RN_FLP_BURST_TX_HI, 0x0006); 0x0006);
if (result) if (result)
return result; return result;
result = ksz9031_extended_write(phydev, OP_DATA, 0, result = phy_write_mmd(phydev, 0, MII_KSZ9031RN_FLP_BURST_TX_LO,
MII_KSZ9031RN_FLP_BURST_TX_LO, 0x1A80); 0x1A80);
if (result) if (result)
return result; return result;
...@@ -524,10 +503,10 @@ static int ksz9031_enable_edpd(struct phy_device *phydev) ...@@ -524,10 +503,10 @@ static int ksz9031_enable_edpd(struct phy_device *phydev)
{ {
int reg; int reg;
reg = ksz9031_extended_read(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD); reg = phy_read_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD);
if (reg < 0) if (reg < 0)
return reg; return reg;
return ksz9031_extended_write(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD, return phy_write_mmd(phydev, 0x1C, MII_KSZ9031RN_EDPD,
reg | MII_KSZ9031RN_EDPD_ENABLE); reg | MII_KSZ9031RN_EDPD_ENABLE);
} }
...@@ -654,7 +633,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev, ...@@ -654,7 +633,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev,
return 0; return 0;
if (matches < numfields) if (matches < numfields)
newval = ksz9031_extended_read(phydev, OP_DATA, 2, reg); newval = phy_read_mmd(phydev, 2, reg);
else else
newval = 0; newval = 0;
...@@ -668,7 +647,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev, ...@@ -668,7 +647,7 @@ static int ksz9131_of_load_skew_values(struct phy_device *phydev,
<< (field_sz * i)); << (field_sz * i));
} }
return ksz9031_extended_write(phydev, OP_DATA, 2, reg, newval); return phy_write_mmd(phydev, 2, reg, newval);
} }
static int ksz9131_config_init(struct phy_device *phydev) static int ksz9131_config_init(struct phy_device *phydev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment