net: phy: broadcom: Wire suspend/resume for BCM54810
The BCM54810 PHY can use the standard BMCR Power down suspend, but needs a custom resume routine which first clear the Power down bit, and then re-initializes the PHY. While in low-power mode, the PHY only accepts writes to the BMCR register. The datasheet clearly says it: Reads or writes to any MII register other than MII Control register (address 00h) while the device is in the standby power-down mode may cause unpredictable results. Reviewed-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
cb64da3a5b
commit
fe26821fa6
@ -313,6 +313,20 @@ static int bcm54xx_config_init(struct phy_device *phydev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int bcm54xx_resume(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
/* Writes to register other than BMCR would be ignored
|
||||||
|
* unless we clear the PDOWN bit first
|
||||||
|
*/
|
||||||
|
ret = genphy_resume(phydev);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
return bcm54xx_config_init(phydev);
|
||||||
|
}
|
||||||
|
|
||||||
static int bcm5482_config_init(struct phy_device *phydev)
|
static int bcm5482_config_init(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
int err, reg;
|
int err, reg;
|
||||||
@ -706,6 +720,8 @@ static struct phy_driver broadcom_drivers[] = {
|
|||||||
.config_aneg = bcm5481_config_aneg,
|
.config_aneg = bcm5481_config_aneg,
|
||||||
.ack_interrupt = bcm_phy_ack_intr,
|
.ack_interrupt = bcm_phy_ack_intr,
|
||||||
.config_intr = bcm_phy_config_intr,
|
.config_intr = bcm_phy_config_intr,
|
||||||
|
.suspend = genphy_suspend,
|
||||||
|
.resume = bcm54xx_resume,
|
||||||
}, {
|
}, {
|
||||||
.phy_id = PHY_ID_BCM5482,
|
.phy_id = PHY_ID_BCM5482,
|
||||||
.phy_id_mask = 0xfffffff0,
|
.phy_id_mask = 0xfffffff0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user