Commit 377bb764 authored by David S. Miller's avatar David S. Miller

Merge branch 'flow_offload-follow-ups-to-HW-stats-type-patchset'

Jiri Pirko says:

====================
flow_offload: follow-ups to HW stats type patchset

This patchset includes couple of patches in reaction to the discussions
to the original HW stats patchset. The first patch is a fix,
the other two patches are basically cosmetics.
====================
Acked-by: default avatarEdward Cree <ecree@solarflare.com>
Reviewed-by: default avatarJakub Kicinski <kuba@kernel.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 79c57bff a16fa289
...@@ -2879,7 +2879,7 @@ static int parse_tc_nic_actions(struct mlx5e_priv *priv, ...@@ -2879,7 +2879,7 @@ static int parse_tc_nic_actions(struct mlx5e_priv *priv,
return -EINVAL; return -EINVAL;
if (!flow_action_hw_stats_types_check(flow_action, extack, if (!flow_action_hw_stats_types_check(flow_action, extack,
FLOW_ACTION_HW_STATS_TYPE_DELAYED)) FLOW_ACTION_HW_STATS_TYPE_DELAYED_BIT))
return -EOPNOTSUPP; return -EOPNOTSUPP;
attr->flow_tag = MLX5_FS_DEFAULT_FLOW_TAG; attr->flow_tag = MLX5_FS_DEFAULT_FLOW_TAG;
...@@ -3374,7 +3374,7 @@ static int parse_tc_fdb_actions(struct mlx5e_priv *priv, ...@@ -3374,7 +3374,7 @@ static int parse_tc_fdb_actions(struct mlx5e_priv *priv,
return -EINVAL; return -EINVAL;
if (!flow_action_hw_stats_types_check(flow_action, extack, if (!flow_action_hw_stats_types_check(flow_action, extack,
FLOW_ACTION_HW_STATS_TYPE_DELAYED)) FLOW_ACTION_HW_STATS_TYPE_DELAYED_BIT))
return -EOPNOTSUPP; return -EOPNOTSUPP;
flow_action_for_each(i, act, flow_action) { flow_action_for_each(i, act, flow_action) {
......
...@@ -155,11 +155,21 @@ enum flow_action_mangle_base { ...@@ -155,11 +155,21 @@ enum flow_action_mangle_base {
FLOW_ACT_MANGLE_HDR_TYPE_UDP, FLOW_ACT_MANGLE_HDR_TYPE_UDP,
}; };
#define FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE BIT(0) enum flow_action_hw_stats_type_bit {
#define FLOW_ACTION_HW_STATS_TYPE_DELAYED BIT(1) FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE_BIT,
#define FLOW_ACTION_HW_STATS_TYPE_ANY (FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE | \ FLOW_ACTION_HW_STATS_TYPE_DELAYED_BIT,
FLOW_ACTION_HW_STATS_TYPE_DELAYED) };
#define FLOW_ACTION_HW_STATS_TYPE_DISABLED 0
enum flow_action_hw_stats_type {
FLOW_ACTION_HW_STATS_TYPE_DISABLED = 0,
FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE =
BIT(FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE_BIT),
FLOW_ACTION_HW_STATS_TYPE_DELAYED =
BIT(FLOW_ACTION_HW_STATS_TYPE_DELAYED_BIT),
FLOW_ACTION_HW_STATS_TYPE_ANY =
FLOW_ACTION_HW_STATS_TYPE_IMMEDIATE |
FLOW_ACTION_HW_STATS_TYPE_DELAYED,
};
typedef void (*action_destr)(void *priv); typedef void (*action_destr)(void *priv);
...@@ -175,7 +185,7 @@ void flow_action_cookie_destroy(struct flow_action_cookie *cookie); ...@@ -175,7 +185,7 @@ void flow_action_cookie_destroy(struct flow_action_cookie *cookie);
struct flow_action_entry { struct flow_action_entry {
enum flow_action_id id; enum flow_action_id id;
u8 hw_stats_type; enum flow_action_hw_stats_type hw_stats_type;
action_destr destructor; action_destr destructor;
void *destructor_priv; void *destructor_priv;
union { union {
...@@ -290,9 +300,10 @@ flow_action_first_entry_get(const struct flow_action *action) ...@@ -290,9 +300,10 @@ flow_action_first_entry_get(const struct flow_action *action)
} }
static inline bool static inline bool
flow_action_hw_stats_types_check(const struct flow_action *action, __flow_action_hw_stats_types_check(const struct flow_action *action,
struct netlink_ext_ack *extack, struct netlink_ext_ack *extack,
u8 allowed_hw_stats_type) bool check_allow_bit,
enum flow_action_hw_stats_type_bit allow_bit)
{ {
const struct flow_action_entry *action_entry; const struct flow_action_entry *action_entry;
...@@ -301,23 +312,32 @@ flow_action_hw_stats_types_check(const struct flow_action *action, ...@@ -301,23 +312,32 @@ flow_action_hw_stats_types_check(const struct flow_action *action,
if (!flow_action_mixed_hw_stats_types_check(action, extack)) if (!flow_action_mixed_hw_stats_types_check(action, extack))
return false; return false;
action_entry = flow_action_first_entry_get(action); action_entry = flow_action_first_entry_get(action);
if (allowed_hw_stats_type == 0 && if (!check_allow_bit &&
action_entry->hw_stats_type != FLOW_ACTION_HW_STATS_TYPE_ANY) { action_entry->hw_stats_type != FLOW_ACTION_HW_STATS_TYPE_ANY) {
NL_SET_ERR_MSG_MOD(extack, "Driver supports only default HW stats type \"any\""); NL_SET_ERR_MSG_MOD(extack, "Driver supports only default HW stats type \"any\"");
return false; return false;
} else if (allowed_hw_stats_type != 0 && } else if (check_allow_bit &&
action_entry->hw_stats_type != allowed_hw_stats_type) { !(action_entry->hw_stats_type & BIT(allow_bit))) {
NL_SET_ERR_MSG_MOD(extack, "Driver does not support selected HW stats type"); NL_SET_ERR_MSG_MOD(extack, "Driver does not support selected HW stats type");
return false; return false;
} }
return true; return true;
} }
static inline bool
flow_action_hw_stats_types_check(const struct flow_action *action,
struct netlink_ext_ack *extack,
enum flow_action_hw_stats_type_bit allow_bit)
{
return __flow_action_hw_stats_types_check(action, extack,
true, allow_bit);
}
static inline bool static inline bool
flow_action_basic_hw_stats_types_check(const struct flow_action *action, flow_action_basic_hw_stats_types_check(const struct flow_action *action,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
return flow_action_hw_stats_types_check(action, extack, 0); return __flow_action_hw_stats_types_check(action, extack, false, 0);
} }
struct flow_rule { struct flow_rule {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment