drivers/net/ethernet/cadence/macb_main.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+)
From: Steve Wilkins <steve.wilkins@raymarine.com>
Add ethtool_ops for configuring Energy Efficient Ethernet in the PHY.
Signed-off-by: Steve Wilkins <steve.wilkins@raymarine.com>
Signed-off-by: Conor Dooley <conor.dooley@microchip.com>
---
Steve sent me this patch (modulo the eee -> keee change), but I know
nothing about the macb driver, so I asked Nicolas whether the patch
made sense. His response was:
> Interesting although I have the feeling that some support from our MAC
> is missing for pretending to support the feature.
> I'm not sure the phylink without the MAC support is valid.
>
> I think we need a real task to be spawn to support EEE / LPI on cadence
> driver (but I don't see it scheduled in a way or another 🙁 ).
Since he was not sure, next port of call is lkml.. Is this patch
sufficient in isolation, or are additional changes required to the driver
for it?
The other drivers that I looked at that use phylink_ethtool_set_eee()
vary between doing what's done here and just forwarding the call, but
others are more complex, so without an understanding of the subsystem
I cannot tell :)
Alternatively, Steve, shout if you can tell me why forwarding to the phy
is sufficient, and I'll update the commit message and send this as
non-RFC.
Thanks,
Conor.
CC: valentina.fernandezalanis@microchip.com
CC: Nicolas Ferre <nicolas.ferre@microchip.com>
CC: Claudiu Beznea <claudiu.beznea@tuxon.dev>
CC: "David S. Miller" <davem@davemloft.net>
CC: Eric Dumazet <edumazet@google.com>
CC: Jakub Kicinski <kuba@kernel.org>
CC: Paolo Abeni <pabeni@redhat.com>
CC: Russell King <linux@armlinux.org.uk>
CC: netdev@vger.kernel.org
CC: linux-kernel@vger.kernel.org
---
drivers/net/ethernet/cadence/macb_main.c | 18 ++++++++++++++++++
1 file changed, 18 insertions(+)
diff --git a/drivers/net/ethernet/cadence/macb_main.c b/drivers/net/ethernet/cadence/macb_main.c
index 95e8742dce1d..a2a222954ebf 100644
--- a/drivers/net/ethernet/cadence/macb_main.c
+++ b/drivers/net/ethernet/cadence/macb_main.c
@@ -3321,6 +3321,20 @@ static int macb_set_link_ksettings(struct net_device *netdev,
return phylink_ethtool_ksettings_set(bp->phylink, kset);
}
+static int macb_get_eee(struct net_device *netdev, struct ethtool_keee *edata)
+{
+ struct macb *bp = netdev_priv(netdev);
+
+ return phylink_ethtool_get_eee(bp->phylink, edata);
+}
+
+static int macb_set_eee(struct net_device *netdev, struct ethtool_keee *edata)
+{
+ struct macb *bp = netdev_priv(netdev);
+
+ return phylink_ethtool_set_eee(bp->phylink, edata);
+}
+
static void macb_get_ringparam(struct net_device *netdev,
struct ethtool_ringparam *ring,
struct kernel_ethtool_ringparam *kernel_ring,
@@ -3767,6 +3781,8 @@ static const struct ethtool_ops macb_ethtool_ops = {
.set_wol = macb_set_wol,
.get_link_ksettings = macb_get_link_ksettings,
.set_link_ksettings = macb_set_link_ksettings,
+ .get_eee = macb_get_eee,
+ .set_eee = macb_set_eee,
.get_ringparam = macb_get_ringparam,
.set_ringparam = macb_set_ringparam,
};
@@ -3783,6 +3799,8 @@ static const struct ethtool_ops gem_ethtool_ops = {
.get_sset_count = gem_get_sset_count,
.get_link_ksettings = macb_get_link_ksettings,
.set_link_ksettings = macb_set_link_ksettings,
+ .get_eee = macb_get_eee,
+ .set_eee = macb_set_eee,
.get_ringparam = macb_get_ringparam,
.set_ringparam = macb_set_ringparam,
.get_rxnfc = gem_get_rxnfc,
--
2.43.0
On Tue, Aug 27, 2024 at 12:29:23PM +0100, Conor Dooley wrote: > From: Steve Wilkins <steve.wilkins@raymarine.com> > > Add ethtool_ops for configuring Energy Efficient Ethernet in the PHY. > > Signed-off-by: Steve Wilkins <steve.wilkins@raymarine.com> > Signed-off-by: Conor Dooley <conor.dooley@microchip.com> > --- > Steve sent me this patch (modulo the eee -> keee change), but I know > nothing about the macb driver, so I asked Nicolas whether the patch > made sense. His response was: > > Interesting although I have the feeling that some support from our MAC > > is missing for pretending to support the feature. > > I'm not sure the phylink without the MAC support is valid. > > > > I think we need a real task to be spawn to support EEE / LPI on cadence > > driver (but I don't see it scheduled in a way or another 🙁 ). > > Since he was not sure, next port of call is lkml.. Is this patch > sufficient in isolation, or are additional changes required to the driver > for it? > > The other drivers that I looked at that use phylink_ethtool_set_eee() > vary between doing what's done here and just forwarding the call, but > others are more complex, so without an understanding of the subsystem > I cannot tell :) > > Alternatively, Steve, shout if you can tell me why forwarding to the phy > is sufficient, and I'll update the commit message and send this as > non-RFC. This is not sufficient. EEE is negotiated with the link peer, so phylib/phylink is involved so that negotiation is performed, and the results reported back to the MAC. The MAC then needs to act on the results of the negotiation. The MAC does most of the work. It keeps a timer of when it last sent a packet. If this time exceeds 'tx-timer', it signals to the PHY it can swap into low power mode, because there is nothing to send. When the next packet comes along, it needs to signal the PHY to transition back into full power mode, and it needs to wait a little for that to happen. You are missing the MAC parts. Andrew
© 2016 - 2025 Red Hat, Inc.