mirror of
https://github.com/coolsnowwolf/lede.git
synced 2025-06-11 20:52:05 +08:00
49 lines
1.9 KiB
Diff
49 lines
1.9 KiB
Diff
From 8af2136e77989a64fae0284bf76fd584e32edd3a Mon Sep 17 00:00:00 2001
|
|
From: Heiner Kallweit <hkallweit1@gmail.com>
|
|
Date: Fri, 14 Feb 2025 21:31:14 +0100
|
|
Subject: [PATCH] net: phy: realtek: add helper RTL822X_VND2_C22_REG
|
|
|
|
C22 register space is mapped to 0xa400 in MMD VEND2 register space.
|
|
Add a helper to access mapped C22 registers.
|
|
|
|
Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
|
|
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
|
|
Link: https://patch.msgid.link/6344277b-c5c7-449b-ac89-d5425306ca76@gmail.com
|
|
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
|
|
---
|
|
drivers/net/phy/realtek/realtek_main.c | 9 ++++-----
|
|
1 file changed, 4 insertions(+), 5 deletions(-)
|
|
|
|
--- a/drivers/net/phy/realtek/realtek_main.c
|
|
+++ b/drivers/net/phy/realtek/realtek_main.c
|
|
@@ -79,9 +79,7 @@
|
|
/* RTL822X_VND2_XXXXX registers are only accessible when phydev->is_c45
|
|
* is set, they cannot be accessed by C45-over-C22.
|
|
*/
|
|
-#define RTL822X_VND2_GBCR 0xa412
|
|
-
|
|
-#define RTL822X_VND2_GANLPAR 0xa414
|
|
+#define RTL822X_VND2_C22_REG(reg) (0xa400 + 2 * (reg))
|
|
|
|
#define RTL8366RB_POWER_SAVE 0x15
|
|
#define RTL8366RB_POWER_SAVE_ON BIT(12)
|
|
@@ -1015,7 +1013,8 @@ static int rtl822x_c45_config_aneg(struc
|
|
val = linkmode_adv_to_mii_ctrl1000_t(phydev->advertising);
|
|
|
|
/* Vendor register as C45 has no standardized support for 1000BaseT */
|
|
- ret = phy_modify_mmd_changed(phydev, MDIO_MMD_VEND2, RTL822X_VND2_GBCR,
|
|
+ ret = phy_modify_mmd_changed(phydev, MDIO_MMD_VEND2,
|
|
+ RTL822X_VND2_C22_REG(MII_CTRL1000),
|
|
ADVERTISE_1000FULL, val);
|
|
if (ret < 0)
|
|
return ret;
|
|
@@ -1032,7 +1031,7 @@ static int rtl822x_c45_read_status(struc
|
|
/* Vendor register as C45 has no standardized support for 1000BaseT */
|
|
if (phydev->autoneg == AUTONEG_ENABLE && genphy_c45_aneg_done(phydev)) {
|
|
val = phy_read_mmd(phydev, MDIO_MMD_VEND2,
|
|
- RTL822X_VND2_GANLPAR);
|
|
+ RTL822X_VND2_C22_REG(MII_STAT1000));
|
|
if (val < 0)
|
|
return val;
|
|
} else {
|