summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>2024-11-23 17:30:30 +0000
committerRussell King (Oracle) <rmk+kernel@armlinux.org.uk>2025-09-29 10:14:55 +0100
commit72ebc9abe4552d0816ab5a738f5f06bcd9598039 (patch)
tree3211967860568ea81118c7f11e52e6a7fd671edb
parentd44b5b0eefe7f6cbd2301c69eaedf2a49c4e64a9 (diff)
net: phylink: handle mac_enable_tx_lpi() returning -EOPNOTSUPP
Handle -EOPNOTSUPP from mac_enable_tx_lpi() to print a sensible error. Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
-rw-r--r--drivers/net/phy/phylink.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/drivers/net/phy/phylink.c b/drivers/net/phy/phylink.c
index afa491f72291..575c5555d6ba 100644
--- a/drivers/net/phy/phylink.c
+++ b/drivers/net/phy/phylink.c
@@ -1509,14 +1509,18 @@ static void phylink_activate_lpi(struct phylink *pl)
err = pl->mac_ops->mac_enable_tx_lpi(pl->config, pl->mac_tx_lpi_timer,
pl->mac_tx_clk_stop);
- if (err) {
+ if (!err) {
+ pl->mac_enable_tx_lpi = true;
+ } else {
phylink_pcs_disable_eee(pl->pcs);
- phylink_err(pl, "%ps() failed: %pe\n",
- pl->mac_ops->mac_enable_tx_lpi, ERR_PTR(err));
- return;
+ if (err == -EOPNOTSUPP)
+ phylink_dbg(pl, "%ps doesn't support LPI",
+ pl->mac_ops->mac_enable_tx_lpi);
+ else
+ phylink_err(pl, "%ps() failed: %pe\n",
+ pl->mac_ops->mac_enable_tx_lpi,
+ ERR_PTR(err));
}
-
- pl->mac_enable_tx_lpi = true;
}
static void phylink_link_up(struct phylink *pl,