MLX5_CAP_GEN_2((esw->dev), ec_vf_vport_base) +\
(last) - 1)
+/* SPF vport numbers are not contiguous, iterate via the spfs array
+ * and look up each vport in the xarray.
+ */
+#define mlx5_esw_for_each_spf_vport(esw, index, vport) \
+ for ((index) = 0; \
+ (index) < (esw)->esw_funcs.num_spfs && \
+ ((vport) = xa_load(&(esw)->vports, \
+ (esw)->esw_funcs.spfs[(index)].vport_num)); \
+ (index)++)
+
#define mlx5_esw_for_each_rep(esw, i, rep) \
xa_for_each(&((esw)->offloads.vport_reps), i, rep)
flows[peer_vport->index] = flow;
}
+ mlx5_esw_for_each_spf_vport(peer_esw, i, peer_vport) {
+ esw_set_peer_miss_rule_source_port(esw, peer_esw, spec,
+ peer_vport->vport);
+
+ flow = mlx5_add_flow_rules(mlx5_eswitch_get_slow_fdb(esw),
+ spec, &flow_act, &dest, 1);
+ if (IS_ERR(flow)) {
+ err = PTR_ERR(flow);
+ goto add_ecpf_flow_err;
+ }
+ flows[peer_vport->index] = flow;
+ }
+
if (mlx5_ecpf_vport_exists(peer_dev)) {
peer_vport = mlx5_eswitch_get_vport(peer_esw, MLX5_VPORT_ECPF);
MLX5_SET(fte_match_set_misc, misc, source_port, MLX5_VPORT_ECPF);
mlx5_del_flow_rules(flows[peer_vport->index]);
}
add_ecpf_flow_err:
-
+ mlx5_esw_for_each_spf_vport(peer_esw, i, peer_vport) {
+ if (!flows[peer_vport->index])
+ continue;
+ mlx5_del_flow_rules(flows[peer_vport->index]);
+ }
if (mlx5_core_is_ecpf_esw_manager(peer_dev) &&
mlx5_esw_host_functions_enabled(peer_dev)) {
peer_vport = mlx5_eswitch_get_vport(peer_esw,
mlx5_del_flow_rules(flows[peer_vport->index]);
}
+ mlx5_esw_for_each_spf_vport(peer_esw, i, peer_vport)
+ mlx5_del_flow_rules(flows[peer_vport->index]);
+
if (mlx5_core_is_ecpf_esw_manager(peer_dev) &&
mlx5_esw_host_functions_enabled(peer_dev)) {
peer_vport = mlx5_eswitch_get_vport(peer_esw,