Skip to content

Commit

Permalink
net: phy: realtek: change order of calls in C22 read_status()
Browse files Browse the repository at this point in the history
Always call rtlgen_read_status() first, so genphy_read_status() which
is called by it clears bits in case auto-negotiation has not completed.
Also clear 10GBT link-partner advertisement bits in case auto-negotiation
is disabled or has not completed.

Suggested-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
Link: https://patch.msgid.link/b15929a41621d215c6b2b57393368086589569ec.1728565530.git.daniel@makrotopia.org
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
  • Loading branch information
Daniel Golle authored and Paolo Abeni committed Oct 17, 2024
1 parent 081c9c0 commit 68d5cd0
Showing 1 changed file with 15 additions and 7 deletions.
22 changes: 15 additions & 7 deletions drivers/net/phy/realtek.c
Original file line number Diff line number Diff line change
Expand Up @@ -949,17 +949,25 @@ static void rtl822xb_update_interface(struct phy_device *phydev)

static int rtl822x_read_status(struct phy_device *phydev)
{
if (phydev->autoneg == AUTONEG_ENABLE) {
int lpadv = phy_read_paged(phydev, 0xa5d, 0x13);
int lpadv, ret;

if (lpadv < 0)
return lpadv;
ret = rtlgen_read_status(phydev);
if (ret < 0)
return ret;

mii_10gbt_stat_mod_linkmode_lpa_t(phydev->lp_advertising,
lpadv);
if (phydev->autoneg == AUTONEG_DISABLE ||
!phydev->autoneg_complete) {
mii_10gbt_stat_mod_linkmode_lpa_t(phydev->lp_advertising, 0);
return 0;
}

return rtlgen_read_status(phydev);
lpadv = phy_read_paged(phydev, 0xa5d, 0x13);
if (lpadv < 0)
return lpadv;

mii_10gbt_stat_mod_linkmode_lpa_t(phydev->lp_advertising, lpadv);

return 0;
}

static int rtl822xb_read_status(struct phy_device *phydev)
Expand Down

0 comments on commit 68d5cd0

Please sign in to comment.