Re: [PATCH net-next v2 7/9] net: phy: introduce ethtool_phy_ops to get and set phy configuration
From: Andrew Lunn
Date: Mon Oct 07 2024 - 12:39:24 EST
> That's a legit point. I mentioned in the cover for V1 that this in
> itself doesn't really bring anything useful. The only point being that
> it makes it easy to test if a PHY has a working isolation mode, but
> given that we'll assume that it doesn't by default, that whole point
> is moot.
>
> I would therefore understand if you consider that having a kAPI for
> that isn't very interesting and that I shall include this work as part
> of the multi-PHY support.
kAPI add a lot of Maintenance burden. So we should not add them unless
they are justified. to me, there is not a good justification for this.
> Sure thing. There are multiple devices out-there that may have multiple
> PHYs accessible from the MAC, through muxers (I'm trying to be generic
> enough to address all cases, gpio muxers, mmio-controlled muxers, etc.),
> but let me describe the HW I'm working on that's a bit more problematic.
>
> The first such platform I have has an fs_enet MAC, a pair of LXT973
> PHYs for which the isolate mode doesn't work, and no on-board circuitry to
> perform the isolation. Here, we have to power one PHY down when unused :
>
> /--- LXT973
> fs_enet -- MII--|
> \--- LXT973
So you have at least regulators under Linux control? Is that what you
mean by power down? Pulling the plug and putting it back again is
somewhat different to isolation. All its state is going to be lost,
meaning phylib needs to completely initialise it again. Or can you
hide this using PM? Just suspend/resume it?
> The second board has a fs_enet MAC and a pair of KSZ8041 PHYs connected
> in MII.
>
> The third one has a pair of KSZ8041 PHYs connected to a
> ucc_geth MAC in RMII.
>
> On both these boards, we isolate the PHYs when unused, and we also
> drive a GPIO to toggle some on-board circuitry to disconnect the MII
> lines as well for the unused PHY. I'd have to run some tests to see if
> this circuitry could be enough, without relying at all on PHY
> isolation :
>
> /--- KSZ8041
> |
> MAC ------ MUX
> | |
> to SoC <-gpio--/ \--- KSZ8041
>
>
> One point is, if you look at the first case (no mux), we need to know
> if the PHYs are able to isolate or not in order to use the proper
> switching strategy (isolate or power-down).
That explains the hardware, but what are the use cases? How did the
hardware designer envision this hardware being used?
If you need to power the PHY off, you cannot have dynamic behaviour
where the first to have link wins. But if you can have the media side
functional, you can do some dynamic behaviours. Although, is it wise
for the link to come up, yet to be functionally dead because it has no
MAC connected?
There are some Marvell Switches which support both internal Copper
PHYs and a SERDES port. The hardware allows first to get link to have
a functional MAC. But in Linux we have not supported that, and we
leave the unused part down so it does not get link.
Maybe we actually want energy detect, not link, to decide which PHY
should get the MAC? But i have no real idea what you can do with
energy detect, and it would also mean building out the read_status()
call to report additional things, etc.
Andrew