net: add helpers for EEE configuration
authorRussell King <rmk+kernel@armlinux.org.uk>
Sat, 2 Mar 2024 19:53:00 +0000 (20:53 +0100)
committerJakub Kicinski <kuba@kernel.org>
Wed, 6 Mar 2024 03:21:17 +0000 (19:21 -0800)
Add helpers that phylib and phylink can use to manage EEE configuration
and determine whether the MAC should be permitted to use LPI based on
that configuration.

Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: Andrew Lunn <andrew@lunn.ch>
Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
Link: https://lore.kernel.org/r/20240302195306.3207716-2-o.rempel@pengutronix.de
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/net/eee.h [new file with mode: 0644]

diff --git a/include/net/eee.h b/include/net/eee.h
new file mode 100644 (file)
index 0000000..84837ab
--- /dev/null
@@ -0,0 +1,38 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+#ifndef _EEE_H
+#define _EEE_H
+
+#include <linux/types.h>
+
+struct eee_config {
+       u32 tx_lpi_timer;
+       bool tx_lpi_enabled;
+       bool eee_enabled;
+};
+
+static inline bool eeecfg_mac_can_tx_lpi(const struct eee_config *eeecfg)
+{
+       /* eee_enabled is the master on/off */
+       if (!eeecfg->eee_enabled || !eeecfg->tx_lpi_enabled)
+               return false;
+
+       return true;
+}
+
+static inline void eeecfg_to_eee(struct ethtool_keee *eee,
+                                const struct eee_config *eeecfg)
+{
+       eee->tx_lpi_timer = eeecfg->tx_lpi_timer;
+       eee->tx_lpi_enabled = eeecfg->tx_lpi_enabled;
+       eee->eee_enabled = eeecfg->eee_enabled;
+}
+
+static inline void eee_to_eeecfg(struct eee_config *eeecfg,
+                                const struct ethtool_keee *eee)
+{
+       eeecfg->tx_lpi_timer = eee->tx_lpi_timer;
+       eeecfg->tx_lpi_enabled = eee->tx_lpi_enabled;
+       eeecfg->eee_enabled = eee->eee_enabled;
+}
+
+#endif