[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <69711c9c-b85b-4cd4-a5fe-2719b8e30438@broadcom.com>
Date: Wed, 23 Jul 2025 11:13:28 -0700
From: Florian Fainelli <florian.fainelli@...adcom.com>
To: Andrew Lunn <andrew@...n.ch>,
"Russell King (Oracle)" <linux@...linux.org.uk>
Cc: Gatien CHEVALLIER <gatien.chevallier@...s.st.com>,
Krzysztof Kozlowski <krzk@...nel.org>, Andrew Lunn <andrew+netdev@...n.ch>,
"David S. Miller" <davem@...emloft.net>, Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>,
Rob Herring <robh@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>,
Conor Dooley <conor+dt@...nel.org>,
Maxime Coquelin <mcoquelin.stm32@...il.com>,
Alexandre Torgue <alexandre.torgue@...s.st.com>,
Christophe Roullier <christophe.roullier@...s.st.com>,
Heiner Kallweit <hkallweit1@...il.com>, Simon Horman <horms@...nel.org>,
Tristram Ha <Tristram.Ha@...rochip.com>, netdev@...r.kernel.org,
devicetree@...r.kernel.org, linux-stm32@...md-mailman.stormreply.com,
linux-arm-kernel@...ts.infradead.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH net-next 1/4] dt-bindings: net: document st,phy-wol
property
On 7/23/25 07:23, Andrew Lunn wrote:
>> We can't retrofit such detection into PHY drivers - if we do so, we'll
>> break WoL on lots of boards (we'd need to e.g. describe PMEB in DT for
>> RTL8211F PHYs. While we can add it, if a newer kernel that expects
>> PMEB to be described to allow WoL is run with an older DT, then that
>> will be a regression.) Thus, I don't see how we could retrofit PHY
>> WoL support detection to MAC drivers.
>
> WoL is a mess. I wounder on how many boards it actually works
> correctly? How often is it tested?
> > I actually think this is similar to pause and EEE. Those were also a
> mess, and mostly wrongly implemented. The solution to that was to take
> as much as possible out of the driver and put it into the core,
> phylink.
>
> We probably want a similar solution. The MAC driver indicates its WoL
> capabilities to phylink. The PHY driver indicates its capabilities to
> phylink. phylink implements all the business logic, and just tells the
> PHY what it should enable, and stay awake. phylink tells the MAC what
> is should enable, and that it should stay awake.
We would need both a phylib and a phylink set of helpers because not all
of the drivers need to be converted to phylink.
>
> Is this going to happen? Given Russell limited availability, i guess
> not. It needs somebody else to step up and take this on. Are we going
> to break working systems? Probably. But given how broken this is
> overall, how much should we actually care? We can just fix up systems
> as they are reported broken.
Please just refrain from making such statements, it really just does not
help, and if you have no direct hands on experience with Wake-on-LAN, it
becomes purely gratuitous. I agree that there is a lack of adequate
consistency and guidelines for developers to implement Wake-on-LAN
properly, but I don't agree with the message and the way it is
delivered. It's just completely antagonistic to people like me and my
colleagues who have spent a great deal of time implementing Wake-on-LAN
for actively used systems, and I am talking hundred of millions of STBs
deployed each of them doing hundreds of system suspend/resume involving
Wake-on-LAN per day.
>
> I also think WoL, pause and EEE is a space we should have more tests
> for. To fully test WoL and pause you need a link partner, but i
> suspect you can do some basic API tests without one. WoL you
> definitely need a link partner. So this makes testing a bit more
> difficult. But that should not stop the community from writing such
> tests and making them available for developers to use.
The tests are in premise very simple, but you need a link partner and
you need to be ideally on the same physical network and you need to have
a system that supports system wide wake-up, or if nothing else s2idle.
Then you need a secondary wake-up source like a RTC or GPIO in order to
ensure that there is an upper bound on when you timeout for not
receiving a proper wake-on-LAN trigger.
It's not clear to me what needs to be contributed to the community, but
essentially the pseudo code is something like:
- wait for DUT to boot
for each support Wake-on-LAN mode:
- configure wake-on-LAN on DUT
- snapshot /sys/*/wakeup_count for the MAC/PHY device
- enter standby with e.g.: rtcwake -s <TIMEOUT> -m mem
- send Wake-on-LAN trigger from external device
- ensure DUT woke-up before <TIMEOUT> and check that /sys/*wakeup_count
is +1 compared to the previous snapshot
--
Florian
Powered by blists - more mailing lists