net: phy: Dealing with 88e1543 dual-port mode
Maxime Chevallier
maxime.chevallier at bootlin.com
Thu Nov 19 09:22:46 EST 2020
Hello everyone,
I'm reaching out to discuss an issue I'm currently having, while working
on a Marvell 88E1543 PHY.
This PHY is very similar to the 88E1545 we already support upstream, but
with an added "dual-port mode" feature that I'm currently using in a
project, and that might be interesting to have upstream.
As a quick remainder, the 88E154x family are 4-ports PHYs that support
Fiber (SFP) or RJ45 Copper interfaces on the media side, and QSGMII/SGMII
on the host side.
A datasheet for this PHY family can be found here [1] but unfortunately,
this public datasheet doesn't explain the mode I'm going to discuss...
The specificity of the 88E1543 is that is can be configured as a 2-port
PHY, each port having the ability to have both a Copper RJ45 interface and
a Fiber interface with automatic media detection, very much like the
88x3310 that we support, and that is used on the MacchiatoBin.
This auto-media detection is the specific mode i'm interested in.
The way this works is that the PHY is internally configured by chaining
2 internal PHYs back to back. One PHY deals with the Host interface and
is configured as an SGMII to QSGMII converter (the QSGMII is only used
from within the PHY), and the other PHY acts as the Media-side PHY,
configured in QSGMII to auto-media (RJ45 or Fiber (SFP)) :
+- 88e1543 -----------------------+
+-----+ | +--------+ +--------+ | /-- Copper (RJ45)
| |--SGMII----| Port 0 |--QSGMII--| Port 1 |----<
| | | +--------+ +--------+ | \--- Fiber
| MAC | | |
| | | +--------+ +--------+ | /-- Copper (RJ45)
| |--SGMII----| Port 2 |--QSGMII--| Port 3 |----<
+-----+ | +--------+ +--------+ | \-- Fiber
+---------------------------------+
I have two main concerns about how to deal with that (if we are interested
in having such a support upstream at all).
The first one, is how to represent that in the DT.
One approach could be to really represents what's going on, by representing
the 2 PHYs chained together. In this case, only the MAC-facing PHY
will report the link state, so we are basically representing the internal
wiring of the PHY, can we consider that as a description of the hardware ?
Besides that, I don't think that today, we are able to represent link
composed of multiple PHYs daisy-chained together, but this is something
that we might want to support one day, since it could benefit other types
of use-cases.
Another approach could be to pretend the 88E1543 is a 2-port SGMII to
Auto-media PHY. This is also a bit tricky, since we need a way to detect
that we want the whole 4-ports PHY to act as a 2-port PHY. (or 3-port, if
we only want to use one pair of ports in that mode, and the other ports
as SGMII - Copper or SGMII - Fiber PHYs).
The second concern I have is that all of this is made even harder by the
fact that this 88E1543 PHY seems indistinguishable from the 88E1545 by
reading the PHY ID, they both report 0x01410eaX :/ I guess we would also
need some DT indication that we are in fact dealing with a 88E1543.
So I'd like you opinions on how we might want to deal with such scenarios,
and if we do want to bother supporting that at all :(
Thanks in advance,
Maxime
[1] :
https://www.marvell.com/content/dam/marvell/en/public-collateral/transceivers/marvell-phys-transceivers-alaska-88e154x-datasheet.pdf
More information about the linux-arm-kernel
mailing list