On 2020-04-28 8:24 AM, xiangxia.m....@gmail.com wrote: > From: Tonghao Zhang <xiangxia.m....@gmail.com> > > Introduce the mlx5e_eswitch_rep_uplink_priv helper > to make the codes readable. > > Signed-off-by: Tonghao Zhang <xiangxia.m....@gmail.com> > --- > drivers/net/ethernet/mellanox/mlx5/core/en/tc_ct.c | 4 +-- > drivers/net/ethernet/mellanox/mlx5/core/en_rep.h | 9 +++++++ > drivers/net/ethernet/mellanox/mlx5/core/en_tc.c | 30 > +++++----------------- > 3 files changed, 17 insertions(+), 26 deletions(-) > > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en/tc_ct.c > b/drivers/net/ethernet/mellanox/mlx5/core/en/tc_ct.c > index 16416eaac39e..c5d5e69ff147 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en/tc_ct.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en/tc_ct.c > @@ -100,10 +100,8 @@ struct mlx5_ct_entry { > { > struct mlx5_eswitch *esw = priv->mdev->priv.eswitch; > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > return uplink_priv->ct_priv; > } > > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_rep.h > b/drivers/net/ethernet/mellanox/mlx5/core/en_rep.h > index 6a2337900420..899ffa0872b7 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en_rep.h > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_rep.h > @@ -109,6 +109,15 @@ struct mlx5e_rep_priv *mlx5e_rep_to_rep_priv(struct > mlx5_eswitch_rep *rep) > return rep->rep_data[REP_ETH].priv; > } > > +static inline struct mlx5_rep_uplink_priv * > +mlx5e_eswitch_rep_uplink_priv(struct mlx5_eswitch *esw) > +{ > + struct mlx5e_rep_priv *priv; > + > + priv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > + return &priv->uplink_priv; > +} > + since its in en_rep.h, please use "mlx5e_rep_" prefix. thanks > struct mlx5e_neigh { > struct net_device *dev; > union { > diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > index 64f5c3f3dbb3..696544e2a25b 100644 > --- a/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_tc.c > @@ -1250,12 +1250,10 @@ static void unready_flow_del(struct mlx5e_tc_flow > *flow) > static void add_unready_flow(struct mlx5e_tc_flow *flow) > { > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *rpriv; > struct mlx5_eswitch *esw; > > esw = flow->priv->mdev->priv.eswitch; > - rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > > mutex_lock(&uplink_priv->unready_flows_lock); > unready_flow_add(flow, &uplink_priv->unready_flows); > @@ -1265,12 +1263,10 @@ static void add_unready_flow(struct mlx5e_tc_flow > *flow) > static void remove_unready_flow(struct mlx5e_tc_flow *flow) > { > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *rpriv; > struct mlx5_eswitch *esw; > > esw = flow->priv->mdev->priv.eswitch; > - rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > > mutex_lock(&uplink_priv->unready_flows_lock); > unready_flow_del(flow); > @@ -1888,7 +1884,6 @@ static int mlx5e_get_flow_tunnel_id(struct mlx5e_priv > *priv, > struct mlx5e_tc_mod_hdr_acts *mod_hdr_acts; > struct flow_match_enc_opts enc_opts_match; > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > struct tunnel_match_key tunnel_key; > bool enc_opts_is_dont_care = true; > u32 tun_id, enc_opts_id = 0; > @@ -1897,8 +1892,7 @@ static int mlx5e_get_flow_tunnel_id(struct mlx5e_priv > *priv, > int err; > > esw = priv->mdev->priv.eswitch; > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > > mlx5e_make_tunnel_match_key(f, filter_dev, &tunnel_key); > err = mapping_add(uplink_priv->tunnel_mapping, &tunnel_key, &tun_id); > @@ -1957,13 +1951,11 @@ static int mlx5e_lookup_flow_tunnel_id(struct > mlx5e_priv *priv, > u32 *tun_id) > { > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > struct tunnel_match_key tunnel_key; > struct mlx5_eswitch *esw; > > esw = priv->mdev->priv.eswitch; > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > > mlx5e_make_tunnel_match_key(f, filter_dev, &tunnel_key); > return mapping_find_by_data(uplink_priv->tunnel_mapping, &tunnel_key, > tun_id); > @@ -1974,12 +1966,10 @@ static void mlx5e_put_flow_tunnel_id(struct > mlx5e_tc_flow *flow) > u32 enc_opts_id = flow->tunnel_id & ENC_OPTS_BITS_MASK; > u32 tun_id = flow->tunnel_id >> ENC_OPTS_BITS; > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > struct mlx5_eswitch *esw; > > esw = flow->priv->mdev->priv.eswitch; > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > > if (tun_id) > mapping_remove(uplink_priv->tunnel_mapping, tun_id); > @@ -4841,7 +4831,6 @@ static bool mlx5e_restore_tunnel(struct mlx5e_priv > *priv, struct sk_buff *skb, > struct mlx5_eswitch *esw = priv->mdev->priv.eswitch; > struct flow_dissector_key_enc_opts enc_opts = {}; > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > struct metadata_dst *tun_dst; > struct tunnel_match_key key; > u32 tun_id, enc_opts_id; > @@ -4854,9 +4843,7 @@ static bool mlx5e_restore_tunnel(struct mlx5e_priv > *priv, struct sk_buff *skb, > if (!tun_id) > return true; > > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > - > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > err = mapping_find(uplink_priv->tunnel_mapping, tun_id, &key); > if (err) { > WARN_ON_ONCE(true); > @@ -4920,7 +4907,6 @@ bool mlx5e_tc_rep_update_skb(struct mlx5_cqe64 *cqe, > #if IS_ENABLED(CONFIG_NET_TC_SKB_EXT) > u32 chain = 0, reg_c0, reg_c1, tunnel_id, tuple_id; > struct mlx5_rep_uplink_priv *uplink_priv; > - struct mlx5e_rep_priv *uplink_rpriv; > struct tc_skb_ext *tc_skb_ext; > struct mlx5_eswitch *esw; > struct mlx5e_priv *priv; > @@ -4956,9 +4942,7 @@ bool mlx5e_tc_rep_update_skb(struct mlx5_cqe64 *cqe, > tc_skb_ext->chain = chain; > > tuple_id = reg_c1 & TUPLE_ID_MAX; > - > - uplink_rpriv = mlx5_eswitch_get_uplink_priv(esw, REP_ETH); > - uplink_priv = &uplink_rpriv->uplink_priv; > + uplink_priv = mlx5e_eswitch_rep_uplink_priv(esw); > if (!mlx5e_tc_ct_restore_flow(uplink_priv, skb, tuple_id)) > return false; > } >