mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-25 05:47:00 +00:00
generic: 6.6: backport upstream Realtek PHY patches
8989bad54113 net: phy: realtek: add RTL8125D-internal PHY f87a17ed3b51 net: phy: realtek: merge the drivers for internal NBase-T PHY's Signed-off-by: Álvaro Fernández Rojas <noltari@gmail.com> (cherry picked from commit fedb1f86b50986a962c899d7406566d991e030ee)
This commit is contained in:
parent
111c62a06a
commit
56b19f0d50
@ -0,0 +1,136 @@
|
|||||||
|
From f87a17ed3b51fba4dfdd8f8b643b5423a85fc551 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Heiner Kallweit <hkallweit1@gmail.com>
|
||||||
|
Date: Tue, 15 Oct 2024 07:47:14 +0200
|
||||||
|
Subject: [PATCH] net: phy: realtek: merge the drivers for internal NBase-T
|
||||||
|
PHY's
|
||||||
|
|
||||||
|
The Realtek RTL8125/RTL8126 NBase-T MAC/PHY chips have internal PHY's
|
||||||
|
which are register-compatible, at least for the registers we use here.
|
||||||
|
So let's use just one PHY driver to support all of them.
|
||||||
|
These internal PHY's exist also as external C45 PHY's, but on the
|
||||||
|
internal PHY's no access to MMD registers is possible. This can be
|
||||||
|
used to differentiate between the internal and external version.
|
||||||
|
|
||||||
|
As a side effect the drivers for two now external-only drivers don't
|
||||||
|
require read_mmd/write_mmd hooks any longer.
|
||||||
|
|
||||||
|
Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
|
||||||
|
Link: https://patch.msgid.link/c57081a6-811f-4571-ab35-34f4ca6de9af@gmail.com
|
||||||
|
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
|
||||||
|
---
|
||||||
|
drivers/net/phy/realtek.c | 53 +++++++++++++++++++++++++++++++--------
|
||||||
|
1 file changed, 43 insertions(+), 10 deletions(-)
|
||||||
|
|
||||||
|
--- a/drivers/net/phy/realtek.c
|
||||||
|
+++ b/drivers/net/phy/realtek.c
|
||||||
|
@@ -95,6 +95,7 @@
|
||||||
|
|
||||||
|
#define RTL_GENERIC_PHYID 0x001cc800
|
||||||
|
#define RTL_8211FVD_PHYID 0x001cc878
|
||||||
|
+#define RTL_8221B 0x001cc840
|
||||||
|
#define RTL_8221B_VB_CG 0x001cc849
|
||||||
|
#define RTL_8221B_VN_CG 0x001cc84a
|
||||||
|
#define RTL_8251B 0x001cc862
|
||||||
|
@@ -1077,6 +1078,23 @@ static bool rtlgen_supports_2_5gbps(stru
|
||||||
|
return val >= 0 && val & MDIO_PMA_SPEED_2_5G;
|
||||||
|
}
|
||||||
|
|
||||||
|
+/* On internal PHY's MMD reads over C22 always return 0.
|
||||||
|
+ * Check a MMD register which is known to be non-zero.
|
||||||
|
+ */
|
||||||
|
+static bool rtlgen_supports_mmd(struct phy_device *phydev)
|
||||||
|
+{
|
||||||
|
+ int val;
|
||||||
|
+
|
||||||
|
+ phy_lock_mdio_bus(phydev);
|
||||||
|
+ __phy_write(phydev, MII_MMD_CTRL, MDIO_MMD_PCS);
|
||||||
|
+ __phy_write(phydev, MII_MMD_DATA, MDIO_PCS_EEE_ABLE);
|
||||||
|
+ __phy_write(phydev, MII_MMD_CTRL, MDIO_MMD_PCS | MII_MMD_CTRL_NOINCR);
|
||||||
|
+ val = __phy_read(phydev, MII_MMD_DATA);
|
||||||
|
+ phy_unlock_mdio_bus(phydev);
|
||||||
|
+
|
||||||
|
+ return val > 0;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static int rtlgen_match_phy_device(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
return phydev->phy_id == RTL_GENERIC_PHYID &&
|
||||||
|
@@ -1086,7 +1104,8 @@ static int rtlgen_match_phy_device(struc
|
||||||
|
static int rtl8226_match_phy_device(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
return phydev->phy_id == RTL_GENERIC_PHYID &&
|
||||||
|
- rtlgen_supports_2_5gbps(phydev);
|
||||||
|
+ rtlgen_supports_2_5gbps(phydev) &&
|
||||||
|
+ rtlgen_supports_mmd(phydev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int rtlgen_is_c45_match(struct phy_device *phydev, unsigned int id,
|
||||||
|
@@ -1098,6 +1117,11 @@ static int rtlgen_is_c45_match(struct ph
|
||||||
|
return !is_c45 && (id == phydev->phy_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int rtl8221b_match_phy_device(struct phy_device *phydev)
|
||||||
|
+{
|
||||||
|
+ return phydev->phy_id == RTL_8221B && rtlgen_supports_mmd(phydev);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static int rtl8221b_vb_cg_c22_match_phy_device(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
return rtlgen_is_c45_match(phydev, RTL_8221B_VB_CG, false);
|
||||||
|
@@ -1118,9 +1142,21 @@ static int rtl8221b_vn_cg_c45_match_phy_
|
||||||
|
return rtlgen_is_c45_match(phydev, RTL_8221B_VN_CG, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static int rtl8251b_c22_match_phy_device(struct phy_device *phydev)
|
||||||
|
+static int rtl_internal_nbaset_match_phy_device(struct phy_device *phydev)
|
||||||
|
{
|
||||||
|
- return rtlgen_is_c45_match(phydev, RTL_8251B, false);
|
||||||
|
+ if (phydev->is_c45)
|
||||||
|
+ return false;
|
||||||
|
+
|
||||||
|
+ switch (phydev->phy_id) {
|
||||||
|
+ case RTL_GENERIC_PHYID:
|
||||||
|
+ case RTL_8221B:
|
||||||
|
+ case RTL_8251B:
|
||||||
|
+ break;
|
||||||
|
+ default:
|
||||||
|
+ return false;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return rtlgen_supports_2_5gbps(phydev) && !rtlgen_supports_mmd(phydev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int rtl8251b_c45_match_phy_device(struct phy_device *phydev)
|
||||||
|
@@ -1382,10 +1418,8 @@ static struct phy_driver realtek_drvs[]
|
||||||
|
.resume = rtlgen_resume,
|
||||||
|
.read_page = rtl821x_read_page,
|
||||||
|
.write_page = rtl821x_write_page,
|
||||||
|
- .read_mmd = rtl822x_read_mmd,
|
||||||
|
- .write_mmd = rtl822x_write_mmd,
|
||||||
|
}, {
|
||||||
|
- PHY_ID_MATCH_EXACT(0x001cc840),
|
||||||
|
+ .match_phy_device = rtl8221b_match_phy_device,
|
||||||
|
.name = "RTL8226B_RTL8221B 2.5Gbps PHY",
|
||||||
|
.get_features = rtl822x_get_features,
|
||||||
|
.config_aneg = rtl822x_config_aneg,
|
||||||
|
@@ -1396,8 +1430,6 @@ static struct phy_driver realtek_drvs[]
|
||||||
|
.resume = rtlgen_resume,
|
||||||
|
.read_page = rtl821x_read_page,
|
||||||
|
.write_page = rtl821x_write_page,
|
||||||
|
- .read_mmd = rtl822x_read_mmd,
|
||||||
|
- .write_mmd = rtl822x_write_mmd,
|
||||||
|
}, {
|
||||||
|
PHY_ID_MATCH_EXACT(0x001cc838),
|
||||||
|
.name = "RTL8226-CG 2.5Gbps PHY",
|
||||||
|
@@ -1475,8 +1507,9 @@ static struct phy_driver realtek_drvs[]
|
||||||
|
.read_page = rtl821x_read_page,
|
||||||
|
.write_page = rtl821x_write_page,
|
||||||
|
}, {
|
||||||
|
- .match_phy_device = rtl8251b_c22_match_phy_device,
|
||||||
|
- .name = "RTL8126A-internal 5Gbps PHY",
|
||||||
|
+ .match_phy_device = rtl_internal_nbaset_match_phy_device,
|
||||||
|
+ .name = "Realtek Internal NBASE-T PHY",
|
||||||
|
+ .flags = PHY_IS_INTERNAL,
|
||||||
|
.get_features = rtl822x_get_features,
|
||||||
|
.config_aneg = rtl822x_config_aneg,
|
||||||
|
.read_status = rtl822x_read_status,
|
@ -0,0 +1,29 @@
|
|||||||
|
From 8989bad541133c43550bff2b80edbe37b8fb9659 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Heiner Kallweit <hkallweit1@gmail.com>
|
||||||
|
Date: Thu, 17 Oct 2024 18:01:13 +0200
|
||||||
|
Subject: [PATCH] net: phy: realtek: add RTL8125D-internal PHY
|
||||||
|
|
||||||
|
The first boards show up with Realtek's RTL8125D. This MAC/PHY chip
|
||||||
|
comes with an integrated 2.5Gbps PHY with ID 0x001cc841. It's not
|
||||||
|
clear yet whether there's an external version of this PHY and how
|
||||||
|
Realtek calls it, therefore use the numeric id for now.
|
||||||
|
|
||||||
|
Link: https://lore.kernel.org/netdev/2ada65e1-5dfa-456c-9334-2bc51272e9da@gmail.com/T/
|
||||||
|
Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
|
||||||
|
Message-ID: <7d2924de-053b-44d2-a479-870dc3878170@gmail.com>
|
||||||
|
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
|
||||||
|
Signed-off-by: Andrew Lunn <andrew@lunn.ch>
|
||||||
|
---
|
||||||
|
drivers/net/phy/realtek.c | 1 +
|
||||||
|
1 file changed, 1 insertion(+)
|
||||||
|
|
||||||
|
--- a/drivers/net/phy/realtek.c
|
||||||
|
+++ b/drivers/net/phy/realtek.c
|
||||||
|
@@ -1151,6 +1151,7 @@ static int rtl_internal_nbaset_match_phy
|
||||||
|
case RTL_GENERIC_PHYID:
|
||||||
|
case RTL_8221B:
|
||||||
|
case RTL_8251B:
|
||||||
|
+ case 0x001cc841:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
@ -15,7 +15,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
|
|
||||||
--- a/drivers/net/phy/realtek.c
|
--- a/drivers/net/phy/realtek.c
|
||||||
+++ b/drivers/net/phy/realtek.c
|
+++ b/drivers/net/phy/realtek.c
|
||||||
@@ -1375,6 +1375,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1412,6 +1412,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.name = "RTL8226 2.5Gbps PHY",
|
.name = "RTL8226 2.5Gbps PHY",
|
||||||
.match_phy_device = rtl8226_match_phy_device,
|
.match_phy_device = rtl8226_match_phy_device,
|
||||||
@ -23,15 +23,15 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.read_status = rtl822x_read_status,
|
.read_status = rtl822x_read_status,
|
||||||
@@ -1387,6 +1388,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1422,6 +1423,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
PHY_ID_MATCH_EXACT(0x001cc840),
|
.match_phy_device = rtl8221b_match_phy_device,
|
||||||
.name = "RTL8226B_RTL8221B 2.5Gbps PHY",
|
.name = "RTL8226B_RTL8221B 2.5Gbps PHY",
|
||||||
+ .soft_reset = genphy_soft_reset,
|
+ .soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
@@ -1401,6 +1403,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1434,6 +1436,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
PHY_ID_MATCH_EXACT(0x001cc838),
|
PHY_ID_MATCH_EXACT(0x001cc838),
|
||||||
.name = "RTL8226-CG 2.5Gbps PHY",
|
.name = "RTL8226-CG 2.5Gbps PHY",
|
||||||
@ -39,7 +39,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.read_status = rtl822x_read_status,
|
.read_status = rtl822x_read_status,
|
||||||
@@ -1411,6 +1414,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1444,6 +1447,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
PHY_ID_MATCH_EXACT(0x001cc848),
|
PHY_ID_MATCH_EXACT(0x001cc848),
|
||||||
.name = "RTL8226B-CG_RTL8221B-CG 2.5Gbps PHY",
|
.name = "RTL8226B-CG_RTL8221B-CG 2.5Gbps PHY",
|
||||||
@ -47,7 +47,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
@@ -1423,6 +1427,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1456,6 +1460,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
||||||
@ -55,7 +55,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
@@ -1435,6 +1440,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1468,6 +1473,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
||||||
@ -63,7 +63,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
.get_rate_matching = rtl822xb_get_rate_matching,
|
.get_rate_matching = rtl822xb_get_rate_matching,
|
||||||
.get_features = rtl822x_c45_get_features,
|
.get_features = rtl822x_c45_get_features,
|
||||||
@@ -1445,6 +1451,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1478,6 +1484,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
||||||
@ -71,7 +71,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
@@ -1457,6 +1464,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1490,6 +1497,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
||||||
|
@ -20,7 +20,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
|
|
||||||
--- a/drivers/net/phy/realtek.c
|
--- a/drivers/net/phy/realtek.c
|
||||||
+++ b/drivers/net/phy/realtek.c
|
+++ b/drivers/net/phy/realtek.c
|
||||||
@@ -814,8 +814,8 @@ static int rtl822x_write_mmd(struct phy_
|
@@ -815,8 +815,8 @@ static int rtl822x_write_mmd(struct phy_
|
||||||
static int rtl822xb_config_init(struct phy_device *phydev)
|
static int rtl822xb_config_init(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
bool has_2500, has_sgmii;
|
bool has_2500, has_sgmii;
|
||||||
@ -30,7 +30,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
|
|
||||||
has_2500 = test_bit(PHY_INTERFACE_MODE_2500BASEX,
|
has_2500 = test_bit(PHY_INTERFACE_MODE_2500BASEX,
|
||||||
phydev->host_interfaces) ||
|
phydev->host_interfaces) ||
|
||||||
@@ -865,7 +865,29 @@ static int rtl822xb_config_init(struct p
|
@@ -866,7 +866,29 @@ static int rtl822xb_config_init(struct p
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
|
|
||||||
--- a/drivers/net/phy/realtek.c
|
--- a/drivers/net/phy/realtek.c
|
||||||
+++ b/drivers/net/phy/realtek.c
|
+++ b/drivers/net/phy/realtek.c
|
||||||
@@ -1092,9 +1092,11 @@ static bool rtlgen_supports_2_5gbps(stru
|
@@ -1093,9 +1093,11 @@ static bool rtlgen_supports_2_5gbps(stru
|
||||||
{
|
{
|
||||||
int val;
|
int val;
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
#define RTL8366RB_POWER_SAVE 0x15
|
#define RTL8366RB_POWER_SAVE 0x15
|
||||||
#define RTL8366RB_POWER_SAVE_ON BIT(12)
|
#define RTL8366RB_POWER_SAVE_ON BIT(12)
|
||||||
|
|
||||||
@@ -1152,6 +1156,25 @@ static int rtl8251b_c45_match_phy_device
|
@@ -1189,6 +1193,25 @@ static int rtl8251b_c45_match_phy_device
|
||||||
return rtlgen_is_c45_match(phydev, RTL_8251B, true);
|
return rtlgen_is_c45_match(phydev, RTL_8251B, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -50,7 +50,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
static int rtlgen_resume(struct phy_device *phydev)
|
static int rtlgen_resume(struct phy_device *phydev)
|
||||||
{
|
{
|
||||||
int ret = genphy_resume(phydev);
|
int ret = genphy_resume(phydev);
|
||||||
@@ -1427,6 +1450,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1460,6 +1483,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
PHY_ID_MATCH_EXACT(0x001cc838),
|
PHY_ID_MATCH_EXACT(0x001cc838),
|
||||||
.name = "RTL8226-CG 2.5Gbps PHY",
|
.name = "RTL8226-CG 2.5Gbps PHY",
|
||||||
@ -58,7 +58,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
@@ -1438,6 +1462,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1471,6 +1495,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
PHY_ID_MATCH_EXACT(0x001cc848),
|
PHY_ID_MATCH_EXACT(0x001cc848),
|
||||||
.name = "RTL8226B-CG_RTL8221B-CG 2.5Gbps PHY",
|
.name = "RTL8226B-CG_RTL8221B-CG 2.5Gbps PHY",
|
||||||
@ -66,7 +66,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
@@ -1451,6 +1476,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1484,6 +1509,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
||||||
@ -74,7 +74,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
@@ -1464,6 +1490,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1497,6 +1523,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
||||||
@ -82,7 +82,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
.get_rate_matching = rtl822xb_get_rate_matching,
|
.get_rate_matching = rtl822xb_get_rate_matching,
|
||||||
@@ -1475,6 +1502,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1508,6 +1535,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
||||||
@ -90,7 +90,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
.config_aneg = rtl822x_config_aneg,
|
.config_aneg = rtl822x_config_aneg,
|
||||||
@@ -1488,6 +1516,7 @@ static struct phy_driver realtek_drvs[]
|
@@ -1521,6 +1549,7 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: Daniel Golle <daniel@makrotopia.org>
|
|||||||
Signed-off-by: Mieczyslaw Nalewaj <namiltd@yahoo.com>
|
Signed-off-by: Mieczyslaw Nalewaj <namiltd@yahoo.com>
|
||||||
--- a/drivers/net/phy/realtek.c
|
--- a/drivers/net/phy/realtek.c
|
||||||
+++ b/drivers/net/phy/realtek.c
|
+++ b/drivers/net/phy/realtek.c
|
||||||
@@ -1120,10 +1120,32 @@ static int rtl8226_match_phy_device(stru
|
@@ -1139,10 +1139,32 @@ static int rtl8226_match_phy_device(stru
|
||||||
static int rtlgen_is_c45_match(struct phy_device *phydev, unsigned int id,
|
static int rtlgen_is_c45_match(struct phy_device *phydev, unsigned int id,
|
||||||
bool is_c45)
|
bool is_c45)
|
||||||
{
|
{
|
||||||
@ -49,4 +49,4 @@ Signed-off-by: Mieczyslaw Nalewaj <namiltd@yahoo.com>
|
|||||||
+ }
|
+ }
|
||||||
}
|
}
|
||||||
|
|
||||||
static int rtl8221b_vb_cg_c22_match_phy_device(struct phy_device *phydev)
|
static int rtl8221b_match_phy_device(struct phy_device *phydev)
|
||||||
|
@ -12,7 +12,7 @@ Signed-off-by: Jianhui Zhao <zhaojh329@gmail.com>
|
|||||||
|
|
||||||
--- a/drivers/net/phy/realtek.c
|
--- a/drivers/net/phy/realtek.c
|
||||||
+++ b/drivers/net/phy/realtek.c
|
+++ b/drivers/net/phy/realtek.c
|
||||||
@@ -1332,6 +1332,51 @@ static irqreturn_t rtl9000a_handle_inter
|
@@ -1369,6 +1369,51 @@ static irqreturn_t rtl9000a_handle_inter
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,7 +64,7 @@ Signed-off-by: Jianhui Zhao <zhaojh329@gmail.com>
|
|||||||
static struct phy_driver realtek_drvs[] = {
|
static struct phy_driver realtek_drvs[] = {
|
||||||
{
|
{
|
||||||
PHY_ID_MATCH_EXACT(0x00008201),
|
PHY_ID_MATCH_EXACT(0x00008201),
|
||||||
@@ -1498,6 +1543,8 @@ static struct phy_driver realtek_drvs[]
|
@@ -1531,6 +1576,8 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C22)",
|
||||||
@ -73,7 +73,7 @@ Signed-off-by: Jianhui Zhao <zhaojh329@gmail.com>
|
|||||||
.probe = rtl822x_probe,
|
.probe = rtl822x_probe,
|
||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
@@ -1512,6 +1559,8 @@ static struct phy_driver realtek_drvs[]
|
@@ -1545,6 +1592,8 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vb_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VB-CG 2.5Gbps PHY (C45)",
|
||||||
@ -82,7 +82,7 @@ Signed-off-by: Jianhui Zhao <zhaojh329@gmail.com>
|
|||||||
.probe = rtl822x_probe,
|
.probe = rtl822x_probe,
|
||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.config_init = rtl822xb_config_init,
|
.config_init = rtl822xb_config_init,
|
||||||
@@ -1524,6 +1573,8 @@ static struct phy_driver realtek_drvs[]
|
@@ -1557,6 +1606,8 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c22_match_phy_device,
|
||||||
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
.name = "RTL8221B-VM-CG 2.5Gbps PHY (C22)",
|
||||||
@ -91,7 +91,7 @@ Signed-off-by: Jianhui Zhao <zhaojh329@gmail.com>
|
|||||||
.probe = rtl822x_probe,
|
.probe = rtl822x_probe,
|
||||||
.soft_reset = genphy_soft_reset,
|
.soft_reset = genphy_soft_reset,
|
||||||
.get_features = rtl822x_get_features,
|
.get_features = rtl822x_get_features,
|
||||||
@@ -1538,6 +1589,8 @@ static struct phy_driver realtek_drvs[]
|
@@ -1571,6 +1622,8 @@ static struct phy_driver realtek_drvs[]
|
||||||
}, {
|
}, {
|
||||||
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
.match_phy_device = rtl8221b_vn_cg_c45_match_phy_device,
|
||||||
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
.name = "RTL8221B-VN-CG 2.5Gbps PHY (C45)",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user