phy: micrel.c: Enable ksz9031 energy-detect power-down mode
Set bit 0 in register 1C.23 to enable the EDPD feature of the KSZ9031 PHY. This reduces power consumption when the link is down. Signed-off-by: Mike Looijmans <mike.looijmans@topic.nl> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
a44c984f1e
commit
af70c1f92d
|
@ -439,6 +439,10 @@ static int ksz9021_config_init(struct phy_device *phydev)
|
||||||
#define MII_KSZ9031RN_TX_DATA_PAD_SKEW 6
|
#define MII_KSZ9031RN_TX_DATA_PAD_SKEW 6
|
||||||
#define MII_KSZ9031RN_CLK_PAD_SKEW 8
|
#define MII_KSZ9031RN_CLK_PAD_SKEW 8
|
||||||
|
|
||||||
|
/* MMD Address 0x1C */
|
||||||
|
#define MII_KSZ9031RN_EDPD 0x23
|
||||||
|
#define MII_KSZ9031RN_EDPD_ENABLE BIT(0)
|
||||||
|
|
||||||
static int ksz9031_extended_write(struct phy_device *phydev,
|
static int ksz9031_extended_write(struct phy_device *phydev,
|
||||||
u8 mode, u32 dev_addr, u32 regnum, u16 val)
|
u8 mode, u32 dev_addr, u32 regnum, u16 val)
|
||||||
{
|
{
|
||||||
|
@ -510,6 +514,18 @@ static int ksz9031_center_flp_timing(struct phy_device *phydev)
|
||||||
return genphy_restart_aneg(phydev);
|
return genphy_restart_aneg(phydev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Enable energy-detect power-down mode */
|
||||||
|
static int ksz9031_enable_edpd(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
int reg;
|
||||||
|
|
||||||
|
reg = ksz9031_extended_read(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD);
|
||||||
|
if (reg < 0)
|
||||||
|
return reg;
|
||||||
|
return ksz9031_extended_write(phydev, OP_DATA, 0x1C, MII_KSZ9031RN_EDPD,
|
||||||
|
reg | MII_KSZ9031RN_EDPD_ENABLE);
|
||||||
|
}
|
||||||
|
|
||||||
static int ksz9031_config_init(struct phy_device *phydev)
|
static int ksz9031_config_init(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
const struct device *dev = &phydev->mdio.dev;
|
const struct device *dev = &phydev->mdio.dev;
|
||||||
|
@ -525,6 +541,11 @@ static int ksz9031_config_init(struct phy_device *phydev)
|
||||||
};
|
};
|
||||||
static const char *control_skews[2] = {"txen-skew-ps", "rxdv-skew-ps"};
|
static const char *control_skews[2] = {"txen-skew-ps", "rxdv-skew-ps"};
|
||||||
const struct device *dev_walker;
|
const struct device *dev_walker;
|
||||||
|
int result;
|
||||||
|
|
||||||
|
result = ksz9031_enable_edpd(phydev);
|
||||||
|
if (result < 0)
|
||||||
|
return result;
|
||||||
|
|
||||||
/* The Micrel driver has a deprecated option to place phy OF
|
/* The Micrel driver has a deprecated option to place phy OF
|
||||||
* properties in the MAC node. Walk up the tree of devices to
|
* properties in the MAC node. Walk up the tree of devices to
|
||||||
|
|
Loading…
Reference in New Issue