From: Maxime Chevallier <maxime.chevallier@bootlin.com>
To: "Björn Töpel" <bjorn@kernel.org>,
netdev@vger.kernel.org, "David S. Miller" <davem@davemloft.net>,
"Andrew Lunn" <andrew+netdev@lunn.ch>,
"Donald Hunter" <donald.hunter@gmail.com>,
"Eric Dumazet" <edumazet@google.com>,
"Jakub Kicinski" <kuba@kernel.org>,
"Naveen Mamindlapalli" <naveenm@marvell.com>,
"Paolo Abeni" <pabeni@redhat.com>,
"Simon Horman" <horms@kernel.org>
Cc: Danielle Ratson <danieller@nvidia.com>,
Hariprasad Kelam <hkelam@marvell.com>,
Ido Schimmel <idosch@nvidia.com>,
Kory Maincent <kory.maincent@bootlin.com>,
Leon Romanovsky <leon@kernel.org>,
Michael Chan <michael.chan@broadcom.com>,
Oleksij Rempel <o.rempel@pengutronix.de>,
Pavan Chebbi <pavan.chebbi@broadcom.com>,
Piergiorgio Beruto <piergiorgio.beruto@gmail.com>,
Russell King <linux@armlinux.org.uk>,
Saeed Mahameed <saeedm@nvidia.com>, Shuah Khan <shuah@kernel.org>,
Tariq Toukan <tariqt@nvidia.com>,
Willem de Bruijn <willemb@google.com>,
linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org,
linux-rdma@vger.kernel.org
Subject: Re: [PATCH net-next 02/11] ethtool: Add loopback netlink UAPI definitions
Date: Wed, 11 Mar 2026 08:33:26 +0100 [thread overview]
Message-ID: <580debbb-8f6c-4b60-95ef-22c68480ded1@bootlin.com> (raw)
In-Reply-To: <20260310104743.907818-3-bjorn@kernel.org>
Hi again Björn,
First, thanks for iterating so quick !
On 10/03/2026 11:47, Björn Töpel wrote:
> Add the netlink YAML spec and auto-generated UAPI header for a unified
> loopback interface covering MAC, PCS, PHY, and pluggable module
> components.
>
> Each loopback point is described by a nested entry attribute
> containing:
>
> - component where in the path (MAC, PCS, PHY, MODULE)
> - name subsystem label, e.g. "cmis-host" or "cmis-media"
> - id optional instance selector (e.g. PHY id, port id)
> - supported bitmask of supported directions
> - direction NEAR_END, FAR_END, or 0 (disabled)
>
> Signed-off-by: Björn Töpel <bjorn@kernel.org>
> ---
> Documentation/netlink/specs/ethtool.yaml | 123 ++++++++++++++++++
> .../uapi/linux/ethtool_netlink_generated.h | 59 +++++++++
> 2 files changed, 182 insertions(+)
>
> diff --git a/Documentation/netlink/specs/ethtool.yaml b/Documentation/netlink/specs/ethtool.yaml
> index 4707063af3b4..8bd14a3c946a 100644
> --- a/Documentation/netlink/specs/ethtool.yaml
> +++ b/Documentation/netlink/specs/ethtool.yaml
> @@ -211,6 +211,49 @@ definitions:
> name: discard
> value: 31
>
> + -
> + name: loopback-component
> + type: enum
> + doc: |
> + Loopback component. Identifies where in the network path the
> + loopback is applied.
> + entries:
> + -
> + name: mac
> + doc: MAC loopback. Loops traffic at the MAC block.
> + -
> + name: pcs
> + doc: |
> + PCS loopback. Loops traffic at the PCS sublayer between the
> + MAC and the PHY.
> + -
> + name: phy
> + doc: |
> + Ethernet PHY loopback. This refers to the Ethernet PHY managed
> + by phylib, not generic PHY drivers. A Base-T SFP module
> + containing an Ethernet PHY driven by Linux should report
> + loopback under this component, not module.
> + -
> + name: module
> + doc: |
> + Pluggable module (e.g. CMIS (Q)SFP) loopback. Covers loopback
> + modes controlled via module firmware or EEPROM registers. When
> + Linux drives an Ethernet PHY inside the module via phylib, use
> + the phy component instead.
So to get back on Andrew's remarks, let's see if we can get something
closer to 802.3.
Here, we have loopback at various locations, which all depends on the
Ethernet standard you use.
It's usually in the PCS, PMA or PMD components. Thing is, we may have
these in multiple places in our link.
If we take an example with a 10G PHY, we may have :
+----SoC-----+
| |
| MAC |- drivers/net/ethernet
| | |
| Base-R PCS |- could be in drivers/net/pcs, or directly
| | | in the MAC driver
| | |
| SerDes |- May be in drivers/phy, maybe handled by firmware,
| | | maybe by the MAC driver, maybe by the PCS driver ?
+---|--------+
|
| 10GBase-R
|
+---|-PHY+
| | |
| SerDes | \
| | | |
| PCS | |
| | | > All of that handled by the drivers/net/phy PHY driver
| PMA | |
| | | |
| PMD | /
+---|----+
|
v 10GBaseT
So even the "PCS" loopback component is a bit ambiguous, are we talking
about the PHY PCS or the MAC PCS ?
Another thing to consider is that there may be multiple PCSs in the SoC
(e.g. a BaseX and a BaseR PCS like we have in mvpp2), the one in use
depends on the current interface between the MAC and the PHY.
Another open question is, do we deal with loopbacks that may affect
multi-netdev links ? Like the multi-lane modes we discussed with fbnic,
or even for embedded, interfaces such as QSGMII ?
As for the SerDes on the MAC side (say, the comphy on Marvell devices),
can we say it's a PMA for 10GBase-KR ? Or is it something that's simply
out of spec ?
So I'd say, maybe we should not have a PCS loopback component at all,
but instead loopback at the well-defined components on our link, that is:
- MAC => MAC loopack, PCS on the MAC side, SerDes on the SoC, etc.
- PHY => Loopbacks on the PCS/PHY/PMA withing the PHY device
- Module => For non-PHY (Q)SFPs
The important part would therefore to get the "name" part right, making
sure we don't fall into driver specific names.
We can name that 'pcs', 'pma', 'pmd', or maybe even 'mii' ? Let's see :
+----SoC-----+
| |
| MAC |- component = MAC, name = 'mac'
| | |
| Base-R PCS |- component = MAC, name = 'pcs'
| | |
| | |
| SerDes |- component = MAC, name = 'mii' ?
| | |
+---|--------+
|
| 10GBase-R
|
+---|-PHY+
| | |
| SerDes | - component = PHY, name = 'mii' ?
| | |
| PCS | - component = PHY, name = 'pcs'
| | |
| PMA | - component = PHY, name = 'pma'
| | |
| PMD |- component = PHY, name = 'pmd' or 'mdi' ?
+---|----+
|
v 10GBaseT
Sorry that's a lot of questions and I don't expect you to have the
answer, but as what you've come-up with is taking a good shape, it's
important to decide on the overall design and draw some lines about
what do we support, and how :(
> + -
> + name: loopback-direction
> + type: flags
> + doc: |
> + Loopback direction flags. Used as a bitmask in supported, and as
> + a single value in direction.
> + entries:
> + -
> + name: near-end
> + doc: Near-end loopback; host-loop-host
> + -
> + name: far-end
> + doc: Far-end loopback; line-loop-line
I was browsing 802.3, it uses the terminlogy of "local loopback" vs
"remote loopback", I suggest we use those.
Maxime
next prev parent reply other threads:[~2026-03-11 7:33 UTC|newest]
Thread overview: 44+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-03-10 10:47 [PATCH net-next 00/11] ethtool: Generic loopback support Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 01/11] ethtool: Add dump_one_dev callback for per-device sub-iteration Björn Töpel
2026-03-12 2:32 ` Jakub Kicinski
2026-03-13 16:36 ` Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 02/11] ethtool: Add loopback netlink UAPI definitions Björn Töpel
2026-03-11 7:33 ` Maxime Chevallier [this message]
2026-03-11 10:39 ` Björn Töpel
2026-03-11 15:30 ` Andrew Lunn
2026-03-11 15:42 ` Maxime Chevallier
2026-03-11 19:37 ` Andrew Lunn
2026-03-12 2:47 ` Jakub Kicinski
2026-03-12 13:46 ` Andrew Lunn
2026-03-13 0:21 ` Jakub Kicinski
2026-03-11 10:50 ` Oleksij Rempel
2026-03-12 2:49 ` Jakub Kicinski
2026-03-11 15:22 ` Andrew Lunn
2026-03-11 15:35 ` Maxime Chevallier
2026-03-11 19:26 ` Andrew Lunn
2026-03-12 2:50 ` Jakub Kicinski
2026-03-12 5:04 ` Oleksij Rempel
2026-03-12 7:49 ` Maxime Chevallier
2026-03-12 8:46 ` Oleksij Rempel
2026-03-12 13:34 ` Andrew Lunn
2026-03-12 13:51 ` Oleksij Rempel
2026-03-12 16:39 ` Maxime Chevallier
2026-03-13 19:11 ` Björn Töpel
2026-03-15 15:09 ` Oleksij Rempel
2026-03-15 16:20 ` Björn Töpel
2026-03-18 15:59 ` Andrew Lunn
2026-03-10 10:47 ` [PATCH net-next 03/11] ethtool: Add loopback GET/SET netlink implementation Björn Töpel
2026-03-12 2:51 ` [net-next,03/11] " Jakub Kicinski
2026-03-10 10:47 ` [PATCH net-next 04/11] ethtool: Add CMIS loopback helpers for module loopback control Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 05/11] selftests: drv-net: Add loopback driver test Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 06/11] ethtool: Add MAC loopback support via ethtool_ops Björn Töpel
2026-03-11 6:04 ` [PATCH 6/11] " Naveen Mamindlapalli
2026-03-10 10:47 ` [PATCH net-next 07/11] netdevsim: Add MAC loopback simulation Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 08/11] selftests: drv-net: Add MAC loopback netdevsim test Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 09/11] MAINTAINERS: Add entry for ethtool loopback Björn Töpel
2026-03-10 10:47 ` [PATCH net-next 10/11] netdevsim: Add module EEPROM simulation via debugfs Björn Töpel
2026-03-12 2:52 ` [net-next,10/11] " Jakub Kicinski
2026-03-10 10:47 ` [PATCH net-next 11/11] selftests: drv-net: Add CMIS loopback netdevsim test Björn Töpel
2026-03-11 6:18 ` [PATCH net-next 00/11] ethtool: Generic loopback support Naveen Mamindlapalli
2026-03-11 10:24 ` Björn Töpel
2026-03-12 2:53 ` Jakub Kicinski
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=580debbb-8f6c-4b60-95ef-22c68480ded1@bootlin.com \
--to=maxime.chevallier@bootlin.com \
--cc=andrew+netdev@lunn.ch \
--cc=bjorn@kernel.org \
--cc=danieller@nvidia.com \
--cc=davem@davemloft.net \
--cc=donald.hunter@gmail.com \
--cc=edumazet@google.com \
--cc=hkelam@marvell.com \
--cc=horms@kernel.org \
--cc=idosch@nvidia.com \
--cc=kory.maincent@bootlin.com \
--cc=kuba@kernel.org \
--cc=leon@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-rdma@vger.kernel.org \
--cc=linux@armlinux.org.uk \
--cc=michael.chan@broadcom.com \
--cc=naveenm@marvell.com \
--cc=netdev@vger.kernel.org \
--cc=o.rempel@pengutronix.de \
--cc=pabeni@redhat.com \
--cc=pavan.chebbi@broadcom.com \
--cc=piergiorgio.beruto@gmail.com \
--cc=saeedm@nvidia.com \
--cc=shuah@kernel.org \
--cc=tariqt@nvidia.com \
--cc=willemb@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox