 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			126 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 2e4ea707c7e04eb83e58c43e0e744bbdf6b23ff2 Mon Sep 17 00:00:00 2001
 | |
| From: Eric Woudstra <ericwouds@gmail.com>
 | |
| Date: Tue, 9 Apr 2024 09:30:14 +0200
 | |
| Subject: [PATCH] net: phy: realtek: Change rtlgen_get_speed() to
 | |
|  rtlgen_decode_speed()
 | |
| 
 | |
| The value of the register to determine the speed, is retrieved
 | |
| differently when using Clause 45 only. To use the rtlgen_get_speed()
 | |
| function in this case, pass the value of the register as argument to
 | |
| rtlgen_get_speed(). The function would then always return 0, so change it
 | |
| to void. A better name for this function now is rtlgen_decode_speed().
 | |
| 
 | |
| Replace a call to genphy_read_status() followed by rtlgen_get_speed()
 | |
| with a call to rtlgen_read_status() in rtl822x_read_status().
 | |
| 
 | |
| Add reading speed to rtl822x_c45_read_status().
 | |
| 
 | |
| Signed-off-by: Eric Woudstra <ericwouds@gmail.com>
 | |
| 
 | |
| Reviewed-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
 | |
| Signed-off-by: David S. Miller <davem@davemloft.net>
 | |
| ---
 | |
|  drivers/net/phy/realtek.c | 46 +++++++++++++++++++++------------------
 | |
|  1 file changed, 25 insertions(+), 21 deletions(-)
 | |
| 
 | |
| --- a/drivers/net/phy/realtek.c
 | |
| +++ b/drivers/net/phy/realtek.c
 | |
| @@ -71,6 +71,8 @@
 | |
|  
 | |
|  #define RTL822X_VND2_GANLPAR				0xa414
 | |
|  
 | |
| +#define RTL822X_VND2_PHYSR				0xa434
 | |
| +
 | |
|  #define RTL8366RB_POWER_SAVE			0x15
 | |
|  #define RTL8366RB_POWER_SAVE_ON			BIT(12)
 | |
|  
 | |
| @@ -551,17 +553,8 @@ static int rtl8366rb_config_init(struct
 | |
|  }
 | |
|  
 | |
|  /* get actual speed to cover the downshift case */
 | |
| -static int rtlgen_get_speed(struct phy_device *phydev)
 | |
| +static void rtlgen_decode_speed(struct phy_device *phydev, int val)
 | |
|  {
 | |
| -	int val;
 | |
| -
 | |
| -	if (!phydev->link)
 | |
| -		return 0;
 | |
| -
 | |
| -	val = phy_read_paged(phydev, 0xa43, 0x12);
 | |
| -	if (val < 0)
 | |
| -		return val;
 | |
| -
 | |
|  	switch (val & RTLGEN_SPEED_MASK) {
 | |
|  	case 0x0000:
 | |
|  		phydev->speed = SPEED_10;
 | |
| @@ -584,19 +577,26 @@ static int rtlgen_get_speed(struct phy_d
 | |
|  	default:
 | |
|  		break;
 | |
|  	}
 | |
| -
 | |
| -	return 0;
 | |
|  }
 | |
|  
 | |
|  static int rtlgen_read_status(struct phy_device *phydev)
 | |
|  {
 | |
| -	int ret;
 | |
| +	int ret, val;
 | |
|  
 | |
|  	ret = genphy_read_status(phydev);
 | |
|  	if (ret < 0)
 | |
|  		return ret;
 | |
|  
 | |
| -	return rtlgen_get_speed(phydev);
 | |
| +	if (!phydev->link)
 | |
| +		return 0;
 | |
| +
 | |
| +	val = phy_read_paged(phydev, 0xa43, 0x12);
 | |
| +	if (val < 0)
 | |
| +		return val;
 | |
| +
 | |
| +	rtlgen_decode_speed(phydev, val);
 | |
| +
 | |
| +	return 0;
 | |
|  }
 | |
|  
 | |
|  static int rtlgen_read_mmd(struct phy_device *phydev, int devnum, u16 regnum)
 | |
| @@ -817,8 +817,6 @@ static void rtl822xb_update_interface(st
 | |
|  
 | |
|  static int rtl822x_read_status(struct phy_device *phydev)
 | |
|  {
 | |
| -	int ret;
 | |
| -
 | |
|  	if (phydev->autoneg == AUTONEG_ENABLE) {
 | |
|  		int lpadv = phy_read_paged(phydev, 0xa5d, 0x13);
 | |
|  
 | |
| @@ -829,11 +827,7 @@ static int rtl822x_read_status(struct ph
 | |
|  						  lpadv);
 | |
|  	}
 | |
|  
 | |
| -	ret = genphy_read_status(phydev);
 | |
| -	if (ret < 0)
 | |
| -		return ret;
 | |
| -
 | |
| -	return rtlgen_get_speed(phydev);
 | |
| +	return rtlgen_read_status(phydev);
 | |
|  }
 | |
|  
 | |
|  static int rtl822xb_read_status(struct phy_device *phydev)
 | |
| @@ -894,6 +888,16 @@ static int rtl822x_c45_read_status(struc
 | |
|  		mii_stat1000_mod_linkmode_lpa_t(phydev->lp_advertising, val);
 | |
|  	}
 | |
|  
 | |
| +	if (!phydev->link)
 | |
| +		return 0;
 | |
| +
 | |
| +	/* Read actual speed from vendor register. */
 | |
| +	val = phy_read_mmd(phydev, MDIO_MMD_VEND2, RTL822X_VND2_PHYSR);
 | |
| +	if (val < 0)
 | |
| +		return val;
 | |
| +
 | |
| +	rtlgen_decode_speed(phydev, val);
 | |
| +
 | |
|  	return 0;
 | |
|  }
 | |
|  
 |