]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
net/mlx5: E-Switch, Have explicit API to delete fwd rules
authorOr Gerlitz <ogerlitz@mellanox.com>
Thu, 20 Sep 2018 15:09:57 +0000 (17:09 +0200)
committerSaeed Mahameed <saeedm@mellanox.com>
Wed, 17 Oct 2018 21:18:50 +0000 (14:18 -0700)
Be symmetric with the e-switch API to add rules which has a
specific function to add fwd rules which are used as part of
vport mirroring.

This patch doesn't change any functionality.

Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
Reviewed-by: Paul Blakey <paulb@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
drivers/net/ethernet/mellanox/mlx5/core/en_tc.c
drivers/net/ethernet/mellanox/mlx5/core/eswitch.h
drivers/net/ethernet/mellanox/mlx5/core/eswitch_offloads.c

index a4a432f029304fa1176ccde7eb1d90189f74e9ee..7487bdd55f23b4b24a4aae73249700e44aca8047 100644 (file)
@@ -920,7 +920,7 @@ static void mlx5e_tc_del_fdb_flow(struct mlx5e_priv *priv,
        if (flow->flags & MLX5E_TC_FLOW_OFFLOADED) {
                flow->flags &= ~MLX5E_TC_FLOW_OFFLOADED;
                if (attr->mirror_count)
-                       mlx5_eswitch_del_offloaded_rule(esw, flow->rule[1], attr);
+                       mlx5_eswitch_del_fwd_rule(esw, flow->rule[1], attr);
                mlx5_eswitch_del_offloaded_rule(esw, flow->rule[0], attr);
        }
 
@@ -996,7 +996,7 @@ void mlx5e_tc_encap_flows_del(struct mlx5e_priv *priv,
 
                        flow->flags &= ~MLX5E_TC_FLOW_OFFLOADED;
                        if (attr->mirror_count)
-                               mlx5_eswitch_del_offloaded_rule(esw, flow->rule[1], attr);
+                               mlx5_eswitch_del_fwd_rule(esw, flow->rule[1], attr);
                        mlx5_eswitch_del_offloaded_rule(esw, flow->rule[0], attr);
                }
        }
index 1698a322a7c461374eefbbca235a5064345d1ff4..584e735bbad1ca494b1291aa2b6edf4ac78dfc0b 100644 (file)
@@ -231,6 +231,10 @@ void
 mlx5_eswitch_del_offloaded_rule(struct mlx5_eswitch *esw,
                                struct mlx5_flow_handle *rule,
                                struct mlx5_esw_flow_attr *attr);
+void
+mlx5_eswitch_del_fwd_rule(struct mlx5_eswitch *esw,
+                         struct mlx5_flow_handle *rule,
+                         struct mlx5_esw_flow_attr *attr);
 
 struct mlx5_flow_handle *
 mlx5_eswitch_create_vport_rx_rule(struct mlx5_eswitch *esw, int vport,
index 39932dce15cbab4c93e7b9656c9a2ebd1ddc478f..983bb8a80f75b58218734ac1141a25d8645942d3 100644 (file)
@@ -194,6 +194,14 @@ mlx5_eswitch_del_offloaded_rule(struct mlx5_eswitch *esw,
        esw->offloads.num_flows--;
 }
 
+void
+mlx5_eswitch_del_fwd_rule(struct mlx5_eswitch *esw,
+                         struct mlx5_flow_handle *rule,
+                         struct mlx5_esw_flow_attr *attr)
+{
+       mlx5_eswitch_del_offloaded_rule(esw, rule, attr);
+}
+
 static int esw_set_global_vlan_pop(struct mlx5_eswitch *esw, u8 val)
 {
        struct mlx5_eswitch_rep *rep;