Commit 27ea84ab authored by Gal Pressman's avatar Gal Pressman Committed by Jakub Kicinski

net/mlx5e: Make stats group fill_stats callbacks consistent with the API

The fill_strings() callbacks were changed to accept a **data pointer,
and not rely on propagating the index value.
Make a similar change to fill_stats() callbacks to keep the API
consistent.
Signed-off-by: default avatarGal Pressman <gal@nvidia.com>
Reviewed-by: default avatarTariq Toukan <tariqt@nvidia.com>
Signed-off-by: default avatarSaeed Mahameed <saeedm@nvidia.com>
Signed-off-by: default avatarTariq Toukan <tariqt@nvidia.com>
Reviewed-by: default avatarSimon Horman <horms@kernel.org>
Link: https://lore.kernel.org/r/20240402133043.56322-5-tariqt@nvidia.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 89b34322
...@@ -89,14 +89,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ipsec_hw) ...@@ -89,14 +89,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ipsec_hw)
int i; int i;
if (!priv->ipsec) if (!priv->ipsec)
return idx; return;
mlx5e_accel_ipsec_fs_read_stats(priv, &priv->ipsec->hw_stats); mlx5e_accel_ipsec_fs_read_stats(priv, &priv->ipsec->hw_stats);
for (i = 0; i < NUM_IPSEC_HW_COUNTERS; i++) for (i = 0; i < NUM_IPSEC_HW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR_ATOMIC64(&priv->ipsec->hw_stats, mlx5e_ethtool_put_stat(
mlx5e_ipsec_hw_stats_desc, i); data,
MLX5E_READ_CTR_ATOMIC64(&priv->ipsec->hw_stats,
return idx; mlx5e_ipsec_hw_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(ipsec_sw) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(ipsec_sw)
...@@ -121,9 +121,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ipsec_sw) ...@@ -121,9 +121,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ipsec_sw)
if (priv->ipsec) if (priv->ipsec)
for (i = 0; i < NUM_IPSEC_SW_COUNTERS; i++) for (i = 0; i < NUM_IPSEC_SW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR_ATOMIC64(&priv->ipsec->sw_stats, mlx5e_ethtool_put_stat(
mlx5e_ipsec_sw_stats_desc, i); data, MLX5E_READ_CTR_ATOMIC64(
return idx; &priv->ipsec->sw_stats,
mlx5e_ipsec_sw_stats_desc, i));
} }
MLX5E_DEFINE_STATS_GRP(ipsec_hw, 0); MLX5E_DEFINE_STATS_GRP(ipsec_hw, 0);
......
...@@ -96,7 +96,7 @@ void mlx5e_ktls_cleanup(struct mlx5e_priv *priv); ...@@ -96,7 +96,7 @@ void mlx5e_ktls_cleanup(struct mlx5e_priv *priv);
int mlx5e_ktls_get_count(struct mlx5e_priv *priv); int mlx5e_ktls_get_count(struct mlx5e_priv *priv);
void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data); void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data);
int mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 *data); void mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 **data);
#else #else
static inline void mlx5e_ktls_build_netdev(struct mlx5e_priv *priv) static inline void mlx5e_ktls_build_netdev(struct mlx5e_priv *priv)
...@@ -146,10 +146,7 @@ static inline void mlx5e_ktls_cleanup(struct mlx5e_priv *priv) { } ...@@ -146,10 +146,7 @@ static inline void mlx5e_ktls_cleanup(struct mlx5e_priv *priv) { }
static inline int mlx5e_ktls_get_count(struct mlx5e_priv *priv) { return 0; } static inline int mlx5e_ktls_get_count(struct mlx5e_priv *priv) { return 0; }
static inline void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data) { } static inline void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data) { }
static inline int mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 *data) static inline void mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 **data) { }
{
return 0;
}
#endif #endif
#endif /* __MLX5E_TLS_H__ */ #endif /* __MLX5E_TLS_H__ */
...@@ -71,19 +71,18 @@ void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data) ...@@ -71,19 +71,18 @@ void mlx5e_ktls_get_strings(struct mlx5e_priv *priv, uint8_t **data)
ethtool_puts(data, mlx5e_ktls_sw_stats_desc[i].format); ethtool_puts(data, mlx5e_ktls_sw_stats_desc[i].format);
} }
int mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 *data) void mlx5e_ktls_get_stats(struct mlx5e_priv *priv, u64 **data)
{ {
unsigned int i, n, idx = 0; unsigned int i, n;
if (!priv->tls) if (!priv->tls)
return 0; return;
n = mlx5e_ktls_get_count(priv); n = mlx5e_ktls_get_count(priv);
for (i = 0; i < n; i++) for (i = 0; i < n; i++)
data[idx++] = MLX5E_READ_CTR_ATOMIC64(&priv->tls->sw_stats, mlx5e_ethtool_put_stat(
mlx5e_ktls_sw_stats_desc, data,
i); MLX5E_READ_CTR_ATOMIC64(&priv->tls->sw_stats,
mlx5e_ktls_sw_stats_desc, i));
return n;
} }
...@@ -53,19 +53,18 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(macsec_hw) ...@@ -53,19 +53,18 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(macsec_hw)
int i; int i;
if (!priv->macsec) if (!priv->macsec)
return idx; return;
if (!mlx5e_is_macsec_device(priv->mdev)) if (!mlx5e_is_macsec_device(priv->mdev))
return idx; return;
macsec_fs = priv->mdev->macsec_fs; macsec_fs = priv->mdev->macsec_fs;
mlx5_macsec_fs_get_stats_fill(macsec_fs, mlx5_macsec_fs_get_stats(macsec_fs)); mlx5_macsec_fs_get_stats_fill(macsec_fs, mlx5_macsec_fs_get_stats(macsec_fs));
for (i = 0; i < NUM_MACSEC_HW_COUNTERS; i++) for (i = 0; i < NUM_MACSEC_HW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(mlx5_macsec_fs_get_stats(macsec_fs), mlx5e_ethtool_put_stat(
mlx5e_macsec_hw_stats_desc, data, MLX5E_READ_CTR64_CPU(
i); mlx5_macsec_fs_get_stats(macsec_fs),
mlx5e_macsec_hw_stats_desc, i));
return idx;
} }
MLX5E_DEFINE_STATS_GRP(macsec_hw, 0); MLX5E_DEFINE_STATS_GRP(macsec_hw, 0);
...@@ -143,9 +143,9 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(sw_rep) ...@@ -143,9 +143,9 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(sw_rep)
int i; int i;
for (i = 0; i < NUM_VPORT_REP_SW_COUNTERS; i++) for (i = 0; i < NUM_VPORT_REP_SW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(&priv->stats.sw, mlx5e_ethtool_put_stat(
sw_rep_stats_desc, i); data, MLX5E_READ_CTR64_CPU(&priv->stats.sw,
return idx; sw_rep_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(sw_rep) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(sw_rep)
...@@ -184,12 +184,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vport_rep) ...@@ -184,12 +184,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vport_rep)
int i; int i;
for (i = 0; i < NUM_VPORT_REP_HW_COUNTERS; i++) for (i = 0; i < NUM_VPORT_REP_HW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(&priv->stats.rep_stats, mlx5e_ethtool_put_stat(
vport_rep_stats_desc, i); data, MLX5E_READ_CTR64_CPU(&priv->stats.rep_stats,
vport_rep_stats_desc, i));
for (i = 0; i < NUM_VPORT_REP_LOOPBACK_COUNTERS(priv->mdev); i++) for (i = 0; i < NUM_VPORT_REP_LOOPBACK_COUNTERS(priv->mdev); i++)
data[idx++] = MLX5E_READ_CTR64_CPU(&priv->stats.rep_stats, mlx5e_ethtool_put_stat(
vport_rep_loopback_stats_desc, i); data,
return idx; MLX5E_READ_CTR64_CPU(&priv->stats.rep_stats,
vport_rep_loopback_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vport_rep) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vport_rep)
......
...@@ -41,6 +41,11 @@ ...@@ -41,6 +41,11 @@
#include <net/page_pool/helpers.h> #include <net/page_pool/helpers.h>
#endif #endif
void mlx5e_ethtool_put_stat(u64 **data, u64 val)
{
*(*data)++ = val;
}
static unsigned int stats_grps_num(struct mlx5e_priv *priv) static unsigned int stats_grps_num(struct mlx5e_priv *priv)
{ {
return !priv->profile->stats_grps_num ? 0 : return !priv->profile->stats_grps_num ? 0 :
...@@ -90,7 +95,7 @@ void mlx5e_stats_fill(struct mlx5e_priv *priv, u64 *data, int idx) ...@@ -90,7 +95,7 @@ void mlx5e_stats_fill(struct mlx5e_priv *priv, u64 *data, int idx)
int i; int i;
for (i = 0; i < num_stats_grps; i++) for (i = 0; i < num_stats_grps; i++)
idx = stats_grps[i]->fill_stats(priv, data, idx); stats_grps[i]->fill_stats(priv, &data);
} }
void mlx5e_stats_fill_strings(struct mlx5e_priv *priv, u8 *data) void mlx5e_stats_fill_strings(struct mlx5e_priv *priv, u8 *data)
...@@ -265,8 +270,9 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(sw) ...@@ -265,8 +270,9 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(sw)
int i; int i;
for (i = 0; i < NUM_SW_COUNTERS; i++) for (i = 0; i < NUM_SW_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(&priv->stats.sw, sw_stats_desc, i); mlx5e_ethtool_put_stat(data,
return idx; MLX5E_READ_CTR64_CPU(&priv->stats.sw,
sw_stats_desc, i));
} }
static void mlx5e_stats_grp_sw_update_stats_xdp_red(struct mlx5e_sw_stats *s, static void mlx5e_stats_grp_sw_update_stats_xdp_red(struct mlx5e_sw_stats *s,
...@@ -601,12 +607,13 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(qcnt) ...@@ -601,12 +607,13 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(qcnt)
int i; int i;
for (i = 0; i < NUM_Q_COUNTERS && q_counter_any(priv); i++) for (i = 0; i < NUM_Q_COUNTERS && q_counter_any(priv); i++)
data[idx++] = MLX5E_READ_CTR32_CPU(&priv->stats.qcnt, mlx5e_ethtool_put_stat(data,
q_stats_desc, i); MLX5E_READ_CTR32_CPU(&priv->stats.qcnt,
q_stats_desc, i));
for (i = 0; i < NUM_DROP_RQ_COUNTERS && priv->drop_rq_q_counter; i++) for (i = 0; i < NUM_DROP_RQ_COUNTERS && priv->drop_rq_q_counter; i++)
data[idx++] = MLX5E_READ_CTR32_CPU(&priv->stats.qcnt, mlx5e_ethtool_put_stat(
drop_rq_stats_desc, i); data, MLX5E_READ_CTR32_CPU(&priv->stats.qcnt,
return idx; drop_rq_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(qcnt) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(qcnt)
...@@ -694,18 +701,22 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vnic_env) ...@@ -694,18 +701,22 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vnic_env)
int i; int i;
for (i = 0; i < NUM_VNIC_ENV_STEER_COUNTERS(priv->mdev); i++) for (i = 0; i < NUM_VNIC_ENV_STEER_COUNTERS(priv->mdev); i++)
data[idx++] = MLX5E_READ_CTR64_BE(priv->stats.vnic.query_vnic_env_out, mlx5e_ethtool_put_stat(
vnic_env_stats_steer_desc, i); data,
MLX5E_READ_CTR64_BE(priv->stats.vnic.query_vnic_env_out,
vnic_env_stats_steer_desc, i));
for (i = 0; i < NUM_VNIC_ENV_DEV_OOB_COUNTERS(priv->mdev); i++) for (i = 0; i < NUM_VNIC_ENV_DEV_OOB_COUNTERS(priv->mdev); i++)
data[idx++] = MLX5E_READ_CTR32_BE(priv->stats.vnic.query_vnic_env_out, mlx5e_ethtool_put_stat(
vnic_env_stats_dev_oob_desc, i); data,
MLX5E_READ_CTR32_BE(priv->stats.vnic.query_vnic_env_out,
vnic_env_stats_dev_oob_desc, i));
for (i = 0; i < NUM_VNIC_ENV_DROP_COUNTERS(priv->mdev); i++) for (i = 0; i < NUM_VNIC_ENV_DROP_COUNTERS(priv->mdev); i++)
data[idx++] = MLX5E_READ_CTR32_BE(priv->stats.vnic.query_vnic_env_out, mlx5e_ethtool_put_stat(
vnic_env_stats_drop_desc, i); data,
MLX5E_READ_CTR32_BE(priv->stats.vnic.query_vnic_env_out,
return idx; vnic_env_stats_drop_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vnic_env) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vnic_env)
...@@ -799,14 +810,16 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vport) ...@@ -799,14 +810,16 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vport)
int i; int i;
for (i = 0; i < NUM_VPORT_COUNTERS; i++) for (i = 0; i < NUM_VPORT_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_BE(priv->stats.vport.query_vport_out, mlx5e_ethtool_put_stat(
vport_stats_desc, i); data,
MLX5E_READ_CTR64_BE(priv->stats.vport.query_vport_out,
vport_stats_desc, i));
for (i = 0; i < NUM_VPORT_LOOPBACK_COUNTERS(priv->mdev); i++) for (i = 0; i < NUM_VPORT_LOOPBACK_COUNTERS(priv->mdev); i++)
data[idx++] = MLX5E_READ_CTR64_BE(priv->stats.vport.query_vport_out, mlx5e_ethtool_put_stat(
vport_loopback_stats_desc, i); data,
MLX5E_READ_CTR64_BE(priv->stats.vport.query_vport_out,
return idx; vport_loopback_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vport) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vport)
...@@ -863,9 +876,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(802_3) ...@@ -863,9 +876,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(802_3)
int i; int i;
for (i = 0; i < NUM_PPORT_802_3_COUNTERS; i++) for (i = 0; i < NUM_PPORT_802_3_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_BE(&priv->stats.pport.IEEE_802_3_counters, mlx5e_ethtool_put_stat(
pport_802_3_stats_desc, i); data, MLX5E_READ_CTR64_BE(
return idx; &priv->stats.pport.IEEE_802_3_counters,
pport_802_3_stats_desc, i));
} }
#define MLX5_BASIC_PPCNT_SUPPORTED(mdev) \ #define MLX5_BASIC_PPCNT_SUPPORTED(mdev) \
...@@ -1023,9 +1037,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2863) ...@@ -1023,9 +1037,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2863)
int i; int i;
for (i = 0; i < NUM_PPORT_2863_COUNTERS; i++) for (i = 0; i < NUM_PPORT_2863_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_BE(&priv->stats.pport.RFC_2863_counters, mlx5e_ethtool_put_stat(
pport_2863_stats_desc, i); data, MLX5E_READ_CTR64_BE(
return idx; &priv->stats.pport.RFC_2863_counters,
pport_2863_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2863) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2863)
...@@ -1081,9 +1096,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2819) ...@@ -1081,9 +1096,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2819)
int i; int i;
for (i = 0; i < NUM_PPORT_2819_COUNTERS; i++) for (i = 0; i < NUM_PPORT_2819_COUNTERS; i++)
data[idx++] = MLX5E_READ_CTR64_BE(&priv->stats.pport.RFC_2819_counters, mlx5e_ethtool_put_stat(
pport_2819_stats_desc, i); data, MLX5E_READ_CTR64_BE(
return idx; &priv->stats.pport.RFC_2819_counters,
pport_2819_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2819) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2819)
...@@ -1219,24 +1235,29 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(phy) ...@@ -1219,24 +1235,29 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(phy)
int i; int i;
/* link_down_events_phy has special handling since it is not stored in __be64 format */ /* link_down_events_phy has special handling since it is not stored in __be64 format */
data[idx++] = MLX5_GET(ppcnt_reg, priv->stats.pport.phy_counters, mlx5e_ethtool_put_stat(
counter_set.phys_layer_cntrs.link_down_events); data, MLX5_GET(ppcnt_reg, priv->stats.pport.phy_counters,
counter_set.phys_layer_cntrs.link_down_events));
if (!MLX5_CAP_PCAM_FEATURE(mdev, ppcnt_statistical_group)) if (!MLX5_CAP_PCAM_FEATURE(mdev, ppcnt_statistical_group))
return idx; return;
for (i = 0; i < NUM_PPORT_PHY_STATISTICAL_COUNTERS; i++) for (i = 0; i < NUM_PPORT_PHY_STATISTICAL_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.phy_statistical_counters, data,
pport_phy_statistical_stats_desc, i); MLX5E_READ_CTR64_BE(
&priv->stats.pport.phy_statistical_counters,
pport_phy_statistical_stats_desc, i));
if (MLX5_CAP_PCAM_FEATURE(mdev, per_lane_error_counters)) if (MLX5_CAP_PCAM_FEATURE(mdev, per_lane_error_counters))
for (i = 0; i < NUM_PPORT_PHY_STATISTICAL_PER_LANE_COUNTERS; i++) for (i = 0; i < NUM_PPORT_PHY_STATISTICAL_PER_LANE_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.phy_statistical_counters, data,
MLX5E_READ_CTR64_BE(
&priv->stats.pport
.phy_statistical_counters,
pport_phy_statistical_err_lanes_stats_desc, pport_phy_statistical_err_lanes_stats_desc,
i); i));
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(phy) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(phy)
...@@ -1426,10 +1447,11 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(eth_ext) ...@@ -1426,10 +1447,11 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(eth_ext)
if (MLX5_CAP_PCAM_FEATURE((priv)->mdev, rx_buffer_fullness_counters)) if (MLX5_CAP_PCAM_FEATURE((priv)->mdev, rx_buffer_fullness_counters))
for (i = 0; i < NUM_PPORT_ETH_EXT_COUNTERS; i++) for (i = 0; i < NUM_PPORT_ETH_EXT_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.eth_ext_counters, data,
pport_eth_ext_stats_desc, i); MLX5E_READ_CTR64_BE(
return idx; &priv->stats.pport.eth_ext_counters,
pport_eth_ext_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(eth_ext) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(eth_ext)
...@@ -1513,22 +1535,27 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pcie) ...@@ -1513,22 +1535,27 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pcie)
if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, pcie_performance_group)) if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, pcie_performance_group))
for (i = 0; i < NUM_PCIE_PERF_COUNTERS; i++) for (i = 0; i < NUM_PCIE_PERF_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR32_BE(&priv->stats.pcie.pcie_perf_counters, data,
pcie_perf_stats_desc, i); MLX5E_READ_CTR32_BE(
&priv->stats.pcie.pcie_perf_counters,
pcie_perf_stats_desc, i));
if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, tx_overflow_buffer_pkt)) if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, tx_overflow_buffer_pkt))
for (i = 0; i < NUM_PCIE_PERF_COUNTERS64; i++) for (i = 0; i < NUM_PCIE_PERF_COUNTERS64; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pcie.pcie_perf_counters, data,
pcie_perf_stats_desc64, i); MLX5E_READ_CTR64_BE(
&priv->stats.pcie.pcie_perf_counters,
pcie_perf_stats_desc64, i));
if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, pcie_outbound_stalled)) if (MLX5_CAP_MCAM_FEATURE((priv)->mdev, pcie_outbound_stalled))
for (i = 0; i < NUM_PCIE_PERF_STALL_COUNTERS; i++) for (i = 0; i < NUM_PCIE_PERF_STALL_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR32_BE(&priv->stats.pcie.pcie_perf_counters, data,
pcie_perf_stall_stats_desc, i); MLX5E_READ_CTR32_BE(
return idx; &priv->stats.pcie.pcie_perf_counters,
pcie_perf_stall_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pcie) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pcie)
...@@ -1606,20 +1633,24 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_port_buff_congest) ...@@ -1606,20 +1633,24 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_port_buff_congest)
int i, prio; int i, prio;
if (!MLX5_CAP_GEN(mdev, sbcam_reg)) if (!MLX5_CAP_GEN(mdev, sbcam_reg))
return idx; return;
for (prio = 0; prio < NUM_PPORT_PRIO; prio++) { for (prio = 0; prio < NUM_PPORT_PRIO; prio++) {
for (i = 0; i < NUM_PPORT_PER_TC_PRIO_COUNTERS; i++) for (i = 0; i < NUM_PPORT_PER_TC_PRIO_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&pport->per_tc_prio_counters[prio], data,
pport_per_tc_prio_stats_desc, i); MLX5E_READ_CTR64_BE(
&pport->per_tc_prio_counters[prio],
pport_per_tc_prio_stats_desc, i));
for (i = 0; i < NUM_PPORT_PER_TC_CONGEST_PRIO_COUNTERS ; i++) for (i = 0; i < NUM_PPORT_PER_TC_CONGEST_PRIO_COUNTERS ; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&pport->per_tc_congest_prio_counters[prio], data,
pport_per_tc_congest_prio_stats_desc, i); MLX5E_READ_CTR64_BE(
&pport->per_tc_congest_prio_counters
[prio],
pport_per_tc_congest_prio_stats_desc,
i));
} }
return idx;
} }
static void mlx5e_grp_per_tc_prio_update_stats(struct mlx5e_priv *priv) static void mlx5e_grp_per_tc_prio_update_stats(struct mlx5e_priv *priv)
...@@ -1717,20 +1748,20 @@ static void mlx5e_grp_per_prio_traffic_fill_strings(struct mlx5e_priv *priv, ...@@ -1717,20 +1748,20 @@ static void mlx5e_grp_per_prio_traffic_fill_strings(struct mlx5e_priv *priv,
} }
} }
static int mlx5e_grp_per_prio_traffic_fill_stats(struct mlx5e_priv *priv, static void mlx5e_grp_per_prio_traffic_fill_stats(struct mlx5e_priv *priv,
u64 *data, u64 **data)
int idx)
{ {
int i, prio; int i, prio;
for (prio = 0; prio < NUM_PPORT_PRIO; prio++) { for (prio = 0; prio < NUM_PPORT_PRIO; prio++) {
for (i = 0; i < NUM_PPORT_PER_PRIO_TRAFFIC_COUNTERS; i++) for (i = 0; i < NUM_PPORT_PER_PRIO_TRAFFIC_COUNTERS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.per_prio_counters[prio], data,
pport_per_prio_traffic_stats_desc, i); MLX5E_READ_CTR64_BE(
&priv->stats.pport
.per_prio_counters[prio],
pport_per_prio_traffic_stats_desc, i));
} }
return idx;
} }
static const struct counter_desc pport_per_prio_pfc_stats_desc[] = { static const struct counter_desc pport_per_prio_pfc_stats_desc[] = {
...@@ -1820,9 +1851,8 @@ static void mlx5e_grp_per_prio_pfc_fill_strings(struct mlx5e_priv *priv, ...@@ -1820,9 +1851,8 @@ static void mlx5e_grp_per_prio_pfc_fill_strings(struct mlx5e_priv *priv,
ethtool_puts(data, pport_pfc_stall_stats_desc[i].format); ethtool_puts(data, pport_pfc_stall_stats_desc[i].format);
} }
static int mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv, static void mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv,
u64 *data, u64 **data)
int idx)
{ {
unsigned long pfc_combined; unsigned long pfc_combined;
int i, prio; int i, prio;
...@@ -1830,25 +1860,30 @@ static int mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv, ...@@ -1830,25 +1860,30 @@ static int mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv,
pfc_combined = mlx5e_query_pfc_combined(priv); pfc_combined = mlx5e_query_pfc_combined(priv);
for_each_set_bit(prio, &pfc_combined, NUM_PPORT_PRIO) { for_each_set_bit(prio, &pfc_combined, NUM_PPORT_PRIO) {
for (i = 0; i < NUM_PPORT_PER_PRIO_PFC_COUNTERS; i++) { for (i = 0; i < NUM_PPORT_PER_PRIO_PFC_COUNTERS; i++) {
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.per_prio_counters[prio], data,
pport_per_prio_pfc_stats_desc, i); MLX5E_READ_CTR64_BE(
&priv->stats.pport
.per_prio_counters[prio],
pport_per_prio_pfc_stats_desc, i));
} }
} }
if (mlx5e_query_global_pause_combined(priv)) { if (mlx5e_query_global_pause_combined(priv)) {
for (i = 0; i < NUM_PPORT_PER_PRIO_PFC_COUNTERS; i++) { for (i = 0; i < NUM_PPORT_PER_PRIO_PFC_COUNTERS; i++) {
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_BE(&priv->stats.pport.per_prio_counters[0], data,
pport_per_prio_pfc_stats_desc, i); MLX5E_READ_CTR64_BE(
&priv->stats.pport.per_prio_counters[0],
pport_per_prio_pfc_stats_desc, i));
} }
} }
for (i = 0; i < NUM_PPORT_PFC_STALL_COUNTERS(priv); i++) for (i = 0; i < NUM_PPORT_PFC_STALL_COUNTERS(priv); i++)
data[idx++] = MLX5E_READ_CTR64_BE(&priv->stats.pport.per_prio_counters[0], mlx5e_ethtool_put_stat(
pport_pfc_stall_stats_desc, i); data, MLX5E_READ_CTR64_BE(
&priv->stats.pport.per_prio_counters[0],
return idx; pport_pfc_stall_stats_desc, i));
} }
static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(per_prio) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(per_prio)
...@@ -1865,9 +1900,8 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(per_prio) ...@@ -1865,9 +1900,8 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(per_prio)
static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_prio) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_prio)
{ {
idx = mlx5e_grp_per_prio_traffic_fill_stats(priv, data, idx); mlx5e_grp_per_prio_traffic_fill_stats(priv, data);
idx = mlx5e_grp_per_prio_pfc_fill_stats(priv, data, idx); mlx5e_grp_per_prio_pfc_fill_stats(priv, data);
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(per_prio) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(per_prio)
...@@ -1929,14 +1963,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pme) ...@@ -1929,14 +1963,14 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pme)
mlx5_get_pme_stats(priv->mdev, &pme_stats); mlx5_get_pme_stats(priv->mdev, &pme_stats);
for (i = 0; i < NUM_PME_STATUS_STATS; i++) for (i = 0; i < NUM_PME_STATUS_STATS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(pme_stats.status_counters, mlx5e_ethtool_put_stat(
mlx5e_pme_status_desc, i); data, MLX5E_READ_CTR64_CPU(pme_stats.status_counters,
mlx5e_pme_status_desc, i));
for (i = 0; i < NUM_PME_ERR_STATS; i++) for (i = 0; i < NUM_PME_ERR_STATS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(pme_stats.error_counters, mlx5e_ethtool_put_stat(
mlx5e_pme_error_desc, i); data, MLX5E_READ_CTR64_CPU(pme_stats.error_counters,
mlx5e_pme_error_desc, i));
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pme) { return; } static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pme) { return; }
...@@ -1953,7 +1987,7 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(tls) ...@@ -1953,7 +1987,7 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(tls)
static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(tls) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(tls)
{ {
return idx + mlx5e_ktls_get_stats(priv, data + idx); mlx5e_ktls_get_stats(priv, data);
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(tls) { return; } static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(tls) { return; }
...@@ -2250,10 +2284,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(qos) ...@@ -2250,10 +2284,10 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(qos)
struct mlx5e_sq_stats *s = READ_ONCE(stats[qid]); struct mlx5e_sq_stats *s = READ_ONCE(stats[qid]);
for (i = 0; i < NUM_QOS_SQ_STATS; i++) for (i = 0; i < NUM_QOS_SQ_STATS; i++)
data[idx++] = MLX5E_READ_CTR64_CPU(s, qos_sq_stats_desc, i); mlx5e_ethtool_put_stat(
data,
MLX5E_READ_CTR64_CPU(s, qos_sq_stats_desc, i));
} }
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(qos) { return; } static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(qos) { return; }
...@@ -2308,33 +2342,35 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ptp) ...@@ -2308,33 +2342,35 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ptp)
int i, tc; int i, tc;
if (!priv->tx_ptp_opened && !priv->rx_ptp_opened) if (!priv->tx_ptp_opened && !priv->rx_ptp_opened)
return idx; return;
for (i = 0; i < NUM_PTP_CH_STATS; i++) for (i = 0; i < NUM_PTP_CH_STATS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->ptp_stats.ch, data, MLX5E_READ_CTR64_CPU(&priv->ptp_stats.ch,
ptp_ch_stats_desc, i); ptp_ch_stats_desc, i));
if (priv->tx_ptp_opened) { if (priv->tx_ptp_opened) {
for (tc = 0; tc < priv->max_opened_tc; tc++) for (tc = 0; tc < priv->max_opened_tc; tc++)
for (i = 0; i < NUM_PTP_SQ_STATS; i++) for (i = 0; i < NUM_PTP_SQ_STATS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->ptp_stats.sq[tc], data, MLX5E_READ_CTR64_CPU(
ptp_sq_stats_desc, i); &priv->ptp_stats.sq[tc],
ptp_sq_stats_desc, i));
for (tc = 0; tc < priv->max_opened_tc; tc++) for (tc = 0; tc < priv->max_opened_tc; tc++)
for (i = 0; i < NUM_PTP_CQ_STATS; i++) for (i = 0; i < NUM_PTP_CQ_STATS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->ptp_stats.cq[tc], data, MLX5E_READ_CTR64_CPU(
ptp_cq_stats_desc, i); &priv->ptp_stats.cq[tc],
ptp_cq_stats_desc, i));
} }
if (priv->rx_ptp_opened) { if (priv->rx_ptp_opened) {
for (i = 0; i < NUM_PTP_RQ_STATS; i++) for (i = 0; i < NUM_PTP_RQ_STATS; i++)
data[idx++] = mlx5e_ethtool_put_stat(
data,
MLX5E_READ_CTR64_CPU(&priv->ptp_stats.rq, MLX5E_READ_CTR64_CPU(&priv->ptp_stats.rq,
ptp_rq_stats_desc, i); ptp_rq_stats_desc, i));
} }
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(ptp) { return; } static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(ptp) { return; }
...@@ -2393,44 +2429,50 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(channels) ...@@ -2393,44 +2429,50 @@ static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(channels)
for (i = 0; i < max_nch; i++) for (i = 0; i < max_nch; i++)
for (j = 0; j < NUM_CH_STATS; j++) for (j = 0; j < NUM_CH_STATS; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->ch, data, MLX5E_READ_CTR64_CPU(
ch_stats_desc, j); &priv->channel_stats[i]->ch,
ch_stats_desc, j));
for (i = 0; i < max_nch; i++) { for (i = 0; i < max_nch; i++) {
for (j = 0; j < NUM_RQ_STATS; j++) for (j = 0; j < NUM_RQ_STATS; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->rq, data, MLX5E_READ_CTR64_CPU(
rq_stats_desc, j); &priv->channel_stats[i]->rq,
rq_stats_desc, j));
for (j = 0; j < NUM_XSKRQ_STATS * is_xsk; j++) for (j = 0; j < NUM_XSKRQ_STATS * is_xsk; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->xskrq, data, MLX5E_READ_CTR64_CPU(
xskrq_stats_desc, j); &priv->channel_stats[i]->xskrq,
xskrq_stats_desc, j));
for (j = 0; j < NUM_RQ_XDPSQ_STATS; j++) for (j = 0; j < NUM_RQ_XDPSQ_STATS; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->rq_xdpsq, data, MLX5E_READ_CTR64_CPU(
rq_xdpsq_stats_desc, j); &priv->channel_stats[i]->rq_xdpsq,
rq_xdpsq_stats_desc, j));
} }
for (tc = 0; tc < priv->max_opened_tc; tc++) for (tc = 0; tc < priv->max_opened_tc; tc++)
for (i = 0; i < max_nch; i++) for (i = 0; i < max_nch; i++)
for (j = 0; j < NUM_SQ_STATS; j++) for (j = 0; j < NUM_SQ_STATS; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->sq[tc], data,
sq_stats_desc, j); MLX5E_READ_CTR64_CPU(
&priv->channel_stats[i]->sq[tc],
sq_stats_desc, j));
for (i = 0; i < max_nch; i++) { for (i = 0; i < max_nch; i++) {
for (j = 0; j < NUM_XSKSQ_STATS * is_xsk; j++) for (j = 0; j < NUM_XSKSQ_STATS * is_xsk; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->xsksq, data, MLX5E_READ_CTR64_CPU(
xsksq_stats_desc, j); &priv->channel_stats[i]->xsksq,
xsksq_stats_desc, j));
for (j = 0; j < NUM_XDPSQ_STATS; j++) for (j = 0; j < NUM_XDPSQ_STATS; j++)
data[idx++] = mlx5e_ethtool_put_stat(
MLX5E_READ_CTR64_CPU(&priv->channel_stats[i]->xdpsq, data, MLX5E_READ_CTR64_CPU(
xdpsq_stats_desc, j); &priv->channel_stats[i]->xdpsq,
xdpsq_stats_desc, j));
} }
return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(channels) { return; } static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(channels) { return; }
......
...@@ -72,10 +72,12 @@ struct mlx5e_stats_grp { ...@@ -72,10 +72,12 @@ struct mlx5e_stats_grp {
u16 update_stats_mask; u16 update_stats_mask;
int (*get_num_stats)(struct mlx5e_priv *priv); int (*get_num_stats)(struct mlx5e_priv *priv);
void (*fill_strings)(struct mlx5e_priv *priv, u8 **data); void (*fill_strings)(struct mlx5e_priv *priv, u8 **data);
int (*fill_stats)(struct mlx5e_priv *priv, u64 *data, int idx); void (*fill_stats)(struct mlx5e_priv *priv, u64 **data);
void (*update_stats)(struct mlx5e_priv *priv); void (*update_stats)(struct mlx5e_priv *priv);
}; };
void mlx5e_ethtool_put_stat(u64 **data, u64 val);
typedef const struct mlx5e_stats_grp *const mlx5e_stats_grp_t; typedef const struct mlx5e_stats_grp *const mlx5e_stats_grp_t;
#define MLX5E_STATS_GRP_OP(grp, name) mlx5e_stats_grp_ ## grp ## _ ## name #define MLX5E_STATS_GRP_OP(grp, name) mlx5e_stats_grp_ ## grp ## _ ## name
...@@ -90,7 +92,7 @@ typedef const struct mlx5e_stats_grp *const mlx5e_stats_grp_t; ...@@ -90,7 +92,7 @@ typedef const struct mlx5e_stats_grp *const mlx5e_stats_grp_t;
void MLX5E_STATS_GRP_OP(grp, fill_strings)(struct mlx5e_priv *priv, u8 **data) void MLX5E_STATS_GRP_OP(grp, fill_strings)(struct mlx5e_priv *priv, u8 **data)
#define MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(grp) \ #define MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(grp) \
int MLX5E_STATS_GRP_OP(grp, fill_stats)(struct mlx5e_priv *priv, u64 *data, int idx) void MLX5E_STATS_GRP_OP(grp, fill_stats)(struct mlx5e_priv *priv, u64 **data)
#define MLX5E_STATS_GRP(grp) mlx5e_stats_grp_ ## grp #define MLX5E_STATS_GRP(grp) mlx5e_stats_grp_ ## grp
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment