Commit 96b12796 authored by Saeed Mahameed's avatar Saeed Mahameed

net/mlx5e: Declare stats groups via macro

Introduce new macros to declare stats callbacks and groups, for better
code reuse and for individual groups selection per profile which will be
introduced in next patches.
Signed-off-by: default avatarSaeed Mahameed <saeedm@mellanox.com>
Reviewed-by: default avatarTariq Toukan <tariqt@mellanox.com>
parent 3460c184
...@@ -162,7 +162,7 @@ static void mlx5e_uplink_rep_update_hw_counters(struct mlx5e_priv *priv) ...@@ -162,7 +162,7 @@ static void mlx5e_uplink_rep_update_hw_counters(struct mlx5e_priv *priv)
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct rtnl_link_stats64 *vport_stats; struct rtnl_link_stats64 *vport_stats;
mlx5e_grp_802_3_update_stats(priv); MLX5E_STATS_GRP_OP(802_3, update_stats)(priv);
vport_stats = &priv->stats.vf_vport; vport_stats = &priv->stats.vf_vport;
......
...@@ -198,12 +198,12 @@ static const struct counter_desc sw_stats_desc[] = { ...@@ -198,12 +198,12 @@ static const struct counter_desc sw_stats_desc[] = {
#define NUM_SW_COUNTERS ARRAY_SIZE(sw_stats_desc) #define NUM_SW_COUNTERS ARRAY_SIZE(sw_stats_desc)
static int mlx5e_grp_sw_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(sw)
{ {
return NUM_SW_COUNTERS; return NUM_SW_COUNTERS;
} }
static int mlx5e_grp_sw_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(sw)
{ {
int i; int i;
...@@ -212,7 +212,7 @@ static int mlx5e_grp_sw_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx) ...@@ -212,7 +212,7 @@ static int mlx5e_grp_sw_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx)
return idx; return idx;
} }
static int mlx5e_grp_sw_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(sw)
{ {
int i; int i;
...@@ -221,7 +221,7 @@ static int mlx5e_grp_sw_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) ...@@ -221,7 +221,7 @@ static int mlx5e_grp_sw_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx)
return idx; return idx;
} }
static void mlx5e_grp_sw_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(sw)
{ {
struct mlx5e_sw_stats *s = &priv->stats.sw; struct mlx5e_sw_stats *s = &priv->stats.sw;
int i; int i;
...@@ -367,7 +367,7 @@ static const struct counter_desc drop_rq_stats_desc[] = { ...@@ -367,7 +367,7 @@ static const struct counter_desc drop_rq_stats_desc[] = {
#define NUM_Q_COUNTERS ARRAY_SIZE(q_stats_desc) #define NUM_Q_COUNTERS ARRAY_SIZE(q_stats_desc)
#define NUM_DROP_RQ_COUNTERS ARRAY_SIZE(drop_rq_stats_desc) #define NUM_DROP_RQ_COUNTERS ARRAY_SIZE(drop_rq_stats_desc)
static int mlx5e_grp_q_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(qcnt)
{ {
int num_stats = 0; int num_stats = 0;
...@@ -380,7 +380,7 @@ static int mlx5e_grp_q_get_num_stats(struct mlx5e_priv *priv) ...@@ -380,7 +380,7 @@ static int mlx5e_grp_q_get_num_stats(struct mlx5e_priv *priv)
return num_stats; return num_stats;
} }
static int mlx5e_grp_q_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(qcnt)
{ {
int i; int i;
...@@ -395,7 +395,7 @@ static int mlx5e_grp_q_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx) ...@@ -395,7 +395,7 @@ static int mlx5e_grp_q_fill_strings(struct mlx5e_priv *priv, u8 *data, int idx)
return idx; return idx;
} }
static int mlx5e_grp_q_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(qcnt)
{ {
int i; int i;
...@@ -408,7 +408,7 @@ static int mlx5e_grp_q_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) ...@@ -408,7 +408,7 @@ static int mlx5e_grp_q_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx)
return idx; return idx;
} }
static void mlx5e_grp_q_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(qcnt)
{ {
struct mlx5e_qcounter_stats *qcnt = &priv->stats.qcnt; struct mlx5e_qcounter_stats *qcnt = &priv->stats.qcnt;
u32 out[MLX5_ST_SZ_DW(query_q_counter_out)]; u32 out[MLX5_ST_SZ_DW(query_q_counter_out)];
...@@ -443,14 +443,13 @@ static const struct counter_desc vnic_env_stats_dev_oob_desc[] = { ...@@ -443,14 +443,13 @@ static const struct counter_desc vnic_env_stats_dev_oob_desc[] = {
(MLX5_CAP_GEN(dev, vnic_env_int_rq_oob) ? \ (MLX5_CAP_GEN(dev, vnic_env_int_rq_oob) ? \
ARRAY_SIZE(vnic_env_stats_dev_oob_desc) : 0) ARRAY_SIZE(vnic_env_stats_dev_oob_desc) : 0)
static int mlx5e_grp_vnic_env_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(vnic_env)
{ {
return NUM_VNIC_ENV_STEER_COUNTERS(priv->mdev) + return NUM_VNIC_ENV_STEER_COUNTERS(priv->mdev) +
NUM_VNIC_ENV_DEV_OOB_COUNTERS(priv->mdev); NUM_VNIC_ENV_DEV_OOB_COUNTERS(priv->mdev);
} }
static int mlx5e_grp_vnic_env_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(vnic_env)
int idx)
{ {
int i; int i;
...@@ -464,8 +463,7 @@ static int mlx5e_grp_vnic_env_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -464,8 +463,7 @@ static int mlx5e_grp_vnic_env_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_vnic_env_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vnic_env)
int idx)
{ {
int i; int i;
...@@ -479,7 +477,7 @@ static int mlx5e_grp_vnic_env_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -479,7 +477,7 @@ static int mlx5e_grp_vnic_env_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_vnic_env_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vnic_env)
{ {
u32 *out = (u32 *)priv->stats.vnic.query_vnic_env_out; u32 *out = (u32 *)priv->stats.vnic.query_vnic_env_out;
int outlen = MLX5_ST_SZ_BYTES(query_vnic_env_out); int outlen = MLX5_ST_SZ_BYTES(query_vnic_env_out);
...@@ -542,13 +540,12 @@ static const struct counter_desc vport_stats_desc[] = { ...@@ -542,13 +540,12 @@ static const struct counter_desc vport_stats_desc[] = {
#define NUM_VPORT_COUNTERS ARRAY_SIZE(vport_stats_desc) #define NUM_VPORT_COUNTERS ARRAY_SIZE(vport_stats_desc)
static int mlx5e_grp_vport_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(vport)
{ {
return NUM_VPORT_COUNTERS; return NUM_VPORT_COUNTERS;
} }
static int mlx5e_grp_vport_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(vport)
int idx)
{ {
int i; int i;
...@@ -557,8 +554,7 @@ static int mlx5e_grp_vport_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -557,8 +554,7 @@ static int mlx5e_grp_vport_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_vport_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(vport)
int idx)
{ {
int i; int i;
...@@ -568,7 +564,7 @@ static int mlx5e_grp_vport_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -568,7 +564,7 @@ static int mlx5e_grp_vport_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_vport_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(vport)
{ {
int outlen = MLX5_ST_SZ_BYTES(query_vport_counter_out); int outlen = MLX5_ST_SZ_BYTES(query_vport_counter_out);
u32 *out = (u32 *)priv->stats.vport.query_vport_out; u32 *out = (u32 *)priv->stats.vport.query_vport_out;
...@@ -607,13 +603,12 @@ static const struct counter_desc pport_802_3_stats_desc[] = { ...@@ -607,13 +603,12 @@ static const struct counter_desc pport_802_3_stats_desc[] = {
#define NUM_PPORT_802_3_COUNTERS ARRAY_SIZE(pport_802_3_stats_desc) #define NUM_PPORT_802_3_COUNTERS ARRAY_SIZE(pport_802_3_stats_desc)
static int mlx5e_grp_802_3_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(802_3)
{ {
return NUM_PPORT_802_3_COUNTERS; return NUM_PPORT_802_3_COUNTERS;
} }
static int mlx5e_grp_802_3_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(802_3)
int idx)
{ {
int i; int i;
...@@ -622,8 +617,7 @@ static int mlx5e_grp_802_3_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -622,8 +617,7 @@ static int mlx5e_grp_802_3_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_802_3_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(802_3)
int idx)
{ {
int i; int i;
...@@ -636,7 +630,7 @@ static int mlx5e_grp_802_3_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -636,7 +630,7 @@ static int mlx5e_grp_802_3_fill_stats(struct mlx5e_priv *priv, u64 *data,
#define MLX5_BASIC_PPCNT_SUPPORTED(mdev) \ #define MLX5_BASIC_PPCNT_SUPPORTED(mdev) \
(MLX5_CAP_GEN(mdev, pcam_reg) ? MLX5_CAP_PCAM_REG(mdev, ppcnt) : 1) (MLX5_CAP_GEN(mdev, pcam_reg) ? MLX5_CAP_PCAM_REG(mdev, ppcnt) : 1)
void mlx5e_grp_802_3_update_stats(struct mlx5e_priv *priv) MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(802_3)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -664,13 +658,12 @@ static const struct counter_desc pport_2863_stats_desc[] = { ...@@ -664,13 +658,12 @@ static const struct counter_desc pport_2863_stats_desc[] = {
#define NUM_PPORT_2863_COUNTERS ARRAY_SIZE(pport_2863_stats_desc) #define NUM_PPORT_2863_COUNTERS ARRAY_SIZE(pport_2863_stats_desc)
static int mlx5e_grp_2863_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(2863)
{ {
return NUM_PPORT_2863_COUNTERS; return NUM_PPORT_2863_COUNTERS;
} }
static int mlx5e_grp_2863_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(2863)
int idx)
{ {
int i; int i;
...@@ -679,8 +672,7 @@ static int mlx5e_grp_2863_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -679,8 +672,7 @@ static int mlx5e_grp_2863_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_2863_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2863)
int idx)
{ {
int i; int i;
...@@ -690,7 +682,7 @@ static int mlx5e_grp_2863_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -690,7 +682,7 @@ static int mlx5e_grp_2863_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_2863_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2863)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -725,13 +717,12 @@ static const struct counter_desc pport_2819_stats_desc[] = { ...@@ -725,13 +717,12 @@ static const struct counter_desc pport_2819_stats_desc[] = {
#define NUM_PPORT_2819_COUNTERS ARRAY_SIZE(pport_2819_stats_desc) #define NUM_PPORT_2819_COUNTERS ARRAY_SIZE(pport_2819_stats_desc)
static int mlx5e_grp_2819_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(2819)
{ {
return NUM_PPORT_2819_COUNTERS; return NUM_PPORT_2819_COUNTERS;
} }
static int mlx5e_grp_2819_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(2819)
int idx)
{ {
int i; int i;
...@@ -740,8 +731,7 @@ static int mlx5e_grp_2819_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -740,8 +731,7 @@ static int mlx5e_grp_2819_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_2819_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(2819)
int idx)
{ {
int i; int i;
...@@ -751,7 +741,7 @@ static int mlx5e_grp_2819_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -751,7 +741,7 @@ static int mlx5e_grp_2819_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_2819_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(2819)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -789,7 +779,7 @@ pport_phy_statistical_err_lanes_stats_desc[] = { ...@@ -789,7 +779,7 @@ pport_phy_statistical_err_lanes_stats_desc[] = {
#define NUM_PPORT_PHY_STATISTICAL_PER_LANE_COUNTERS \ #define NUM_PPORT_PHY_STATISTICAL_PER_LANE_COUNTERS \
ARRAY_SIZE(pport_phy_statistical_err_lanes_stats_desc) ARRAY_SIZE(pport_phy_statistical_err_lanes_stats_desc)
static int mlx5e_grp_phy_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(phy)
{ {
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
int num_stats; int num_stats;
...@@ -806,8 +796,7 @@ static int mlx5e_grp_phy_get_num_stats(struct mlx5e_priv *priv) ...@@ -806,8 +796,7 @@ static int mlx5e_grp_phy_get_num_stats(struct mlx5e_priv *priv)
return num_stats; return num_stats;
} }
static int mlx5e_grp_phy_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(phy)
int idx)
{ {
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
int i; int i;
...@@ -829,7 +818,7 @@ static int mlx5e_grp_phy_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -829,7 +818,7 @@ static int mlx5e_grp_phy_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_phy_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(phy)
{ {
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
int i; int i;
...@@ -855,7 +844,7 @@ static int mlx5e_grp_phy_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) ...@@ -855,7 +844,7 @@ static int mlx5e_grp_phy_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx)
return idx; return idx;
} }
static void mlx5e_grp_phy_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(phy)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -885,7 +874,7 @@ static const struct counter_desc pport_eth_ext_stats_desc[] = { ...@@ -885,7 +874,7 @@ static const struct counter_desc pport_eth_ext_stats_desc[] = {
#define NUM_PPORT_ETH_EXT_COUNTERS ARRAY_SIZE(pport_eth_ext_stats_desc) #define NUM_PPORT_ETH_EXT_COUNTERS ARRAY_SIZE(pport_eth_ext_stats_desc)
static int mlx5e_grp_eth_ext_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_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))
return NUM_PPORT_ETH_EXT_COUNTERS; return NUM_PPORT_ETH_EXT_COUNTERS;
...@@ -893,8 +882,7 @@ static int mlx5e_grp_eth_ext_get_num_stats(struct mlx5e_priv *priv) ...@@ -893,8 +882,7 @@ static int mlx5e_grp_eth_ext_get_num_stats(struct mlx5e_priv *priv)
return 0; return 0;
} }
static int mlx5e_grp_eth_ext_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(eth_ext)
int idx)
{ {
int i; int i;
...@@ -905,8 +893,7 @@ static int mlx5e_grp_eth_ext_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -905,8 +893,7 @@ static int mlx5e_grp_eth_ext_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_eth_ext_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(eth_ext)
int idx)
{ {
int i; int i;
...@@ -918,7 +905,7 @@ static int mlx5e_grp_eth_ext_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -918,7 +905,7 @@ static int mlx5e_grp_eth_ext_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_eth_ext_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(eth_ext)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -959,7 +946,7 @@ static const struct counter_desc pcie_perf_stall_stats_desc[] = { ...@@ -959,7 +946,7 @@ static const struct counter_desc pcie_perf_stall_stats_desc[] = {
#define NUM_PCIE_PERF_COUNTERS64 ARRAY_SIZE(pcie_perf_stats_desc64) #define NUM_PCIE_PERF_COUNTERS64 ARRAY_SIZE(pcie_perf_stats_desc64)
#define NUM_PCIE_PERF_STALL_COUNTERS ARRAY_SIZE(pcie_perf_stall_stats_desc) #define NUM_PCIE_PERF_STALL_COUNTERS ARRAY_SIZE(pcie_perf_stall_stats_desc)
static int mlx5e_grp_pcie_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(pcie)
{ {
int num_stats = 0; int num_stats = 0;
...@@ -975,8 +962,7 @@ static int mlx5e_grp_pcie_get_num_stats(struct mlx5e_priv *priv) ...@@ -975,8 +962,7 @@ static int mlx5e_grp_pcie_get_num_stats(struct mlx5e_priv *priv)
return num_stats; return num_stats;
} }
static int mlx5e_grp_pcie_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(pcie)
int idx)
{ {
int i; int i;
...@@ -997,8 +983,7 @@ static int mlx5e_grp_pcie_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -997,8 +983,7 @@ static int mlx5e_grp_pcie_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_pcie_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pcie)
int idx)
{ {
int i; int i;
...@@ -1022,7 +1007,7 @@ static int mlx5e_grp_pcie_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -1022,7 +1007,7 @@ static int mlx5e_grp_pcie_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static void mlx5e_grp_pcie_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pcie)
{ {
struct mlx5e_pcie_stats *pcie_stats = &priv->stats.pcie; struct mlx5e_pcie_stats *pcie_stats = &priv->stats.pcie;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -1070,8 +1055,7 @@ static int mlx5e_grp_per_tc_prio_get_num_stats(struct mlx5e_priv *priv) ...@@ -1070,8 +1055,7 @@ static int mlx5e_grp_per_tc_prio_get_num_stats(struct mlx5e_priv *priv)
return NUM_PPORT_PER_TC_PRIO_COUNTERS * NUM_PPORT_PRIO; return NUM_PPORT_PER_TC_PRIO_COUNTERS * NUM_PPORT_PRIO;
} }
static int mlx5e_grp_per_port_buffer_congest_fill_strings(struct mlx5e_priv *priv, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(per_port_buff_congest)
u8 *data, int idx)
{ {
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
int i, prio; int i, prio;
...@@ -1091,8 +1075,7 @@ static int mlx5e_grp_per_port_buffer_congest_fill_strings(struct mlx5e_priv *pri ...@@ -1091,8 +1075,7 @@ static int mlx5e_grp_per_port_buffer_congest_fill_strings(struct mlx5e_priv *pri
return idx; return idx;
} }
static int mlx5e_grp_per_port_buffer_congest_fill_stats(struct mlx5e_priv *priv, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_port_buff_congest)
u64 *data, int idx)
{ {
struct mlx5e_pport_stats *pport = &priv->stats.pport; struct mlx5e_pport_stats *pport = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -1167,13 +1150,13 @@ static void mlx5e_grp_per_tc_congest_prio_update_stats(struct mlx5e_priv *priv) ...@@ -1167,13 +1150,13 @@ static void mlx5e_grp_per_tc_congest_prio_update_stats(struct mlx5e_priv *priv)
} }
} }
static int mlx5e_grp_per_port_buffer_congest_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(per_port_buff_congest)
{ {
return mlx5e_grp_per_tc_prio_get_num_stats(priv) + return mlx5e_grp_per_tc_prio_get_num_stats(priv) +
mlx5e_grp_per_tc_congest_prio_get_num_stats(priv); mlx5e_grp_per_tc_congest_prio_get_num_stats(priv);
} }
static void mlx5e_grp_per_port_buffer_congest_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(per_port_buff_congest)
{ {
mlx5e_grp_per_tc_prio_update_stats(priv); mlx5e_grp_per_tc_prio_update_stats(priv);
mlx5e_grp_per_tc_congest_prio_update_stats(priv); mlx5e_grp_per_tc_congest_prio_update_stats(priv);
...@@ -1348,29 +1331,27 @@ static int mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv, ...@@ -1348,29 +1331,27 @@ static int mlx5e_grp_per_prio_pfc_fill_stats(struct mlx5e_priv *priv,
return idx; return idx;
} }
static int mlx5e_grp_per_prio_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(per_prio)
{ {
return mlx5e_grp_per_prio_traffic_get_num_stats() + return mlx5e_grp_per_prio_traffic_get_num_stats() +
mlx5e_grp_per_prio_pfc_get_num_stats(priv); mlx5e_grp_per_prio_pfc_get_num_stats(priv);
} }
static int mlx5e_grp_per_prio_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(per_prio)
int idx)
{ {
idx = mlx5e_grp_per_prio_traffic_fill_strings(priv, data, idx); idx = mlx5e_grp_per_prio_traffic_fill_strings(priv, data, idx);
idx = mlx5e_grp_per_prio_pfc_fill_strings(priv, data, idx); idx = mlx5e_grp_per_prio_pfc_fill_strings(priv, data, idx);
return idx; return idx;
} }
static int mlx5e_grp_per_prio_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(per_prio)
int idx)
{ {
idx = mlx5e_grp_per_prio_traffic_fill_stats(priv, data, idx); idx = mlx5e_grp_per_prio_traffic_fill_stats(priv, data, idx);
idx = mlx5e_grp_per_prio_pfc_fill_stats(priv, data, idx); idx = mlx5e_grp_per_prio_pfc_fill_stats(priv, data, idx);
return idx; return idx;
} }
static void mlx5e_grp_per_prio_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(per_prio)
{ {
struct mlx5e_pport_stats *pstats = &priv->stats.pport; struct mlx5e_pport_stats *pstats = &priv->stats.pport;
struct mlx5_core_dev *mdev = priv->mdev; struct mlx5_core_dev *mdev = priv->mdev;
...@@ -1405,13 +1386,12 @@ static const struct counter_desc mlx5e_pme_error_desc[] = { ...@@ -1405,13 +1386,12 @@ static const struct counter_desc mlx5e_pme_error_desc[] = {
#define NUM_PME_STATUS_STATS ARRAY_SIZE(mlx5e_pme_status_desc) #define NUM_PME_STATUS_STATS ARRAY_SIZE(mlx5e_pme_status_desc)
#define NUM_PME_ERR_STATS ARRAY_SIZE(mlx5e_pme_error_desc) #define NUM_PME_ERR_STATS ARRAY_SIZE(mlx5e_pme_error_desc)
static int mlx5e_grp_pme_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(pme)
{ {
return NUM_PME_STATUS_STATS + NUM_PME_ERR_STATS; return NUM_PME_STATUS_STATS + NUM_PME_ERR_STATS;
} }
static int mlx5e_grp_pme_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(pme)
int idx)
{ {
int i; int i;
...@@ -1424,8 +1404,7 @@ static int mlx5e_grp_pme_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -1424,8 +1404,7 @@ static int mlx5e_grp_pme_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_pme_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(pme)
int idx)
{ {
struct mlx5_pme_stats pme_stats; struct mlx5_pme_stats pme_stats;
int i; int i;
...@@ -1443,45 +1422,46 @@ static int mlx5e_grp_pme_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -1443,45 +1422,46 @@ static int mlx5e_grp_pme_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static int mlx5e_grp_ipsec_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(pme) { return; }
static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(ipsec)
{ {
return mlx5e_ipsec_get_count(priv); return mlx5e_ipsec_get_count(priv);
} }
static int mlx5e_grp_ipsec_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(ipsec)
int idx)
{ {
return idx + mlx5e_ipsec_get_strings(priv, return idx + mlx5e_ipsec_get_strings(priv,
data + idx * ETH_GSTRING_LEN); data + idx * ETH_GSTRING_LEN);
} }
static int mlx5e_grp_ipsec_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(ipsec)
int idx)
{ {
return idx + mlx5e_ipsec_get_stats(priv, data + idx); return idx + mlx5e_ipsec_get_stats(priv, data + idx);
} }
static void mlx5e_grp_ipsec_update_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(ipsec)
{ {
mlx5e_ipsec_update_stats(priv); mlx5e_ipsec_update_stats(priv);
} }
static int mlx5e_grp_tls_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(tls)
{ {
return mlx5e_tls_get_count(priv); return mlx5e_tls_get_count(priv);
} }
static int mlx5e_grp_tls_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(tls)
int idx)
{ {
return idx + mlx5e_tls_get_strings(priv, data + idx * ETH_GSTRING_LEN); return idx + mlx5e_tls_get_strings(priv, data + idx * ETH_GSTRING_LEN);
} }
static int mlx5e_grp_tls_fill_stats(struct mlx5e_priv *priv, u64 *data, int idx) static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(tls)
{ {
return idx + mlx5e_tls_get_stats(priv, data + idx); return idx + mlx5e_tls_get_stats(priv, data + idx);
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(tls) { return; }
static const struct counter_desc rq_stats_desc[] = { static const struct counter_desc rq_stats_desc[] = {
{ MLX5E_DECLARE_RX_STAT(struct mlx5e_rq_stats, packets) }, { MLX5E_DECLARE_RX_STAT(struct mlx5e_rq_stats, packets) },
{ MLX5E_DECLARE_RX_STAT(struct mlx5e_rq_stats, bytes) }, { MLX5E_DECLARE_RX_STAT(struct mlx5e_rq_stats, bytes) },
...@@ -1615,7 +1595,7 @@ static const struct counter_desc ch_stats_desc[] = { ...@@ -1615,7 +1595,7 @@ static const struct counter_desc ch_stats_desc[] = {
#define NUM_XSKSQ_STATS ARRAY_SIZE(xsksq_stats_desc) #define NUM_XSKSQ_STATS ARRAY_SIZE(xsksq_stats_desc)
#define NUM_CH_STATS ARRAY_SIZE(ch_stats_desc) #define NUM_CH_STATS ARRAY_SIZE(ch_stats_desc)
static int mlx5e_grp_channels_get_num_stats(struct mlx5e_priv *priv) static MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(channels)
{ {
int max_nch = priv->max_nch; int max_nch = priv->max_nch;
...@@ -1628,8 +1608,7 @@ static int mlx5e_grp_channels_get_num_stats(struct mlx5e_priv *priv) ...@@ -1628,8 +1608,7 @@ static int mlx5e_grp_channels_get_num_stats(struct mlx5e_priv *priv)
(NUM_XSKSQ_STATS * max_nch * priv->xsk.ever_used); (NUM_XSKSQ_STATS * max_nch * priv->xsk.ever_used);
} }
static int mlx5e_grp_channels_fill_strings(struct mlx5e_priv *priv, u8 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(channels)
int idx)
{ {
bool is_xsk = priv->xsk.ever_used; bool is_xsk = priv->xsk.ever_used;
int max_nch = priv->max_nch; int max_nch = priv->max_nch;
...@@ -1671,8 +1650,7 @@ static int mlx5e_grp_channels_fill_strings(struct mlx5e_priv *priv, u8 *data, ...@@ -1671,8 +1650,7 @@ static int mlx5e_grp_channels_fill_strings(struct mlx5e_priv *priv, u8 *data,
return idx; return idx;
} }
static int mlx5e_grp_channels_fill_stats(struct mlx5e_priv *priv, u64 *data, static MLX5E_DECLARE_STATS_GRP_OP_FILL_STATS(channels)
int idx)
{ {
bool is_xsk = priv->xsk.ever_used; bool is_xsk = priv->xsk.ever_used;
int max_nch = priv->max_nch; int max_nch = priv->max_nch;
...@@ -1720,104 +1698,26 @@ static int mlx5e_grp_channels_fill_stats(struct mlx5e_priv *priv, u64 *data, ...@@ -1720,104 +1698,26 @@ static int mlx5e_grp_channels_fill_stats(struct mlx5e_priv *priv, u64 *data,
return idx; return idx;
} }
static MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(channels) { return; }
/* The stats groups order is opposite to the update_stats() order calls */ /* The stats groups order is opposite to the update_stats() order calls */
const struct mlx5e_stats_grp mlx5e_nic_stats_grps[] = { const struct mlx5e_stats_grp mlx5e_nic_stats_grps[] = {
{ MLX5E_DEFINE_STATS_GRP(sw, 0),
.get_num_stats = mlx5e_grp_sw_get_num_stats, MLX5E_DEFINE_STATS_GRP(qcnt, MLX5E_NDO_UPDATE_STATS),
.fill_strings = mlx5e_grp_sw_fill_strings, MLX5E_DEFINE_STATS_GRP(vnic_env, 0),
.fill_stats = mlx5e_grp_sw_fill_stats, MLX5E_DEFINE_STATS_GRP(vport, MLX5E_NDO_UPDATE_STATS),
.update_stats = mlx5e_grp_sw_update_stats, MLX5E_DEFINE_STATS_GRP(802_3, MLX5E_NDO_UPDATE_STATS),
}, MLX5E_DEFINE_STATS_GRP(2863, 0),
{ MLX5E_DEFINE_STATS_GRP(2819, 0),
.get_num_stats = mlx5e_grp_q_get_num_stats, MLX5E_DEFINE_STATS_GRP(phy, 0),
.fill_strings = mlx5e_grp_q_fill_strings, MLX5E_DEFINE_STATS_GRP(eth_ext, 0),
.fill_stats = mlx5e_grp_q_fill_stats, MLX5E_DEFINE_STATS_GRP(pcie, 0),
.update_stats_mask = MLX5E_NDO_UPDATE_STATS, MLX5E_DEFINE_STATS_GRP(per_prio, 0),
.update_stats = mlx5e_grp_q_update_stats, MLX5E_DEFINE_STATS_GRP(pme, 0),
}, MLX5E_DEFINE_STATS_GRP(ipsec, 0),
{ MLX5E_DEFINE_STATS_GRP(tls, 0),
.get_num_stats = mlx5e_grp_vnic_env_get_num_stats, MLX5E_DEFINE_STATS_GRP(channels, 0),
.fill_strings = mlx5e_grp_vnic_env_fill_strings, MLX5E_DEFINE_STATS_GRP(per_port_buff_congest, 0),
.fill_stats = mlx5e_grp_vnic_env_fill_stats,
.update_stats = mlx5e_grp_vnic_env_update_stats,
},
{
.get_num_stats = mlx5e_grp_vport_get_num_stats,
.fill_strings = mlx5e_grp_vport_fill_strings,
.fill_stats = mlx5e_grp_vport_fill_stats,
.update_stats_mask = MLX5E_NDO_UPDATE_STATS,
.update_stats = mlx5e_grp_vport_update_stats,
},
{
.get_num_stats = mlx5e_grp_802_3_get_num_stats,
.fill_strings = mlx5e_grp_802_3_fill_strings,
.fill_stats = mlx5e_grp_802_3_fill_stats,
.update_stats_mask = MLX5E_NDO_UPDATE_STATS,
.update_stats = mlx5e_grp_802_3_update_stats,
},
{
.get_num_stats = mlx5e_grp_2863_get_num_stats,
.fill_strings = mlx5e_grp_2863_fill_strings,
.fill_stats = mlx5e_grp_2863_fill_stats,
.update_stats = mlx5e_grp_2863_update_stats,
},
{
.get_num_stats = mlx5e_grp_2819_get_num_stats,
.fill_strings = mlx5e_grp_2819_fill_strings,
.fill_stats = mlx5e_grp_2819_fill_stats,
.update_stats = mlx5e_grp_2819_update_stats,
},
{
.get_num_stats = mlx5e_grp_phy_get_num_stats,
.fill_strings = mlx5e_grp_phy_fill_strings,
.fill_stats = mlx5e_grp_phy_fill_stats,
.update_stats = mlx5e_grp_phy_update_stats,
},
{
.get_num_stats = mlx5e_grp_eth_ext_get_num_stats,
.fill_strings = mlx5e_grp_eth_ext_fill_strings,
.fill_stats = mlx5e_grp_eth_ext_fill_stats,
.update_stats = mlx5e_grp_eth_ext_update_stats,
},
{
.get_num_stats = mlx5e_grp_pcie_get_num_stats,
.fill_strings = mlx5e_grp_pcie_fill_strings,
.fill_stats = mlx5e_grp_pcie_fill_stats,
.update_stats = mlx5e_grp_pcie_update_stats,
},
{
.get_num_stats = mlx5e_grp_per_prio_get_num_stats,
.fill_strings = mlx5e_grp_per_prio_fill_strings,
.fill_stats = mlx5e_grp_per_prio_fill_stats,
.update_stats = mlx5e_grp_per_prio_update_stats,
},
{
.get_num_stats = mlx5e_grp_pme_get_num_stats,
.fill_strings = mlx5e_grp_pme_fill_strings,
.fill_stats = mlx5e_grp_pme_fill_stats,
},
{
.get_num_stats = mlx5e_grp_ipsec_get_num_stats,
.fill_strings = mlx5e_grp_ipsec_fill_strings,
.fill_stats = mlx5e_grp_ipsec_fill_stats,
.update_stats = mlx5e_grp_ipsec_update_stats,
},
{
.get_num_stats = mlx5e_grp_tls_get_num_stats,
.fill_strings = mlx5e_grp_tls_fill_strings,
.fill_stats = mlx5e_grp_tls_fill_stats,
},
{
.get_num_stats = mlx5e_grp_channels_get_num_stats,
.fill_strings = mlx5e_grp_channels_fill_strings,
.fill_stats = mlx5e_grp_channels_fill_stats,
},
{
.get_num_stats = mlx5e_grp_per_port_buffer_congest_get_num_stats,
.fill_strings = mlx5e_grp_per_port_buffer_congest_fill_strings,
.fill_stats = mlx5e_grp_per_port_buffer_congest_fill_stats,
.update_stats = mlx5e_grp_per_port_buffer_congest_update_stats,
},
}; };
unsigned int mlx5e_nic_stats_grps_num(struct mlx5e_priv *priv) unsigned int mlx5e_nic_stats_grps_num(struct mlx5e_priv *priv)
......
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE. * SOFTWARE.
*/ */
#ifndef __MLX5_EN_STATS_H__ #ifndef __MLX5_EN_STATS_H__
#define __MLX5_EN_STATS_H__ #define __MLX5_EN_STATS_H__
...@@ -68,6 +69,28 @@ struct mlx5e_stats_grp { ...@@ -68,6 +69,28 @@ struct mlx5e_stats_grp {
void (*update_stats)(struct mlx5e_priv *priv); void (*update_stats)(struct mlx5e_priv *priv);
}; };
#define MLX5E_STATS_GRP_OP(grp, name) mlx5e_stats_grp_ ## grp ## _ ## name
#define MLX5E_DECLARE_STATS_GRP_OP_NUM_STATS(grp) \
int MLX5E_STATS_GRP_OP(grp, num_stats)(struct mlx5e_priv *priv)
#define MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(grp) \
void MLX5E_STATS_GRP_OP(grp, update_stats)(struct mlx5e_priv *priv)
#define MLX5E_DECLARE_STATS_GRP_OP_FILL_STRS(grp) \
int MLX5E_STATS_GRP_OP(grp, fill_strings)(struct mlx5e_priv *priv, u8 *data, int idx)
#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)
#define MLX5E_DEFINE_STATS_GRP(grp, mask) { \
.get_num_stats = MLX5E_STATS_GRP_OP(grp, num_stats), \
.fill_stats = MLX5E_STATS_GRP_OP(grp, fill_stats), \
.fill_strings = MLX5E_STATS_GRP_OP(grp, fill_strings), \
.update_stats = MLX5E_STATS_GRP_OP(grp, update_stats), \
.update_stats_mask = mask, \
}
unsigned int mlx5e_stats_total_num(struct mlx5e_priv *priv); unsigned int mlx5e_stats_total_num(struct mlx5e_priv *priv);
void mlx5e_stats_update(struct mlx5e_priv *priv); void mlx5e_stats_update(struct mlx5e_priv *priv);
void mlx5e_stats_fill(struct mlx5e_priv *priv, u64 *data, int idx); void mlx5e_stats_fill(struct mlx5e_priv *priv, u64 *data, int idx);
...@@ -345,6 +368,6 @@ struct mlx5e_stats { ...@@ -345,6 +368,6 @@ struct mlx5e_stats {
extern const struct mlx5e_stats_grp mlx5e_nic_stats_grps[]; extern const struct mlx5e_stats_grp mlx5e_nic_stats_grps[];
unsigned int mlx5e_nic_stats_grps_num(struct mlx5e_priv *priv); unsigned int mlx5e_nic_stats_grps_num(struct mlx5e_priv *priv);
void mlx5e_grp_802_3_update_stats(struct mlx5e_priv *priv); MLX5E_DECLARE_STATS_GRP_OP_UPDATE_STATS(802_3);
#endif /* __MLX5_EN_STATS_H__ */ #endif /* __MLX5_EN_STATS_H__ */
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