mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-12 16:03:13 +00:00
96 lines
4.1 KiB
Diff
96 lines
4.1 KiB
Diff
|
From ee0e0ddb910e7e989b65a19d72b6435baa641fc7 Mon Sep 17 00:00:00 2001
|
||
|
From: "Russell King (Oracle)" <rmk+kernel@armlinux.org.uk>
|
||
|
Date: Fri, 24 Nov 2023 12:28:34 +0000
|
||
|
Subject: [PATCH 6/7] net: phylink: split out PHY validation from
|
||
|
phylink_bringup_phy()
|
||
|
|
||
|
When bringing up a PHY, we need to work out which ethtool link modes it
|
||
|
should support and advertise. Clause 22 PHYs operate in a single
|
||
|
interface mode, which can be easily dealt with. However, clause 45 PHYs
|
||
|
tend to switch interface mode depending on the media. We need more
|
||
|
flexible validation at this point, so this patch splits out that code
|
||
|
in preparation to changing it.
|
||
|
|
||
|
Tested-by: Luo Jie <quic_luoj@quicinc.com>
|
||
|
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
|
||
|
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
|
||
|
Link: https://lore.kernel.org/r/E1r6VIQ-00DDM9-LK@rmk-PC.armlinux.org.uk
|
||
|
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
|
||
|
---
|
||
|
drivers/net/phy/phylink.c | 56 ++++++++++++++++++++++-----------------
|
||
|
1 file changed, 31 insertions(+), 25 deletions(-)
|
||
|
|
||
|
--- a/drivers/net/phy/phylink.c
|
||
|
+++ b/drivers/net/phy/phylink.c
|
||
|
@@ -1775,6 +1775,35 @@ static void phylink_phy_change(struct ph
|
||
|
phylink_pause_to_str(pl->phy_state.pause));
|
||
|
}
|
||
|
|
||
|
+static int phylink_validate_phy(struct phylink *pl, struct phy_device *phy,
|
||
|
+ unsigned long *supported,
|
||
|
+ struct phylink_link_state *state)
|
||
|
+{
|
||
|
+ /* Check whether we would use rate matching for the proposed interface
|
||
|
+ * mode.
|
||
|
+ */
|
||
|
+ state->rate_matching = phy_get_rate_matching(phy, state->interface);
|
||
|
+
|
||
|
+ /* Clause 45 PHYs may switch their Serdes lane between, e.g. 10GBASE-R,
|
||
|
+ * 5GBASE-R, 2500BASE-X and SGMII if they are not using rate matching.
|
||
|
+ * For some interface modes (e.g. RXAUI, XAUI and USXGMII) switching
|
||
|
+ * their Serdes is either unnecessary or not reasonable.
|
||
|
+ *
|
||
|
+ * For these which switch interface modes, we really need to know which
|
||
|
+ * interface modes the PHY supports to properly work out which ethtool
|
||
|
+ * linkmodes can be supported. For now, as a work-around, we validate
|
||
|
+ * against all interface modes, which may lead to more ethtool link
|
||
|
+ * modes being advertised than are actually supported.
|
||
|
+ */
|
||
|
+ if (phy->is_c45 && state->rate_matching == RATE_MATCH_NONE &&
|
||
|
+ state->interface != PHY_INTERFACE_MODE_RXAUI &&
|
||
|
+ state->interface != PHY_INTERFACE_MODE_XAUI &&
|
||
|
+ state->interface != PHY_INTERFACE_MODE_USXGMII)
|
||
|
+ state->interface = PHY_INTERFACE_MODE_NA;
|
||
|
+
|
||
|
+ return phylink_validate(pl, supported, state);
|
||
|
+}
|
||
|
+
|
||
|
static int phylink_bringup_phy(struct phylink *pl, struct phy_device *phy,
|
||
|
phy_interface_t interface)
|
||
|
{
|
||
|
@@ -1795,32 +1824,9 @@ static int phylink_bringup_phy(struct ph
|
||
|
memset(&config, 0, sizeof(config));
|
||
|
linkmode_copy(supported, phy->supported);
|
||
|
linkmode_copy(config.advertising, phy->advertising);
|
||
|
+ config.interface = interface;
|
||
|
|
||
|
- /* Check whether we would use rate matching for the proposed interface
|
||
|
- * mode.
|
||
|
- */
|
||
|
- config.rate_matching = phy_get_rate_matching(phy, interface);
|
||
|
-
|
||
|
- /* Clause 45 PHYs may switch their Serdes lane between, e.g. 10GBASE-R,
|
||
|
- * 5GBASE-R, 2500BASE-X and SGMII if they are not using rate matching.
|
||
|
- * For some interface modes (e.g. RXAUI, XAUI and USXGMII) switching
|
||
|
- * their Serdes is either unnecessary or not reasonable.
|
||
|
- *
|
||
|
- * For these which switch interface modes, we really need to know which
|
||
|
- * interface modes the PHY supports to properly work out which ethtool
|
||
|
- * linkmodes can be supported. For now, as a work-around, we validate
|
||
|
- * against all interface modes, which may lead to more ethtool link
|
||
|
- * modes being advertised than are actually supported.
|
||
|
- */
|
||
|
- if (phy->is_c45 && config.rate_matching == RATE_MATCH_NONE &&
|
||
|
- interface != PHY_INTERFACE_MODE_RXAUI &&
|
||
|
- interface != PHY_INTERFACE_MODE_XAUI &&
|
||
|
- interface != PHY_INTERFACE_MODE_USXGMII)
|
||
|
- config.interface = PHY_INTERFACE_MODE_NA;
|
||
|
- else
|
||
|
- config.interface = interface;
|
||
|
-
|
||
|
- ret = phylink_validate(pl, supported, &config);
|
||
|
+ ret = phylink_validate_phy(pl, phy, supported, &config);
|
||
|
if (ret) {
|
||
|
phylink_warn(pl, "validation of %s with support %*pb and advertisement %*pb failed: %pe\n",
|
||
|
phy_modes(config.interface),
|