sample_flow = kzalloc(sizeof(*sample_flow), GFP_KERNEL);
        if (!sample_flow)
                return ERR_PTR(-ENOMEM);
-       esw_attr->sample->sample_flow = sample_flow;
+       sample_attr = attr->sample_attr;
+       sample_attr->sample_flow = sample_flow;
 
        /* Allocate default table per vport, chain and prio. Otherwise, there is
         * only one default table for the same sampler object. Rules with different
        /* Perform the original matches on the default table.
         * Offload all actions except the sample action.
         */
-       esw_attr->sample->sample_default_tbl = default_tbl;
+       sample_attr->sample_default_tbl = default_tbl;
        /* When offloading sample and encap action, if there is no valid
         * neigh data struct, a slow path rule is offloaded first. Source
         * port metadata match is set at that time. A per vport table is
        }
 
        /* Create sampler object. */
-       sample_flow->sampler = sampler_get(tc_psample, esw_attr->sample->rate, default_tbl->id);
+       sample_flow->sampler = sampler_get(tc_psample, sample_attr->rate, default_tbl->id);
        if (IS_ERR(sample_flow->sampler)) {
                err = PTR_ERR(sample_flow->sampler);
                goto err_sampler;
 
        /* Create an id mapping reg_c0 value to sample object. */
        restore_obj.type = MLX5_MAPPED_OBJ_SAMPLE;
-       restore_obj.sample.group_id = esw_attr->sample->group_num;
-       restore_obj.sample.rate = esw_attr->sample->rate;
-       restore_obj.sample.trunc_size = esw_attr->sample->trunc_size;
+       restore_obj.sample.group_id = sample_attr->group_num;
+       restore_obj.sample.rate = sample_attr->rate;
+       restore_obj.sample.trunc_size = sample_attr->trunc_size;
        err = mapping_add(esw->offloads.reg_c0_obj_pool, &restore_obj, &obj_id);
        if (err)
                goto err_obj_id;
-       esw_attr->sample->restore_obj_id = obj_id;
+       sample_attr->restore_obj_id = obj_id;
 
        /* Create sample restore context. */
        sample_flow->restore = sample_restore_get(tc_psample, obj_id);
                err = -ENOMEM;
                goto err_alloc_sample_attr;
        }
-       pre_esw_attr = pre_attr->esw_attr;
        pre_attr->action = MLX5_FLOW_CONTEXT_ACTION_FWD_DEST | MLX5_FLOW_CONTEXT_ACTION_MOD_HDR;
        pre_attr->modify_hdr = sample_flow->restore->modify_hdr;
        pre_attr->flags = MLX5_ESW_ATTR_FLAG_SAMPLE;
        pre_attr->chain = attr->chain;
        pre_attr->prio = attr->prio;
-       pre_esw_attr->sample = sample_attr;
-       pre_esw_attr->sample->sampler_id = sample_flow->sampler->sampler_id;
+       pre_attr->sample_attr = sample_attr;
+       sample_attr->sampler_id = sample_flow->sampler->sampler_id;
+       pre_esw_attr = pre_attr->esw_attr;
        pre_esw_attr->in_mdev = esw_attr->in_mdev;
        pre_esw_attr->in_rep = esw_attr->in_rep;
        sample_flow->pre_rule = mlx5_eswitch_add_offloaded_rule(esw, spec, pre_attr);
                return;
        }
 
-       sample_flow = esw_attr->sample->sample_flow;
+       sample_flow = attr->sample_attr->sample_flow;
        pre_attr = sample_flow->pre_attr;
        memset(pre_attr, 0, sizeof(*pre_attr));
        mlx5_eswitch_del_offloaded_rule(esw, sample_flow->pre_rule, pre_attr);
        mlx5_eswitch_del_offloaded_rule(esw, sample_flow->rule, attr);
 
        sample_restore_put(tc_psample, sample_flow->restore);
-       mapping_remove(esw->offloads.reg_c0_obj_pool, esw_attr->sample->restore_obj_id);
+       mapping_remove(esw->offloads.reg_c0_obj_pool, attr->sample_attr->restore_obj_id);
        sampler_put(tc_psample, sample_flow->sampler);
        tbl_attr.chain = attr->chain;
        tbl_attr.prio = attr->prio;
        tbl_attr.vport_ns = &mlx5_esw_vport_tbl_sample_ns;
        mlx5_esw_vporttbl_put(esw, &tbl_attr);
 
-       kfree(pre_attr->esw_attr->sample);
+       kfree(pre_attr->sample_attr);
        kfree(pre_attr);
        kfree(sample_flow);
 }
 
                else
                        mlx5e_detach_mod_hdr(priv, flow);
        }
+       kfree(attr->sample_attr);
        kvfree(attr->parse_attr);
        kvfree(attr->esw_attr->rx_tun_attr);
 
        if (flow_flag_test(flow, L3_TO_L2_DECAP))
                mlx5e_detach_decap(priv, flow);
 
-       kfree(flow->attr->esw_attr->sample);
        kfree(flow->attr);
 }
 
        struct mlx5_eswitch *esw = priv->mdev->priv.eswitch;
        struct mlx5e_tc_flow_parse_attr *parse_attr;
        struct mlx5e_rep_priv *rpriv = priv->ppriv;
+       struct mlx5e_sample_attr sample_attr = {};
        const struct ip_tunnel_info *info = NULL;
        struct mlx5_flow_attr *attr = flow->attr;
        int ifindexes[MLX5_MAX_FLOW_FWD_VPORTS];
        bool ft_flow = mlx5e_is_ft_flow(flow);
        const struct flow_action_entry *act;
        struct mlx5_esw_flow_attr *esw_attr;
-       struct mlx5e_sample_attr sample = {};
        bool encap = false, decap = false;
        u32 action = attr->action;
        int err, i, if_count = 0;
                                NL_SET_ERR_MSG_MOD(extack, "Sample action with connection tracking is not supported");
                                return -EOPNOTSUPP;
                        }
-                       sample.rate = act->sample.rate;
-                       sample.group_num = act->sample.psample_group->group_num;
+                       sample_attr.rate = act->sample.rate;
+                       sample_attr.group_num = act->sample.psample_group->group_num;
                        if (act->sample.truncate)
-                               sample.trunc_size = act->sample.trunc_size;
+                               sample_attr.trunc_size = act->sample.trunc_size;
                        flow_flag_set(flow, SAMPLE);
                        break;
                default:
         * no errors after parsing.
         */
        if (flow_flag_test(flow, SAMPLE)) {
-               esw_attr->sample = kzalloc(sizeof(*esw_attr->sample), GFP_KERNEL);
-               if (!esw_attr->sample)
+               attr->sample_attr = kzalloc(sizeof(*attr->sample_attr), GFP_KERNEL);
+               if (!attr->sample_attr)
                        return -ENOMEM;
-               *esw_attr->sample = sample;
+               *attr->sample_attr = sample_attr;
        }
 
        return 0;
 
        struct mlx5_fc *counter;
        struct mlx5_modify_hdr *modify_hdr;
        struct mlx5_ct_attr ct_attr;
+       struct mlx5e_sample_attr *sample_attr;
        struct mlx5e_tc_flow_parse_attr *parse_attr;
        u32 chain;
        u16 prio;
 
        } dests[MLX5_MAX_FLOW_FWD_VPORTS];
        struct mlx5_rx_tun_attr *rx_tun_attr;
        struct mlx5_pkt_reformat *decap_pkt_reformat;
-       struct mlx5e_sample_attr *sample;
 };
 
 int mlx5_devlink_eswitch_mode_set(struct devlink *devlink, u16 mode,
 
 static int
 esw_setup_sampler_dest(struct mlx5_flow_destination *dest,
                       struct mlx5_flow_act *flow_act,
-                      struct mlx5_esw_flow_attr *esw_attr,
+                      struct mlx5_flow_attr *attr,
                       int i)
 {
        flow_act->flags |= FLOW_ACT_IGNORE_FLOW_LEVEL;
        dest[i].type = MLX5_FLOW_DESTINATION_TYPE_FLOW_SAMPLER;
-       dest[i].sampler_id = esw_attr->sample->sampler_id;
+       dest[i].sampler_id = attr->sample_attr->sampler_id;
 
        return 0;
 }
                attr->flags |= MLX5_ESW_ATTR_FLAG_SRC_REWRITE;
 
        if (attr->flags & MLX5_ESW_ATTR_FLAG_SAMPLE) {
-               esw_setup_sampler_dest(dest, flow_act, esw_attr, *i);
+               esw_setup_sampler_dest(dest, flow_act, attr, *i);
                (*i)++;
        } else if (attr->dest_ft) {
                esw_setup_ft_dest(dest, flow_act, esw, attr, spec, *i);
        if (flow_act.action & MLX5_FLOW_CONTEXT_ACTION_MOD_HDR)
                flow_act.modify_hdr = attr->modify_hdr;
 
-       /* esw_attr->sample is allocated only when there is a sample action */
-       if (esw_attr->sample && esw_attr->sample->sample_default_tbl) {
-               fdb = esw_attr->sample->sample_default_tbl;
+       /* sample_attr is allocated only when there is a sample action */
+       if (attr->sample_attr && attr->sample_attr->sample_default_tbl) {
+               fdb = attr->sample_attr->sample_default_tbl;
        } else if (split) {
                fwd_attr.chain = attr->chain;
                fwd_attr.prio = attr->prio;