On Fri, Dec 03, 2021 at 04:18:18PM +0000, Machnikowski, Maciej wrote:
-----Original Message----- From: Ido Schimmel idosch@idosch.org Sent: Friday, December 3, 2021 4:46 PM To: Machnikowski, Maciej maciej.machnikowski@intel.com Subject: Re: [PATCH v4 net-next 2/4] ethtool: Add ability to configure recovered clock for SyncE feature
On Thu, Dec 02, 2021 at 05:20:24PM +0000, Machnikowski, Maciej wrote:
-----Original Message----- From: Ido Schimmel idosch@idosch.org Sent: Thursday, December 2, 2021 5:36 PM To: Machnikowski, Maciej maciej.machnikowski@intel.com Subject: Re: [PATCH v4 net-next 2/4] ethtool: Add ability to configure recovered clock for SyncE feature
On Thu, Dec 02, 2021 at 03:17:06PM +0000, Machnikowski, Maciej wrote:
-----Original Message----- From: Ido Schimmel idosch@idosch.org Sent: Thursday, December 2, 2021 1:44 PM To: Machnikowski, Maciej maciej.machnikowski@intel.com Subject: Re: [PATCH v4 net-next 2/4] ethtool: Add ability to configure recovered clock for SyncE feature
On Wed, Dec 01, 2021 at 07:02:06PM +0100, Maciej Machnikowski
wrote:
Looking at the diagram from the previous submission [1]:
┌──────────┬──────────┐ │ RX │ TX │
1 │ ports │ ports │ 1 ───►├─────┐ │ ├─────► 2 │ │ │ │ 2 ───►├───┐ │ │ ├─────► 3 │ │ │ │ │ 3 ───►├─┐ │ │ │ ├─────► │ ▼ ▼ ▼ │ │ │ ────── │ │ │ ____/ │ │ └──┼──┼────┴──────────┘ 1│ 2│ ▲ RCLK out│ │ │ TX CLK in ▼ ▼ │ ┌─────────────┴───┐ │ │ │ SEC │ │ │ └─────────────────┘
Given a netdev (1, 2 or 3 in the diagram), the RCLK_SET message
allows
me to redirect the frequency recovered from this netdev to the EEC
via
either pin 1, pin 2 or both.
Given a netdev, the RCLK_GET message allows me to query the range
of
pins (RCLK out 1-2 in the diagram) through which the frequency can
be
fed into the EEC.
Questions:
- The query for all the above netdevs will return the same range of
pins. How does user space know that these are the same pins? That
is,
how does user space know that RCLK_SET message to redirect the
frequency
recovered from netdev 1 to pin 1 will be overridden by the same
message
but for netdev 2?
We don't have a way to do so right now. When we have EEC subsystem
in
place
the right thing to do will be to add EEC input index and EEC index as
additional
arguments
- How does user space know the mapping between a netdev and an
EEC?
That is, how does user space know that RCLK_SET message for netdev
1
will cause the Tx frequency of netdev 2 to change according to the frequency recovered from netdev 1?
Ditto - currently we don't have any entity to link the pins to ATM, but we can address that in userspace just like PTP pins are used now
- If user space sends two RCLK_SET messages to redirect the
frequency
recovered from netdev 1 to RCLK out 1 and from netdev 2 to RCLK out
2,
how does it know which recovered frequency is actually used an input
to
the EEC?
User space doesn't know this as well?
In current model it can come from the config file. Once we implement DPLL subsystem we can implement connection between pins and DPLLs if they
are
known.
To be clear, no SyncE patches should be accepted before we have a DPLL subsystem or however the subsystem that will model the EEC is going to be called.
You are asking us to buy into a new uAPI that can never be removed. We pointed out numerous problems with this uAPI and suggested a model that solves them. When asked why it can't work we are answered with vague arguments about this model being "hard".
My argument was never "it's hard" - the answer is we need both APIs.
We are discussing whether two APIs are actually necessary or whether EEC source configuration can be done via the EEC. The answer cannot be "the answer is we need both APIs".
In addition, without a representation of the EEC, these patches have no value for user space. They basically allow user space to redirect the recovered frequency from a netdev to an object that does not exist. User space doesn't know if the object is successfully tracking the frequency (the EEC state) and does not know which other components are utilizing this recovered frequency as input (e.g., other netdevs, PHC).
That's also not true - the proposed uAPI lets you enable recovered frequency output pins and redirect the right clock to them. In some implementations you may not have anything else.
What isn't true? That these patches have no value for user space? This is 100% true. You admitted that this is incomplete work. There is no reason to merge one API without the other. At the very least, we need to see an explanation of how the two APIs work together. This is missing from the patchset, which prompted these questions:
https://lore.kernel.org/netdev/Yai%2Fe5jz3NZAg0pm@shredder/
BTW, what is the use case for enabling two EEC inputs simultaneously? Some seamless failover?
Mainly - redundacy
- Why these pins are represented as attributes of a netdev and not
as
attributes of the EEC? That is, why are they represented as output
pins
of the PHY as opposed to input pins of the EEC?
They are 2 separate beings. Recovered clock outputs are controlled separately from EEC inputs.
Separate how? What does it mean that they are controlled separately? In which sense? That redirection of recovered frequency to pin is controlled via PHY registers whereas priority setting between EEC inputs is controlled via EEC registers? If so, this is an implementation detail of a specific design. It is not of any importance to user space.
They belong to different devices. EEC registers are physically in the DPLL hanging over I2C and recovered clocks are in the PHY/integrated PHY in the MAC. Depending on system architecture you may have control over one piece only
These are implementation details of a specific design and should not influence the design of the uAPI. The uAPI should be influenced by the logical task that it is trying to achieve.
There are 2 logical tasks:
- Enable clocks that are recovered from a specific netdev
I already replied about this here:
https://lore.kernel.org/netdev/Yao+nK40D0+u8UKL@shredder/
If the recovered clock outputs are only meaningful as EEC inputs, then there is no reason not to configure them through the EEC object. The fact that you think that the *internal* kernel plumbing (that can be improved over time) will be "hard" is not a reason to end up with a *user* API (that cannot be changed) where the *Ethernet* Equipment Clock is ignorant of its *Ethernet* ports.
With your proposal where the EEC is only aware of pins, how does user space answer the question of what is the source of the EEC? It needs to issue RCLK_GET dump? How does it even know that the source is a netdev and not an external one? And if the EEC object knows that the source is a netdev, how come it does not know which netdev?
- Control the EEC
They are both needed to get to the full solution, but are independent from each other. You can't put RCLK redirection to the EEC as it's one to many relation and you will need to call the netdev to enable it anyway.
So what if I need to call the netdev? The EEC cannot be so disjoint from the associated netdevs. After all, EEC stands for *Ethernet* Equipment Clock. In the common case, the EEC will transfer the frequency from one netdev to another. In the less common case, it will transfer the frequency from an external source to a netdev.
Also, when we tried to add EEC state to PTP subsystem the answer was that we can't mix subsystems.
SyncE doesn't belong in PTP because PTP can work without SyncE and SyncE can work without PTP. The fact that the primary use case for SyncE might be PTP doesn't mean that SyncE belongs in PTP subsystem.
The proposal to configure recovered clocks through EEC would mix netdev with EEC.
I don't believe that *Ethernet* Equipment Clock and *Ethernet* ports should be so disjoint so that the EEC doesn't know about:
a. The netdev from which it is recovering its frequency b. The netdevs that it is controlling
If the netdevs are smart enough to report the EEC input pins and EEC association to user space, then they are also smart enough to register themselves internally in the kernel with the EEC. They can all appear as virtual input/output pins of the EEC that can be enabled/disabled by user space. In addition, you can have physical (named) pins for external sources / outputs and another virtual output pin towards the PHC.
If we mix them it'll be hard to control everything especially that a single EEC can support multiple devices.
Hard how? Please provide concrete examples.
From the EEC perspective it's one to many relation - one EEC input pin will
serve
even 4,16,48 netdevs. I don't see easy way of starting from EEC input of EEC
device
and figuring out which netdevs are connected to it to talk to the right one. In current model it's as simple as:
- I received QL-PRC on netdev ens4f0
- I send back enable recovered clock on pin 0 of the ens4f0
- go to EEC that will be linked to it
- see the state of it - if its locked - report QL-EEC downsteam
How would you this control look in the EEC/DPLL implementation? Maybe I missed something.
Petr already replied.
See my response there.
What do you mean by "multiple devices"? A multi-port adapter with a single EEC or something else?
Multiple MACs that use a single EEC clock.
Also if we make those pins attributes of the EEC it'll become extremally
hard
to map them to netdevs and control them from the userspace app that
will
receive the ESMC message with a given QL level on netdev X.
Hard how? What is the problem with something like:
# eec set source 1 type netdev dev swp1
The EEC object should be registered by the same entity that registers the netdevs whose Tx frequency is controlled by the EEC, the MAC
driver.
But the EEC object may not be controlled by the MAC - in which case this model won't work.
Why wouldn't it work? Leave individual kernel modules alone and look at the kernel. It is registering all the necessary logical objects such netdevs, PHCs and EECs. There is no way user space knows better than the kernel how these objects fit together as the purpose of the kernel is to abstract the hardware to user space.
User space's request to use the Rx frequency recovered from netdev X as an input to EEC Y will be processed by the DPLL subsystem. In turn, this subsystem will invoke whichever kernel modules it needs to fulfill the request.
But how would that call go through the kernel? What would you like to give to the EEC object and how should it react. I'm fine with the changes, but I don't see the solution in that proposal and this model would mix independent subsystems. The netdev -> EEC should be a downstream relation, just like the PTP is now If a netdev wants to check what's the state of EEC driving it - it can do it, but I don't see a way for the EEC subsystem to directly configure something in Potentially couple different MAC chips without calling a kind of netdev API. And that's what those patches address.
- What is the problem with the following model?
The EEC is a separate object with following attributes:
- State: Invalid / Freerun / Locked / etc
- Sources: Netdev / external / etc
- Potentially more
Notifications are emitted to user space when the state of the EEC changes. Drivers will either poll the state from the device or get interrupts
The mapping from netdev to EEC is queried via ethtool
Yep - that will be part of the EEC (DPLL) subsystem
This model avoids all the problems I pointed out in the current proposal.
That's the go-to model, but first we need control over the source as well :)
The point that we are trying to make is that like the EEC state, the source is also an EEC attribute and not a netdev attribute.