net/mlx5e: Introduce lost_cqe statistic counter for PTP Tx port timestamping CQ
authorRahul Rameshbabu <rrameshbabu@nvidia.com>
Wed, 3 Apr 2024 21:28:40 +0000 (14:28 -0700)
committerJakub Kicinski <kuba@kernel.org>
Sat, 6 Apr 2024 05:24:09 +0000 (22:24 -0700)
Track the number of times a CQE was expected to not be delivered on PTP Tx
port timestamping CQ. A CQE is expected to not be delivered if a certain
amount of time passes since the corresponding CQE containing the DMA
timestamp information has arrived. Increment the late_cqe counter when such
a CQE does manage to be delivered to the CQ.

Signed-off-by: Rahul Rameshbabu <rrameshbabu@nvidia.com>
Reviewed-by: Tariq Toukan <tariqt@nvidia.com>
Reviewed-by: Dragos Tatulea <dtatulea@nvidia.com>
Signed-off-by: Saeed Mahameed <saeedm@nvidia.com>
Link: https://lore.kernel.org/r/20240403212931.128541-3-rrameshbabu@nvidia.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Documentation/networking/device_drivers/ethernet/mellanox/mlx5/counters.rst
drivers/net/ethernet/mellanox/mlx5/core/en/ptp.c
drivers/net/ethernet/mellanox/mlx5/core/en_stats.c
drivers/net/ethernet/mellanox/mlx5/core/en_stats.h

index f69ee1ebee010a9437ace77f9b220849ad70cdab..5464cd9e2694a4498d42426e7af4a3ee525c2f21 100644 (file)
@@ -702,6 +702,12 @@ the software port.
        the device typically ensures not posting the CQE.
      - Error
 
+   * - `ptp_cq[i]_lost_cqe`
+     - Number of times a CQE is expected to not be delivered on the PTP
+       timestamping CQE by the device due to a time delta elapsing. If such a
+       CQE is somehow delivered, `ptp_cq[i]_late_cqe` is incremented.
+     - Error
+
 .. [#ring_global] The corresponding ring and global counters do not share the
                   same name (i.e. do not follow the common naming scheme).
 
index d0af7271da3416c910347accc202326a5a201fa4..afd654583b6b14588a5f95df2f91ec5e569e698e 100644 (file)
@@ -169,6 +169,7 @@ static void mlx5e_ptpsq_mark_ts_cqes_undelivered(struct mlx5e_ptpsq *ptpsq,
                WARN_ON_ONCE(!pos->inuse);
                pos->inuse = false;
                list_del(&pos->entry);
+               ptpsq->cq_stats->lost_cqe++;
        }
        spin_unlock_bh(&cqe_list->tracker_list_lock);
 }
index 4f372cb2fc9aad6eab5328c22a227f0cf5dd1fdb..3004778e253eb6fe0a9080682ae76f652693f037 100644 (file)
@@ -2178,6 +2178,7 @@ static const struct counter_desc ptp_cq_stats_desc[] = {
        { MLX5E_DECLARE_PTP_CQ_STAT(struct mlx5e_ptp_cq_stats, abort) },
        { MLX5E_DECLARE_PTP_CQ_STAT(struct mlx5e_ptp_cq_stats, abort_abs_diff_ns) },
        { MLX5E_DECLARE_PTP_CQ_STAT(struct mlx5e_ptp_cq_stats, late_cqe) },
+       { MLX5E_DECLARE_PTP_CQ_STAT(struct mlx5e_ptp_cq_stats, lost_cqe) },
 };
 
 static const struct counter_desc ptp_rq_stats_desc[] = {
index b71e3fdf92c5fa206a86dcb85eeec1cdcba0f57a..ccc67a471f68aae70a52bd3d0fd00ecbfa6b39da 100644 (file)
@@ -463,6 +463,7 @@ struct mlx5e_ptp_cq_stats {
        u64 abort;
        u64 abort_abs_diff_ns;
        u64 late_cqe;
+       u64 lost_cqe;
 };
 
 struct mlx5e_rep_stats {