mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-30 18:47:06 +00:00
70 lines
2.5 KiB
Diff
70 lines
2.5 KiB
Diff
|
From c278ec644377249aba5b1e1ca2b5705fd1c0132c Mon Sep 17 00:00:00 2001
|
||
|
From: Paweł Owoc <frut3k7@gmail.com>
|
||
|
Date: Mon, 1 Apr 2024 16:51:06 +0200
|
||
|
Subject: [PATCH net-next v2] net: phy: aquantia: add support for AQR114C PHY ID
|
||
|
|
||
|
Add support for AQR114C PHY ID. This PHY advertise 10G speed:
|
||
|
SPEED(0x04): 0x6031
|
||
|
capabilities: -400g +5g +2.5g -200g -25g -10g-xr -100g -40g -10g/1g -10
|
||
|
+100 +1000 -10-ts -2-tl +10g
|
||
|
EXTABLE(0x0B): 0x40fc
|
||
|
capabilities: -10g-cx4 -10g-lrm +10g-t +10g-kx4 +10g-kr +1000-t +1000-kx
|
||
|
+100-tx -10-t -p2mp -40g/100g -1000/100-t1 -25g -200g/400g
|
||
|
+2.5g/5g -1000-h
|
||
|
|
||
|
but supports only up to 5G speed (as with AQR111/111B0).
|
||
|
AQR111 init config is used to set max speed 5G.
|
||
|
|
||
|
Signed-off-by: Paweł Owoc <frut3k7@gmail.com>
|
||
|
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
|
||
|
Link: https://lore.kernel.org/r/20240401145114.1699451-1-frut3k7@gmail.com
|
||
|
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
|
||
|
---
|
||
|
drivers/net/phy/aquantia/aquantia_main.c | 21 +++++++++++++++++++++
|
||
|
1 file changed, 21 insertions(+)
|
||
|
|
||
|
--- a/drivers/net/phy/aquantia/aquantia_main.c
|
||
|
+++ b/drivers/net/phy/aquantia/aquantia_main.c
|
||
|
@@ -28,6 +28,7 @@
|
||
|
#define PHY_ID_AQR412 0x03a1b712
|
||
|
#define PHY_ID_AQR113 0x31c31c40
|
||
|
#define PHY_ID_AQR113C 0x31c31c12
|
||
|
+#define PHY_ID_AQR114C 0x31c31c22
|
||
|
#define PHY_ID_AQR813 0x31c31cb2
|
||
|
|
||
|
#define MDIO_PHYXS_VEND_IF_STATUS 0xe812
|
||
|
@@ -880,6 +881,25 @@ static struct phy_driver aqr_driver[] =
|
||
|
.link_change_notify = aqr107_link_change_notify,
|
||
|
},
|
||
|
{
|
||
|
+ PHY_ID_MATCH_MODEL(PHY_ID_AQR114C),
|
||
|
+ .name = "Aquantia AQR114C",
|
||
|
+ .probe = aqr107_probe,
|
||
|
+ .get_rate_matching = aqr107_get_rate_matching,
|
||
|
+ .config_init = aqr111_config_init,
|
||
|
+ .config_aneg = aqr_config_aneg,
|
||
|
+ .config_intr = aqr_config_intr,
|
||
|
+ .handle_interrupt = aqr_handle_interrupt,
|
||
|
+ .read_status = aqr107_read_status,
|
||
|
+ .get_tunable = aqr107_get_tunable,
|
||
|
+ .set_tunable = aqr107_set_tunable,
|
||
|
+ .suspend = aqr107_suspend,
|
||
|
+ .resume = aqr107_resume,
|
||
|
+ .get_sset_count = aqr107_get_sset_count,
|
||
|
+ .get_strings = aqr107_get_strings,
|
||
|
+ .get_stats = aqr107_get_stats,
|
||
|
+ .link_change_notify = aqr107_link_change_notify,
|
||
|
+},
|
||
|
+{
|
||
|
PHY_ID_MATCH_MODEL(PHY_ID_AQR813),
|
||
|
.name = "Aquantia AQR813",
|
||
|
.probe = aqr107_probe,
|
||
|
@@ -916,6 +936,7 @@ static struct mdio_device_id __maybe_unu
|
||
|
{ PHY_ID_MATCH_MODEL(PHY_ID_AQR412) },
|
||
|
{ PHY_ID_MATCH_MODEL(PHY_ID_AQR113) },
|
||
|
{ PHY_ID_MATCH_MODEL(PHY_ID_AQR113C) },
|
||
|
+ { PHY_ID_MATCH_MODEL(PHY_ID_AQR114C) },
|
||
|
{ PHY_ID_MATCH_MODEL(PHY_ID_AQR813) },
|
||
|
{ }
|
||
|
};
|