[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20251119162636.1a518f2f@kmaincent-XPS-13-7390>
Date: Wed, 19 Nov 2025 16:26:36 +0100
From: Kory Maincent <kory.maincent@...tlin.com>
To: Vadim Fedorenko <vadim.fedorenko@...ux.dev>
Cc: Andrew Lunn <andrew+netdev@...n.ch>, Florian Fainelli
<florian.fainelli@...adcom.com>, Russell King <linux@...linux.org.uk>,
Heiner Kallweit <hkallweit1@...il.com>, "David S. Miller"
<davem@...emloft.net>, Eric Dumazet <edumazet@...gle.com>, Jakub Kicinski
<kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>, Andrei Botila
<andrei.botila@....nxp.com>, Richard Cochran <richardcochran@...il.com>,
Andrew Lunn <andrew@...n.ch>, Simon Horman <horms@...nel.org>, Vladimir
Oltean <vladimir.oltean@....com>, Jacob Keller <jacob.e.keller@...el.com>,
bcm-kernel-feedback-list@...adcom.com, netdev@...r.kernel.org
Subject: Re: [PATCH net-next v3 5/9] net: phy: micrel: add HW timestamp
configuration reporting
On Wed, 19 Nov 2025 15:10:27 +0000
Vadim Fedorenko <vadim.fedorenko@...ux.dev> wrote:
> On 19/11/2025 14:44, Kory Maincent wrote:
> > On Wed, 19 Nov 2025 12:47:21 +0000
> > Vadim Fedorenko <vadim.fedorenko@...ux.dev> wrote:
> >
> >> The driver stores HW timestamping configuration and can technically
> >> report it. Add callback to do it.
> >>
> >> Signed-off-by: Vadim Fedorenko <vadim.fedorenko@...ux.dev>
> >> ---
> >> drivers/net/phy/micrel.c | 27 +++++++++++++++++++++++++++
> >> 1 file changed, 27 insertions(+)
> >>
> >> diff --git a/drivers/net/phy/micrel.c b/drivers/net/phy/micrel.c
> >> index 05de68b9f719..b149d539aec3 100644
> >> --- a/drivers/net/phy/micrel.c
> >> +++ b/drivers/net/phy/micrel.c
> >> @@ -3147,6 +3147,18 @@ static void lan8814_flush_fifo(struct phy_device
> >> *phydev, bool egress) lanphy_read_page_reg(phydev, LAN8814_PAGE_PORT_REGS,
> >> PTP_TSU_INT_STS); }
> >>
> >> +static int lan8814_hwtstamp_get(struct mii_timestamper *mii_ts,
> >> + struct kernel_hwtstamp_config *config)
> >> +{
> >> + struct kszphy_ptp_priv *ptp_priv =
> >> + container_of(mii_ts, struct kszphy_ptp_priv,
> >> mii_ts); +
> >> + config->tx_type = ptp_priv->hwts_tx_type;
> >> + config->rx_filter = ptp_priv->rx_filter;
> >> +
> >> + return 0;
> >> +}
> >> +
> >> static int lan8814_hwtstamp_set(struct mii_timestamper *mii_ts,
> >> struct kernel_hwtstamp_config *config,
> >> struct netlink_ext_ack *extack)
> >> @@ -4390,6 +4402,7 @@ static void lan8814_ptp_init(struct phy_device
> >> *phydev) ptp_priv->mii_ts.rxtstamp = lan8814_rxtstamp;
> >> ptp_priv->mii_ts.txtstamp = lan8814_txtstamp;
> >> ptp_priv->mii_ts.hwtstamp_set = lan8814_hwtstamp_set;
> >> + ptp_priv->mii_ts.hwtstamp_get = lan8814_hwtstamp_get;
> >> ptp_priv->mii_ts.ts_info = lan8814_ts_info;
> >>
> >> phydev->mii_ts = &ptp_priv->mii_ts;
> >> @@ -5042,6 +5055,19 @@ static void lan8841_ptp_enable_processing(struct
> >> kszphy_ptp_priv *ptp_priv, #define LAN8841_PTP_TX_TIMESTAMP_EN
> >> 443 #define LAN8841_PTP_TX_MOD 445
> >>
> >> +static int lan8841_hwtstamp_get(struct mii_timestamper *mii_ts,
> >> + struct kernel_hwtstamp_config *config)
> >> +{
> >> + struct kszphy_ptp_priv *ptp_priv;
> >> +
> >> + ptp_priv = container_of(mii_ts, struct kszphy_ptp_priv, mii_ts);
> >> +
> >> + config->tx_type = ptp_priv->hwts_tx_type;
> >> + config->rx_filter = ptp_priv->rx_filter;
> >
> > Something related to this patch, it seems there is an issue in the set
> > callback:
> > https://elixir.bootlin.com/linux/v6.18-rc6/source/drivers/net/phy/micrel.c#L3056
> >
> > The priv->rx_filter and priv->hwts_tx_type are set before the switch
> > condition. The hwtstamp_get can then report something that is not supported.
> > Also HWTSTAMP_TX_ONESTEP_P2P is not managed by the driver but not returning
> > -ERANGE either so if we set this config the hwtstamp_get will report
> > something wrong as not supported.
> > I think you will need to add a new patch here to fix the hwtstamp_set ops.
>
> I agree, that there is a problem in the flow, but such change is out of
> scope of this patch set. I'm going to provide some logic improvements on
> per-driver basis as follow up work.
As you want but patch 5 and 6 won't be accepted without these change.
> > Maybe we should update net_hwtstamp_validate to check on the capabilities
> > reported by ts_info but that is a bigger change.
>
> In this case we have to introduce validation callback and implement it
> in drivers. Some drivers do downgrade filter values if provided value is
> not in the list of what was provided in ethtool::ts_info. And we have to
> keep this logic as otherwise it may be considered as API breakage.
Indeed so lets keep the current design.
--
Köry Maincent, Bootlin
Embedded Linux and kernel engineering
https://bootlin.com
Powered by blists - more mailing lists