Merge branch 'net-sched-cls_flower-add-support-for-matching-on-ct_state-reply-flag'
Paul Blakey says: ==================== net/sched: cls_flower: Add support for matching on ct_state reply flag This patchset adds software match support and offload of flower match ct_state reply flag (+/-rpl). The first patch adds the definition for the flag and match to flower. Second patch gives the direction of the connection to the offloading drivers via ct_metadata flow offload action. The last patch does offload of this new ct_state by using the supplied connection's direction. ==================== Link: https://lore.kernel.org/r/1611757967-18236-1-git-send-email-paulb@nvidia.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
commit
810e754c7b
@ -27,6 +27,7 @@
|
||||
#define MLX5_CT_STATE_ESTABLISHED_BIT BIT(1)
|
||||
#define MLX5_CT_STATE_TRK_BIT BIT(2)
|
||||
#define MLX5_CT_STATE_NAT_BIT BIT(3)
|
||||
#define MLX5_CT_STATE_REPLY_BIT BIT(4)
|
||||
|
||||
#define MLX5_FTE_ID_BITS (mlx5e_tc_attr_to_reg_mappings[FTEID_TO_REG].mlen * 8)
|
||||
#define MLX5_FTE_ID_MAX GENMASK(MLX5_FTE_ID_BITS - 1, 0)
|
||||
@ -641,6 +642,7 @@ mlx5_tc_ct_entry_create_mod_hdr(struct mlx5_tc_ct_priv *ct_priv,
|
||||
}
|
||||
|
||||
ct_state |= MLX5_CT_STATE_ESTABLISHED_BIT | MLX5_CT_STATE_TRK_BIT;
|
||||
ct_state |= meta->ct_metadata.orig_dir ? 0 : MLX5_CT_STATE_REPLY_BIT;
|
||||
err = mlx5_tc_ct_entry_set_registers(ct_priv, &mod_acts,
|
||||
ct_state,
|
||||
meta->ct_metadata.mark,
|
||||
@ -1086,8 +1088,8 @@ mlx5_tc_ct_match_add(struct mlx5_tc_ct_priv *priv,
|
||||
struct netlink_ext_ack *extack)
|
||||
{
|
||||
struct flow_rule *rule = flow_cls_offload_flow_rule(f);
|
||||
bool trk, est, untrk, unest, new, rpl, unrpl;
|
||||
struct flow_dissector_key_ct *mask, *key;
|
||||
bool trk, est, untrk, unest, new;
|
||||
u32 ctstate = 0, ctstate_mask = 0;
|
||||
u16 ct_state_on, ct_state_off;
|
||||
u16 ct_state, ct_state_mask;
|
||||
@ -1113,9 +1115,10 @@ mlx5_tc_ct_match_add(struct mlx5_tc_ct_priv *priv,
|
||||
|
||||
if (ct_state_mask & ~(TCA_FLOWER_KEY_CT_FLAGS_TRACKED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_NEW)) {
|
||||
TCA_FLOWER_KEY_CT_FLAGS_NEW |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_REPLY)) {
|
||||
NL_SET_ERR_MSG_MOD(extack,
|
||||
"only ct_state trk, est and new are supported for offload");
|
||||
"only ct_state trk, est, new and rpl are supported for offload");
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
@ -1124,13 +1127,17 @@ mlx5_tc_ct_match_add(struct mlx5_tc_ct_priv *priv,
|
||||
trk = ct_state_on & TCA_FLOWER_KEY_CT_FLAGS_TRACKED;
|
||||
new = ct_state_on & TCA_FLOWER_KEY_CT_FLAGS_NEW;
|
||||
est = ct_state_on & TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED;
|
||||
rpl = ct_state_on & TCA_FLOWER_KEY_CT_FLAGS_REPLY;
|
||||
untrk = ct_state_off & TCA_FLOWER_KEY_CT_FLAGS_TRACKED;
|
||||
unest = ct_state_off & TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED;
|
||||
unrpl = ct_state_off & TCA_FLOWER_KEY_CT_FLAGS_REPLY;
|
||||
|
||||
ctstate |= trk ? MLX5_CT_STATE_TRK_BIT : 0;
|
||||
ctstate |= est ? MLX5_CT_STATE_ESTABLISHED_BIT : 0;
|
||||
ctstate |= rpl ? MLX5_CT_STATE_REPLY_BIT : 0;
|
||||
ctstate_mask |= (untrk || trk) ? MLX5_CT_STATE_TRK_BIT : 0;
|
||||
ctstate_mask |= (unest || est) ? MLX5_CT_STATE_ESTABLISHED_BIT : 0;
|
||||
ctstate_mask |= (unrpl || rpl) ? MLX5_CT_STATE_REPLY_BIT : 0;
|
||||
|
||||
if (new) {
|
||||
NL_SET_ERR_MSG_MOD(extack,
|
||||
|
@ -245,6 +245,7 @@ struct flow_action_entry {
|
||||
unsigned long cookie;
|
||||
u32 mark;
|
||||
u32 labels[4];
|
||||
bool orig_dir;
|
||||
} ct_metadata;
|
||||
struct { /* FLOW_ACTION_MPLS_PUSH */
|
||||
u32 label;
|
||||
|
@ -592,6 +592,7 @@ enum {
|
||||
TCA_FLOWER_KEY_CT_FLAGS_RELATED = 1 << 2, /* Related to an established connection. */
|
||||
TCA_FLOWER_KEY_CT_FLAGS_TRACKED = 1 << 3, /* Conntrack has occurred. */
|
||||
TCA_FLOWER_KEY_CT_FLAGS_INVALID = 1 << 4, /* Conntrack is invalid. */
|
||||
TCA_FLOWER_KEY_CT_FLAGS_REPLY = 1 << 5, /* Packet is in the reply direction. */
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -183,6 +183,7 @@ static void tcf_ct_flow_table_add_action_meta(struct nf_conn *ct,
|
||||
IP_CT_ESTABLISHED_REPLY;
|
||||
/* aligns with the CT reference on the SKB nf_ct_set */
|
||||
entry->ct_metadata.cookie = (unsigned long)ct | ctinfo;
|
||||
entry->ct_metadata.orig_dir = dir == IP_CT_DIR_ORIGINAL;
|
||||
|
||||
act_ct_labels = entry->ct_metadata.labels;
|
||||
ct_labels = nf_ct_labels_find(ct);
|
||||
|
@ -291,9 +291,11 @@ static u16 fl_ct_info_to_flower_map[] = {
|
||||
[IP_CT_RELATED] = TCA_FLOWER_KEY_CT_FLAGS_TRACKED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_RELATED,
|
||||
[IP_CT_ESTABLISHED_REPLY] = TCA_FLOWER_KEY_CT_FLAGS_TRACKED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED,
|
||||
TCA_FLOWER_KEY_CT_FLAGS_ESTABLISHED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_REPLY,
|
||||
[IP_CT_RELATED_REPLY] = TCA_FLOWER_KEY_CT_FLAGS_TRACKED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_RELATED,
|
||||
TCA_FLOWER_KEY_CT_FLAGS_RELATED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_REPLY,
|
||||
[IP_CT_NEW] = TCA_FLOWER_KEY_CT_FLAGS_TRACKED |
|
||||
TCA_FLOWER_KEY_CT_FLAGS_NEW,
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user