mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	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…
	
		Reference in New Issue
	
	Block a user
	 Florian Fainelli
						Florian Fainelli