net/sched: act_police: allow 'continue' action offload
Offloading police with action TC_ACT_UNSPEC was erroneously disabled even though it was supported by mlx5 matchall offload implementation, which didn't verify the action type but instead assumed that any single police action attached to matchall classifier is a 'continue' action. Lack of action type check made it non-obvious what mlx5 matchall implementation actually supports and caused implementers and reviewers of referenced commits to disallow it as a part of improved validation code. Fixes:b8cd5831c6
("net: flow_offload: add tc police action parameters") Fixes:b50e462bc2
("net/sched: act_police: Add extack messages for offload failure") Signed-off-by: Vlad Buslov <vladbu@nvidia.com> Reviewed-by: Ido Schimmel <idosch@nvidia.com> Tested-by: Ido Schimmel <idosch@nvidia.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e6fa930f73
commit
052f744f44
|
@ -152,6 +152,7 @@ enum flow_action_id {
|
|||
FLOW_ACTION_PIPE,
|
||||
FLOW_ACTION_VLAN_PUSH_ETH,
|
||||
FLOW_ACTION_VLAN_POP_ETH,
|
||||
FLOW_ACTION_CONTINUE,
|
||||
NUM_FLOW_ACTIONS,
|
||||
};
|
||||
|
||||
|
|
|
@ -442,7 +442,7 @@ static int tcf_police_act_to_flow_act(int tc_act, u32 *extval,
|
|||
act_id = FLOW_ACTION_JUMP;
|
||||
*extval = tc_act & TC_ACT_EXT_VAL_MASK;
|
||||
} else if (tc_act == TC_ACT_UNSPEC) {
|
||||
NL_SET_ERR_MSG_MOD(extack, "Offload not supported when conform/exceed action is \"continue\"");
|
||||
act_id = FLOW_ACTION_CONTINUE;
|
||||
} else {
|
||||
NL_SET_ERR_MSG_MOD(extack, "Unsupported conform/exceed action offload");
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue