forked from mirrors/linux
		
	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
					
				
					 1 changed files with 16 additions and 0 deletions
				
			
		| 
						 | 
					@ -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…
	
		Reference in a new issue