mlxsw: spectrum_matchall: Perform priority checks earlier
authorIdo Schimmel <idosch@nvidia.com>
Mon, 29 Mar 2021 10:09:45 +0000 (13:09 +0300)
committerDavid S. Miller <davem@davemloft.net>
Mon, 29 Mar 2021 20:37:25 +0000 (13:37 -0700)
Perform the priority check earlier in the function instead of repeating
it for every action. This fixes a bug that allowed matchall rules with
sample action to be added in front of flower rules on egress.

Fixes: 54d0e963f683 ("mlxsw: spectrum_matchall: Add support for egress sampling")
Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Reviewed-by: Jiri Pirko <jiri@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlxsw/spectrum_matchall.c

index af0a205..07b371c 100644 (file)
@@ -250,32 +250,27 @@ int mlxsw_sp_mall_replace(struct mlxsw_sp *mlxsw_sp,
        mall_entry->priority = f->common.prio;
        mall_entry->ingress = mlxsw_sp_flow_block_is_ingress_bound(block);
 
+       if (flower_prio_valid && mall_entry->ingress &&
+           mall_entry->priority >= flower_min_prio) {
+               NL_SET_ERR_MSG(f->common.extack, "Failed to add behind existing flower rules");
+               err = -EOPNOTSUPP;
+               goto errout;
+       }
+       if (flower_prio_valid && !mall_entry->ingress &&
+           mall_entry->priority <= flower_max_prio) {
+               NL_SET_ERR_MSG(f->common.extack, "Failed to add in front of existing flower rules");
+               err = -EOPNOTSUPP;
+               goto errout;
+       }
+
        act = &f->rule->action.entries[0];
 
        switch (act->id) {
        case FLOW_ACTION_MIRRED:
-               if (flower_prio_valid && mall_entry->ingress &&
-                   mall_entry->priority >= flower_min_prio) {
-                       NL_SET_ERR_MSG(f->common.extack, "Failed to add behind existing flower rules");
-                       err = -EOPNOTSUPP;
-                       goto errout;
-               }
-               if (flower_prio_valid && !mall_entry->ingress &&
-                   mall_entry->priority <= flower_max_prio) {
-                       NL_SET_ERR_MSG(f->common.extack, "Failed to add in front of existing flower rules");
-                       err = -EOPNOTSUPP;
-                       goto errout;
-               }
                mall_entry->type = MLXSW_SP_MALL_ACTION_TYPE_MIRROR;
                mall_entry->mirror.to_dev = act->dev;
                break;
        case FLOW_ACTION_SAMPLE:
-               if (flower_prio_valid &&
-                   mall_entry->priority >= flower_min_prio) {
-                       NL_SET_ERR_MSG(f->common.extack, "Failed to add behind existing flower rules");
-                       err = -EOPNOTSUPP;
-                       goto errout;
-               }
                mall_entry->type = MLXSW_SP_MALL_ACTION_TYPE_SAMPLE;
                mall_entry->sample.params.psample_group = act->sample.psample_group;
                mall_entry->sample.params.truncate = act->sample.truncate;