[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <IA3PR11MB8986224FD5C2D9290D57E658E5EEA@IA3PR11MB8986.namprd11.prod.outlook.com>
Date: Thu, 9 Oct 2025 08:52:30 +0000
From: "Loktionov, Aleksandr" <aleksandr.loktionov@...el.com>
To: "Keller, Jacob E" <jacob.e.keller@...el.com>, "Brandeburg, Jesse"
<jbrandeburg@...udflare.com>, Jakub Kicinski <kuba@...nel.org>, "Hariprasad
Kelam" <hkelam@...vell.com>, Simon Horman <horms@...nel.org>, Marcin Szycik
<marcin.szycik@...ux.intel.com>, Rahul Rameshbabu <rrameshbabu@...dia.com>,
"netdev@...r.kernel.org" <netdev@...r.kernel.org>,
"intel-wired-lan@...ts.osuosl.org" <intel-wired-lan@...ts.osuosl.org>,
"linux-doc@...r.kernel.org" <linux-doc@...r.kernel.org>, "corbet@....net"
<corbet@....net>, "Keller, Jacob E" <jacob.e.keller@...el.com>
CC: Jesse Brandeburg <jesse.brandeburg@...el.com>
Subject: RE: [Intel-wired-lan] [PATCH v3 3/5] ice: add tracking of good
transmit timestamps
> -----Original Message-----
> From: Intel-wired-lan <intel-wired-lan-bounces@...osl.org> On Behalf
> Of Jacob Keller
> Sent: Friday, September 12, 2025 1:41 AM
> To: Brandeburg, Jesse <jbrandeburg@...udflare.com>; Jakub Kicinski
> <kuba@...nel.org>; Hariprasad Kelam <hkelam@...vell.com>; Simon Horman
> <horms@...nel.org>; Marcin Szycik <marcin.szycik@...ux.intel.com>;
> Rahul Rameshbabu <rrameshbabu@...dia.com>; netdev@...r.kernel.org;
> intel-wired-lan@...ts.osuosl.org; linux-doc@...r.kernel.org;
> corbet@....net; Keller, Jacob E <jacob.e.keller@...el.com>
> Cc: Jesse Brandeburg <jesse.brandeburg@...el.com>
> Subject: [Intel-wired-lan] [PATCH v3 3/5] ice: add tracking of good
> transmit timestamps
>
> From: Jesse Brandeburg <jesse.brandeburg@...el.com>
>
> As a pre-requisite to implementing timestamp statistics, start
> tracking successful PTP timestamps. There already existed a trace
> event, but add a counter as well so it can be displayed by the next
> patch.
>
> Good count is a u64 as it is much more likely to be incremented. The
> existing error stats are all u32 as before, and are less likely so
> will wrap less.
>
> Reviewed-by: Jacob Keller <jacob.e.keller@...el.com>
> Reviewed-by: Jakub Kicinski <kuba@...nel.org>
> Reviewed-by: Simon Horman <horms@...nel.org>
> Signed-off-by: Jesse Brandeburg <jesse.brandeburg@...el.com>
> Signed-off-by: Jacob Keller <jacob.e.keller@...el.com>
> ---
> drivers/net/ethernet/intel/ice/ice_ptp.h | 2 ++
> drivers/net/ethernet/intel/ice/ice_ptp.c | 9 +++++++++
> 2 files changed, 11 insertions(+)
>
> diff --git a/drivers/net/ethernet/intel/ice/ice_ptp.h
> b/drivers/net/ethernet/intel/ice/ice_ptp.h
> index 137f2070a2d9..27016aac4f1e 100644
> --- a/drivers/net/ethernet/intel/ice/ice_ptp.h
> +++ b/drivers/net/ethernet/intel/ice/ice_ptp.h
> @@ -237,6 +237,7 @@ struct ice_ptp_pin_desc {
> * @clock: pointer to registered PTP clock device
> * @tstamp_config: hardware timestamping configuration
> * @reset_time: kernel time after clock stop on reset
> + * @tx_hwtstamp_good: number of completed Tx timestamp requests
> * @tx_hwtstamp_skipped: number of Tx time stamp requests skipped
> * @tx_hwtstamp_timeouts: number of Tx skbs discarded with no time
> stamp
> * @tx_hwtstamp_flushed: number of Tx skbs flushed due to interface
> closed @@ -261,6 +262,7 @@ struct ice_ptp {
> struct ptp_clock *clock;
> struct kernel_hwtstamp_config tstamp_config;
> u64 reset_time;
> + u64 tx_hwtstamp_good;
> u32 tx_hwtstamp_skipped;
> u32 tx_hwtstamp_timeouts;
> u32 tx_hwtstamp_flushed;
> diff --git a/drivers/net/ethernet/intel/ice/ice_ptp.c
> b/drivers/net/ethernet/intel/ice/ice_ptp.c
> index 9b065709c899..d2ca9d7bcfc1 100644
> --- a/drivers/net/ethernet/intel/ice/ice_ptp.c
> +++ b/drivers/net/ethernet/intel/ice/ice_ptp.c
> @@ -500,6 +500,9 @@ void ice_ptp_complete_tx_single_tstamp(struct
> ice_ptp_tx *tx)
> if (tstamp) {
> shhwtstamps.hwtstamp = ns_to_ktime(tstamp);
> ice_trace(tx_tstamp_complete, skb, idx);
> +
> + /* Count the number of Tx timestamps that succeeded */
> + pf->ptp.tx_hwtstamp_good++;
> }
>
> skb_tstamp_tx(skb, &shhwtstamps);
> @@ -558,6 +561,7 @@ static void ice_ptp_process_tx_tstamp(struct
> ice_ptp_tx *tx) {
> struct ice_ptp_port *ptp_port;
> unsigned long flags;
> + u32 tstamp_good = 0;
> struct ice_pf *pf;
> struct ice_hw *hw;
> u64 tstamp_ready;
> @@ -658,11 +662,16 @@ static void ice_ptp_process_tx_tstamp(struct
> ice_ptp_tx *tx)
> if (tstamp) {
> shhwtstamps.hwtstamp = ns_to_ktime(tstamp);
> ice_trace(tx_tstamp_complete, skb, idx);
> +
> + /* Count the number of Tx timestamps that
> succeeded */
> + tstamp_good++;
> }
>
> skb_tstamp_tx(skb, &shhwtstamps);
> dev_kfree_skb_any(skb);
> }
> +
> + pf->ptp.tx_hwtstamp_good += tstamp_good;
> }
>
> /**
>
> --
> 2.51.0.rc1.197.g6d975e95c9d7
Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@...el.com>
Powered by blists - more mailing lists