net: flow_offload: rename tc_cls_flower_offload to flow_cls_offload

And any other existing fields in this structure that refer to tc.
Specifically:

* tc_cls_flower_offload_flow_rule() to flow_cls_offload_flow_rule().
* TC_CLSFLOWER_* to FLOW_CLS_*.
* tc_cls_common_offload to tc_cls_common_offload.

Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Pablo Neira Ayuso 2019-07-09 22:55:49 +02:00 committed by David S. Miller
parent 0d4fd02e71
commit f9e30088d2
32 changed files with 254 additions and 254 deletions

View File

@ -170,10 +170,10 @@ static int bnxt_tc_parse_actions(struct bnxt *bp,
} }
static int bnxt_tc_parse_flow(struct bnxt *bp, static int bnxt_tc_parse_flow(struct bnxt *bp,
struct tc_cls_flower_offload *tc_flow_cmd, struct flow_cls_offload *tc_flow_cmd,
struct bnxt_tc_flow *flow) struct bnxt_tc_flow *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(tc_flow_cmd); struct flow_rule *rule = flow_cls_offload_flow_rule(tc_flow_cmd);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
/* KEY_CONTROL and KEY_BASIC are needed for forming a meaningful key */ /* KEY_CONTROL and KEY_BASIC are needed for forming a meaningful key */
@ -1262,7 +1262,7 @@ static void bnxt_tc_set_src_fid(struct bnxt *bp, struct bnxt_tc_flow *flow,
* The hash-tables are already protected by the rhashtable API. * The hash-tables are already protected by the rhashtable API.
*/ */
static int bnxt_tc_add_flow(struct bnxt *bp, u16 src_fid, static int bnxt_tc_add_flow(struct bnxt *bp, u16 src_fid,
struct tc_cls_flower_offload *tc_flow_cmd) struct flow_cls_offload *tc_flow_cmd)
{ {
struct bnxt_tc_flow_node *new_node, *old_node; struct bnxt_tc_flow_node *new_node, *old_node;
struct bnxt_tc_info *tc_info = bp->tc_info; struct bnxt_tc_info *tc_info = bp->tc_info;
@ -1348,7 +1348,7 @@ static int bnxt_tc_add_flow(struct bnxt *bp, u16 src_fid,
} }
static int bnxt_tc_del_flow(struct bnxt *bp, static int bnxt_tc_del_flow(struct bnxt *bp,
struct tc_cls_flower_offload *tc_flow_cmd) struct flow_cls_offload *tc_flow_cmd)
{ {
struct bnxt_tc_info *tc_info = bp->tc_info; struct bnxt_tc_info *tc_info = bp->tc_info;
struct bnxt_tc_flow_node *flow_node; struct bnxt_tc_flow_node *flow_node;
@ -1363,7 +1363,7 @@ static int bnxt_tc_del_flow(struct bnxt *bp,
} }
static int bnxt_tc_get_flow_stats(struct bnxt *bp, static int bnxt_tc_get_flow_stats(struct bnxt *bp,
struct tc_cls_flower_offload *tc_flow_cmd) struct flow_cls_offload *tc_flow_cmd)
{ {
struct bnxt_tc_flow_stats stats, *curr_stats, *prev_stats; struct bnxt_tc_flow_stats stats, *curr_stats, *prev_stats;
struct bnxt_tc_info *tc_info = bp->tc_info; struct bnxt_tc_info *tc_info = bp->tc_info;
@ -1585,14 +1585,14 @@ void bnxt_tc_flow_stats_work(struct bnxt *bp)
} }
int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid, int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return bnxt_tc_add_flow(bp, src_fid, cls_flower); return bnxt_tc_add_flow(bp, src_fid, cls_flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return bnxt_tc_del_flow(bp, cls_flower); return bnxt_tc_del_flow(bp, cls_flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return bnxt_tc_get_flow_stats(bp, cls_flower); return bnxt_tc_get_flow_stats(bp, cls_flower);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -196,7 +196,7 @@ struct bnxt_tc_flow_node {
}; };
int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid, int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid,
struct tc_cls_flower_offload *cls_flower); struct flow_cls_offload *cls_flower);
int bnxt_init_tc(struct bnxt *bp); int bnxt_init_tc(struct bnxt *bp);
void bnxt_shutdown_tc(struct bnxt *bp); void bnxt_shutdown_tc(struct bnxt *bp);
void bnxt_tc_flow_stats_work(struct bnxt *bp); void bnxt_tc_flow_stats_work(struct bnxt *bp);
@ -209,7 +209,7 @@ static inline bool bnxt_tc_flower_enabled(struct bnxt *bp)
#else /* CONFIG_BNXT_FLOWER_OFFLOAD */ #else /* CONFIG_BNXT_FLOWER_OFFLOAD */
static inline int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid, static inline int bnxt_tc_setup_flower(struct bnxt *bp, u16 src_fid,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
return -EOPNOTSUPP; return -EOPNOTSUPP;
} }

View File

@ -3135,14 +3135,14 @@ static int cxgb_set_tx_maxrate(struct net_device *dev, int index, u32 rate)
} }
static int cxgb_setup_tc_flower(struct net_device *dev, static int cxgb_setup_tc_flower(struct net_device *dev,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return cxgb4_tc_flower_replace(dev, cls_flower); return cxgb4_tc_flower_replace(dev, cls_flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return cxgb4_tc_flower_destroy(dev, cls_flower); return cxgb4_tc_flower_destroy(dev, cls_flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return cxgb4_tc_flower_stats(dev, cls_flower); return cxgb4_tc_flower_stats(dev, cls_flower);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -80,10 +80,10 @@ static struct ch_tc_flower_entry *ch_flower_lookup(struct adapter *adap,
} }
static void cxgb4_process_flow_match(struct net_device *dev, static void cxgb4_process_flow_match(struct net_device *dev,
struct tc_cls_flower_offload *cls, struct flow_cls_offload *cls,
struct ch_filter_specification *fs) struct ch_filter_specification *fs)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(cls); struct flow_rule *rule = flow_cls_offload_flow_rule(cls);
u16 addr_type = 0; u16 addr_type = 0;
if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_CONTROL)) { if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_CONTROL)) {
@ -223,9 +223,9 @@ static void cxgb4_process_flow_match(struct net_device *dev,
} }
static int cxgb4_validate_flow_match(struct net_device *dev, static int cxgb4_validate_flow_match(struct net_device *dev,
struct tc_cls_flower_offload *cls) struct flow_cls_offload *cls)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(cls); struct flow_rule *rule = flow_cls_offload_flow_rule(cls);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
u16 ethtype_mask = 0; u16 ethtype_mask = 0;
u16 ethtype_key = 0; u16 ethtype_key = 0;
@ -378,10 +378,10 @@ static void process_pedit_field(struct ch_filter_specification *fs, u32 val,
} }
static void cxgb4_process_flow_actions(struct net_device *in, static void cxgb4_process_flow_actions(struct net_device *in,
struct tc_cls_flower_offload *cls, struct flow_cls_offload *cls,
struct ch_filter_specification *fs) struct ch_filter_specification *fs)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(cls); struct flow_rule *rule = flow_cls_offload_flow_rule(cls);
struct flow_action_entry *act; struct flow_action_entry *act;
int i; int i;
@ -544,9 +544,9 @@ static bool valid_pedit_action(struct net_device *dev,
} }
static int cxgb4_validate_flow_actions(struct net_device *dev, static int cxgb4_validate_flow_actions(struct net_device *dev,
struct tc_cls_flower_offload *cls) struct flow_cls_offload *cls)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(cls); struct flow_rule *rule = flow_cls_offload_flow_rule(cls);
struct flow_action_entry *act; struct flow_action_entry *act;
bool act_redir = false; bool act_redir = false;
bool act_pedit = false; bool act_pedit = false;
@ -633,7 +633,7 @@ static int cxgb4_validate_flow_actions(struct net_device *dev,
} }
int cxgb4_tc_flower_replace(struct net_device *dev, int cxgb4_tc_flower_replace(struct net_device *dev,
struct tc_cls_flower_offload *cls) struct flow_cls_offload *cls)
{ {
struct adapter *adap = netdev2adap(dev); struct adapter *adap = netdev2adap(dev);
struct ch_tc_flower_entry *ch_flower; struct ch_tc_flower_entry *ch_flower;
@ -709,7 +709,7 @@ int cxgb4_tc_flower_replace(struct net_device *dev,
} }
int cxgb4_tc_flower_destroy(struct net_device *dev, int cxgb4_tc_flower_destroy(struct net_device *dev,
struct tc_cls_flower_offload *cls) struct flow_cls_offload *cls)
{ {
struct adapter *adap = netdev2adap(dev); struct adapter *adap = netdev2adap(dev);
struct ch_tc_flower_entry *ch_flower; struct ch_tc_flower_entry *ch_flower;
@ -783,7 +783,7 @@ static void ch_flower_stats_cb(struct timer_list *t)
} }
int cxgb4_tc_flower_stats(struct net_device *dev, int cxgb4_tc_flower_stats(struct net_device *dev,
struct tc_cls_flower_offload *cls) struct flow_cls_offload *cls)
{ {
struct adapter *adap = netdev2adap(dev); struct adapter *adap = netdev2adap(dev);
struct ch_tc_flower_stats *ofld_stats; struct ch_tc_flower_stats *ofld_stats;

View File

@ -109,11 +109,11 @@ struct ch_tc_pedit_fields {
#define PEDIT_UDP_SPORT_DPORT 0x0 #define PEDIT_UDP_SPORT_DPORT 0x0
int cxgb4_tc_flower_replace(struct net_device *dev, int cxgb4_tc_flower_replace(struct net_device *dev,
struct tc_cls_flower_offload *cls); struct flow_cls_offload *cls);
int cxgb4_tc_flower_destroy(struct net_device *dev, int cxgb4_tc_flower_destroy(struct net_device *dev,
struct tc_cls_flower_offload *cls); struct flow_cls_offload *cls);
int cxgb4_tc_flower_stats(struct net_device *dev, int cxgb4_tc_flower_stats(struct net_device *dev,
struct tc_cls_flower_offload *cls); struct flow_cls_offload *cls);
int cxgb4_init_tc_flower(struct adapter *adap); int cxgb4_init_tc_flower(struct adapter *adap);
void cxgb4_cleanup_tc_flower(struct adapter *adap); void cxgb4_cleanup_tc_flower(struct adapter *adap);

View File

@ -7759,15 +7759,15 @@ int i40e_add_del_cloud_filter_big_buf(struct i40e_vsi *vsi,
/** /**
* i40e_parse_cls_flower - Parse tc flower filters provided by kernel * i40e_parse_cls_flower - Parse tc flower filters provided by kernel
* @vsi: Pointer to VSI * @vsi: Pointer to VSI
* @cls_flower: Pointer to struct tc_cls_flower_offload * @cls_flower: Pointer to struct flow_cls_offload
* @filter: Pointer to cloud filter structure * @filter: Pointer to cloud filter structure
* *
**/ **/
static int i40e_parse_cls_flower(struct i40e_vsi *vsi, static int i40e_parse_cls_flower(struct i40e_vsi *vsi,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct i40e_cloud_filter *filter) struct i40e_cloud_filter *filter)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
u16 n_proto_mask = 0, n_proto_key = 0, addr_type = 0; u16 n_proto_mask = 0, n_proto_key = 0, addr_type = 0;
struct i40e_pf *pf = vsi->back; struct i40e_pf *pf = vsi->back;
@ -8001,11 +8001,11 @@ static int i40e_handle_tclass(struct i40e_vsi *vsi, u32 tc,
/** /**
* i40e_configure_clsflower - Configure tc flower filters * i40e_configure_clsflower - Configure tc flower filters
* @vsi: Pointer to VSI * @vsi: Pointer to VSI
* @cls_flower: Pointer to struct tc_cls_flower_offload * @cls_flower: Pointer to struct flow_cls_offload
* *
**/ **/
static int i40e_configure_clsflower(struct i40e_vsi *vsi, static int i40e_configure_clsflower(struct i40e_vsi *vsi,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
int tc = tc_classid_to_hwtc(vsi->netdev, cls_flower->classid); int tc = tc_classid_to_hwtc(vsi->netdev, cls_flower->classid);
struct i40e_cloud_filter *filter = NULL; struct i40e_cloud_filter *filter = NULL;
@ -8097,11 +8097,11 @@ static struct i40e_cloud_filter *i40e_find_cloud_filter(struct i40e_vsi *vsi,
/** /**
* i40e_delete_clsflower - Remove tc flower filters * i40e_delete_clsflower - Remove tc flower filters
* @vsi: Pointer to VSI * @vsi: Pointer to VSI
* @cls_flower: Pointer to struct tc_cls_flower_offload * @cls_flower: Pointer to struct flow_cls_offload
* *
**/ **/
static int i40e_delete_clsflower(struct i40e_vsi *vsi, static int i40e_delete_clsflower(struct i40e_vsi *vsi,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
struct i40e_cloud_filter *filter = NULL; struct i40e_cloud_filter *filter = NULL;
struct i40e_pf *pf = vsi->back; struct i40e_pf *pf = vsi->back;
@ -8144,16 +8144,16 @@ static int i40e_delete_clsflower(struct i40e_vsi *vsi,
* @type_data: offload data * @type_data: offload data
**/ **/
static int i40e_setup_tc_cls_flower(struct i40e_netdev_priv *np, static int i40e_setup_tc_cls_flower(struct i40e_netdev_priv *np,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
struct i40e_vsi *vsi = np->vsi; struct i40e_vsi *vsi = np->vsi;
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return i40e_configure_clsflower(vsi, cls_flower); return i40e_configure_clsflower(vsi, cls_flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return i40e_delete_clsflower(vsi, cls_flower); return i40e_delete_clsflower(vsi, cls_flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return -EOPNOTSUPP; return -EOPNOTSUPP;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -2699,14 +2699,14 @@ static int __iavf_setup_tc(struct net_device *netdev, void *type_data)
/** /**
* iavf_parse_cls_flower - Parse tc flower filters provided by kernel * iavf_parse_cls_flower - Parse tc flower filters provided by kernel
* @adapter: board private structure * @adapter: board private structure
* @cls_flower: pointer to struct tc_cls_flower_offload * @cls_flower: pointer to struct flow_cls_offload
* @filter: pointer to cloud filter structure * @filter: pointer to cloud filter structure
*/ */
static int iavf_parse_cls_flower(struct iavf_adapter *adapter, static int iavf_parse_cls_flower(struct iavf_adapter *adapter,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct iavf_cloud_filter *filter) struct iavf_cloud_filter *filter)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
u16 n_proto_mask = 0; u16 n_proto_mask = 0;
u16 n_proto_key = 0; u16 n_proto_key = 0;
@ -2971,10 +2971,10 @@ static int iavf_handle_tclass(struct iavf_adapter *adapter, u32 tc,
/** /**
* iavf_configure_clsflower - Add tc flower filters * iavf_configure_clsflower - Add tc flower filters
* @adapter: board private structure * @adapter: board private structure
* @cls_flower: Pointer to struct tc_cls_flower_offload * @cls_flower: Pointer to struct flow_cls_offload
*/ */
static int iavf_configure_clsflower(struct iavf_adapter *adapter, static int iavf_configure_clsflower(struct iavf_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
int tc = tc_classid_to_hwtc(adapter->netdev, cls_flower->classid); int tc = tc_classid_to_hwtc(adapter->netdev, cls_flower->classid);
struct iavf_cloud_filter *filter = NULL; struct iavf_cloud_filter *filter = NULL;
@ -3050,10 +3050,10 @@ static struct iavf_cloud_filter *iavf_find_cf(struct iavf_adapter *adapter,
/** /**
* iavf_delete_clsflower - Remove tc flower filters * iavf_delete_clsflower - Remove tc flower filters
* @adapter: board private structure * @adapter: board private structure
* @cls_flower: Pointer to struct tc_cls_flower_offload * @cls_flower: Pointer to struct flow_cls_offload
*/ */
static int iavf_delete_clsflower(struct iavf_adapter *adapter, static int iavf_delete_clsflower(struct iavf_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
struct iavf_cloud_filter *filter = NULL; struct iavf_cloud_filter *filter = NULL;
int err = 0; int err = 0;
@ -3077,17 +3077,17 @@ static int iavf_delete_clsflower(struct iavf_adapter *adapter,
* @type_data: offload data * @type_data: offload data
*/ */
static int iavf_setup_tc_cls_flower(struct iavf_adapter *adapter, static int iavf_setup_tc_cls_flower(struct iavf_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
if (cls_flower->common.chain_index) if (cls_flower->common.chain_index)
return -EOPNOTSUPP; return -EOPNOTSUPP;
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return iavf_configure_clsflower(adapter, cls_flower); return iavf_configure_clsflower(adapter, cls_flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return iavf_delete_clsflower(adapter, cls_flower); return iavf_delete_clsflower(adapter, cls_flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return -EOPNOTSUPP; return -EOPNOTSUPP;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -2578,11 +2578,11 @@ static int igb_offload_cbs(struct igb_adapter *adapter,
#define VLAN_PRIO_FULL_MASK (0x07) #define VLAN_PRIO_FULL_MASK (0x07)
static int igb_parse_cls_flower(struct igb_adapter *adapter, static int igb_parse_cls_flower(struct igb_adapter *adapter,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
int traffic_class, int traffic_class,
struct igb_nfc_filter *input) struct igb_nfc_filter *input)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
@ -2660,7 +2660,7 @@ static int igb_parse_cls_flower(struct igb_adapter *adapter,
} }
static int igb_configure_clsflower(struct igb_adapter *adapter, static int igb_configure_clsflower(struct igb_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
struct netlink_ext_ack *extack = cls_flower->common.extack; struct netlink_ext_ack *extack = cls_flower->common.extack;
struct igb_nfc_filter *filter, *f; struct igb_nfc_filter *filter, *f;
@ -2722,7 +2722,7 @@ static int igb_configure_clsflower(struct igb_adapter *adapter,
} }
static int igb_delete_clsflower(struct igb_adapter *adapter, static int igb_delete_clsflower(struct igb_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
struct igb_nfc_filter *filter; struct igb_nfc_filter *filter;
int err; int err;
@ -2752,14 +2752,14 @@ static int igb_delete_clsflower(struct igb_adapter *adapter,
} }
static int igb_setup_tc_cls_flower(struct igb_adapter *adapter, static int igb_setup_tc_cls_flower(struct igb_adapter *adapter,
struct tc_cls_flower_offload *cls_flower) struct flow_cls_offload *cls_flower)
{ {
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return igb_configure_clsflower(adapter, cls_flower); return igb_configure_clsflower(adapter, cls_flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return igb_delete_clsflower(adapter, cls_flower); return igb_delete_clsflower(adapter, cls_flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return -EOPNOTSUPP; return -EOPNOTSUPP;
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -452,7 +452,7 @@ int mlx5e_tc_tun_init_encap_attr(struct net_device *tunnel_dev,
int mlx5e_tc_tun_parse(struct net_device *filter_dev, int mlx5e_tc_tun_parse(struct net_device *filter_dev,
struct mlx5e_priv *priv, struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v, u8 *match_level) void *headers_v, u8 *match_level)
{ {
@ -489,11 +489,11 @@ int mlx5e_tc_tun_parse(struct net_device *filter_dev,
int mlx5e_tc_tun_parse_udp_ports(struct mlx5e_priv *priv, int mlx5e_tc_tun_parse_udp_ports(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct flow_match_ports enc_ports; struct flow_match_ports enc_ports;

View File

@ -33,12 +33,12 @@ struct mlx5e_tc_tunnel {
struct mlx5e_encap_entry *e); struct mlx5e_encap_entry *e);
int (*parse_udp_ports)(struct mlx5e_priv *priv, int (*parse_udp_ports)(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v); void *headers_v);
int (*parse_tunnel)(struct mlx5e_priv *priv, int (*parse_tunnel)(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v); void *headers_v);
}; };
@ -68,13 +68,13 @@ bool mlx5e_tc_tun_device_to_offload(struct mlx5e_priv *priv,
int mlx5e_tc_tun_parse(struct net_device *filter_dev, int mlx5e_tc_tun_parse(struct net_device *filter_dev,
struct mlx5e_priv *priv, struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v, u8 *match_level); void *headers_v, u8 *match_level);
int mlx5e_tc_tun_parse_udp_ports(struct mlx5e_priv *priv, int mlx5e_tc_tun_parse_udp_ports(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v); void *headers_v);

View File

@ -20,9 +20,9 @@ static int mlx5e_tc_tun_calc_hlen_geneve(struct mlx5e_encap_entry *e)
} }
static int mlx5e_tc_tun_check_udp_dport_geneve(struct mlx5e_priv *priv, static int mlx5e_tc_tun_check_udp_dport_geneve(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct flow_match_ports enc_ports; struct flow_match_ports enc_ports;
@ -48,7 +48,7 @@ static int mlx5e_tc_tun_check_udp_dport_geneve(struct mlx5e_priv *priv,
static int mlx5e_tc_tun_parse_udp_ports_geneve(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_udp_ports_geneve(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {
@ -122,9 +122,9 @@ static int mlx5e_gen_ip_tunnel_header_geneve(char buf[],
static int mlx5e_tc_tun_parse_geneve_vni(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_geneve_vni(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct flow_match_enc_keyid enc_keyid; struct flow_match_enc_keyid enc_keyid;
void *misc_c, *misc_v; void *misc_c, *misc_v;
@ -154,11 +154,11 @@ static int mlx5e_tc_tun_parse_geneve_vni(struct mlx5e_priv *priv,
static int mlx5e_tc_tun_parse_geneve_options(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_geneve_options(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
u8 max_tlv_option_data_len = MLX5_CAP_GEN(priv->mdev, max_geneve_tlv_option_data_len); u8 max_tlv_option_data_len = MLX5_CAP_GEN(priv->mdev, max_geneve_tlv_option_data_len);
u8 max_tlv_options = MLX5_CAP_GEN(priv->mdev, max_geneve_tlv_options); u8 max_tlv_options = MLX5_CAP_GEN(priv->mdev, max_geneve_tlv_options);
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
void *misc_c, *misc_v, *misc_3_c, *misc_3_v; void *misc_c, *misc_v, *misc_3_c, *misc_3_v;
struct geneve_opt *option_key, *option_mask; struct geneve_opt *option_key, *option_mask;
@ -277,7 +277,7 @@ static int mlx5e_tc_tun_parse_geneve_options(struct mlx5e_priv *priv,
static int mlx5e_tc_tun_parse_geneve_params(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_geneve_params(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
void *misc_c = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, misc_parameters); void *misc_c = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, misc_parameters);
void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, misc_parameters); void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, misc_parameters);
@ -306,7 +306,7 @@ static int mlx5e_tc_tun_parse_geneve_params(struct mlx5e_priv *priv,
static int mlx5e_tc_tun_parse_geneve(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_geneve(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {

View File

@ -54,13 +54,13 @@ static int mlx5e_gen_ip_tunnel_header_gretap(char buf[],
static int mlx5e_tc_tun_parse_gretap(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_gretap(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {
void *misc_c = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, misc_parameters); void *misc_c = MLX5_ADDR_OF(fte_match_param, spec->match_criteria, misc_parameters);
void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, misc_parameters); void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, misc_parameters);
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
MLX5_SET_TO_ONES(fte_match_set_lyr_2_4, headers_c, ip_protocol); MLX5_SET_TO_ONES(fte_match_set_lyr_2_4, headers_c, ip_protocol);
MLX5_SET(fte_match_set_lyr_2_4, headers_v, ip_protocol, IPPROTO_GRE); MLX5_SET(fte_match_set_lyr_2_4, headers_v, ip_protocol, IPPROTO_GRE);

View File

@ -16,9 +16,9 @@ static int mlx5e_tc_tun_calc_hlen_vxlan(struct mlx5e_encap_entry *e)
} }
static int mlx5e_tc_tun_check_udp_dport_vxlan(struct mlx5e_priv *priv, static int mlx5e_tc_tun_check_udp_dport_vxlan(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct flow_match_ports enc_ports; struct flow_match_ports enc_ports;
@ -44,7 +44,7 @@ static int mlx5e_tc_tun_check_udp_dport_vxlan(struct mlx5e_priv *priv,
static int mlx5e_tc_tun_parse_udp_ports_vxlan(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_udp_ports_vxlan(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {
@ -100,11 +100,11 @@ static int mlx5e_gen_ip_tunnel_header_vxlan(char buf[],
static int mlx5e_tc_tun_parse_vxlan(struct mlx5e_priv *priv, static int mlx5e_tc_tun_parse_vxlan(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
void *headers_c, void *headers_c,
void *headers_v) void *headers_v)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct flow_match_enc_keyid enc_keyid; struct flow_match_enc_keyid enc_keyid;
void *misc_c, *misc_v; void *misc_c, *misc_v;

View File

@ -3426,17 +3426,17 @@ static int mlx5e_setup_tc_mqprio(struct net_device *netdev,
#ifdef CONFIG_MLX5_ESWITCH #ifdef CONFIG_MLX5_ESWITCH
static int mlx5e_setup_tc_cls_flower(struct mlx5e_priv *priv, static int mlx5e_setup_tc_cls_flower(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *cls_flower, struct flow_cls_offload *cls_flower,
int flags) int flags)
{ {
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return mlx5e_configure_flower(priv->netdev, priv, cls_flower, return mlx5e_configure_flower(priv->netdev, priv, cls_flower,
flags); flags);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return mlx5e_delete_flower(priv->netdev, priv, cls_flower, return mlx5e_delete_flower(priv->netdev, priv, cls_flower,
flags); flags);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return mlx5e_stats_flower(priv->netdev, priv, cls_flower, return mlx5e_stats_flower(priv->netdev, priv, cls_flower,
flags); flags);
default: default:

View File

@ -656,7 +656,7 @@ static void mlx5e_rep_indr_clean_block_privs(struct mlx5e_rep_priv *rpriv)
static int static int
mlx5e_rep_indr_offload(struct net_device *netdev, mlx5e_rep_indr_offload(struct net_device *netdev,
struct tc_cls_flower_offload *flower, struct flow_cls_offload *flower,
struct mlx5e_rep_indr_block_priv *indr_priv) struct mlx5e_rep_indr_block_priv *indr_priv)
{ {
struct mlx5e_priv *priv = netdev_priv(indr_priv->rpriv->netdev); struct mlx5e_priv *priv = netdev_priv(indr_priv->rpriv->netdev);
@ -664,13 +664,13 @@ mlx5e_rep_indr_offload(struct net_device *netdev,
int err = 0; int err = 0;
switch (flower->command) { switch (flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
err = mlx5e_configure_flower(netdev, priv, flower, flags); err = mlx5e_configure_flower(netdev, priv, flower, flags);
break; break;
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
err = mlx5e_delete_flower(netdev, priv, flower, flags); err = mlx5e_delete_flower(netdev, priv, flower, flags);
break; break;
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
err = mlx5e_stats_flower(netdev, priv, flower, flags); err = mlx5e_stats_flower(netdev, priv, flower, flags);
break; break;
default: default:
@ -1144,16 +1144,16 @@ static int mlx5e_rep_close(struct net_device *dev)
static int static int
mlx5e_rep_setup_tc_cls_flower(struct mlx5e_priv *priv, mlx5e_rep_setup_tc_cls_flower(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *cls_flower, int flags) struct flow_cls_offload *cls_flower, int flags)
{ {
switch (cls_flower->command) { switch (cls_flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return mlx5e_configure_flower(priv->netdev, priv, cls_flower, return mlx5e_configure_flower(priv->netdev, priv, cls_flower,
flags); flags);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return mlx5e_delete_flower(priv->netdev, priv, cls_flower, return mlx5e_delete_flower(priv->netdev, priv, cls_flower,
flags); flags);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return mlx5e_stats_flower(priv->netdev, priv, cls_flower, return mlx5e_stats_flower(priv->netdev, priv, cls_flower,
flags); flags);
default: default:

View File

@ -1350,7 +1350,7 @@ static void mlx5e_tc_del_flow(struct mlx5e_priv *priv,
static int parse_tunnel_attr(struct mlx5e_priv *priv, static int parse_tunnel_attr(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct net_device *filter_dev, u8 *match_level) struct net_device *filter_dev, u8 *match_level)
{ {
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
@ -1358,7 +1358,7 @@ static int parse_tunnel_attr(struct mlx5e_priv *priv,
outer_headers); outer_headers);
void *headers_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, void *headers_v = MLX5_ADDR_OF(fte_match_param, spec->match_value,
outer_headers); outer_headers);
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
int err; int err;
err = mlx5e_tc_tun_parse(filter_dev, priv, spec, f, err = mlx5e_tc_tun_parse(filter_dev, priv, spec, f,
@ -1478,7 +1478,7 @@ static void *get_match_headers_value(u32 flags,
static int __parse_cls_flower(struct mlx5e_priv *priv, static int __parse_cls_flower(struct mlx5e_priv *priv,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct net_device *filter_dev, struct net_device *filter_dev,
u8 *match_level, u8 *tunnel_match_level) u8 *match_level, u8 *tunnel_match_level)
{ {
@ -1491,7 +1491,7 @@ static int __parse_cls_flower(struct mlx5e_priv *priv,
misc_parameters); misc_parameters);
void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value, void *misc_v = MLX5_ADDR_OF(fte_match_param, spec->match_value,
misc_parameters); misc_parameters);
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
u16 addr_type = 0; u16 addr_type = 0;
u8 ip_proto = 0; u8 ip_proto = 0;
@ -1831,7 +1831,7 @@ static int __parse_cls_flower(struct mlx5e_priv *priv,
static int parse_cls_flower(struct mlx5e_priv *priv, static int parse_cls_flower(struct mlx5e_priv *priv,
struct mlx5e_tc_flow *flow, struct mlx5e_tc_flow *flow,
struct mlx5_flow_spec *spec, struct mlx5_flow_spec *spec,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct net_device *filter_dev) struct net_device *filter_dev)
{ {
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
@ -3115,7 +3115,7 @@ static bool is_peer_flow_needed(struct mlx5e_tc_flow *flow)
static int static int
mlx5e_alloc_flow(struct mlx5e_priv *priv, int attr_size, mlx5e_alloc_flow(struct mlx5e_priv *priv, int attr_size,
struct tc_cls_flower_offload *f, u16 flow_flags, struct flow_cls_offload *f, u16 flow_flags,
struct mlx5e_tc_flow_parse_attr **__parse_attr, struct mlx5e_tc_flow_parse_attr **__parse_attr,
struct mlx5e_tc_flow **__flow) struct mlx5e_tc_flow **__flow)
{ {
@ -3149,7 +3149,7 @@ static void
mlx5e_flow_esw_attr_init(struct mlx5_esw_flow_attr *esw_attr, mlx5e_flow_esw_attr_init(struct mlx5_esw_flow_attr *esw_attr,
struct mlx5e_priv *priv, struct mlx5e_priv *priv,
struct mlx5e_tc_flow_parse_attr *parse_attr, struct mlx5e_tc_flow_parse_attr *parse_attr,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct mlx5_eswitch_rep *in_rep, struct mlx5_eswitch_rep *in_rep,
struct mlx5_core_dev *in_mdev) struct mlx5_core_dev *in_mdev)
{ {
@ -3171,13 +3171,13 @@ mlx5e_flow_esw_attr_init(struct mlx5_esw_flow_attr *esw_attr,
static struct mlx5e_tc_flow * static struct mlx5e_tc_flow *
__mlx5e_add_fdb_flow(struct mlx5e_priv *priv, __mlx5e_add_fdb_flow(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u16 flow_flags, u16 flow_flags,
struct net_device *filter_dev, struct net_device *filter_dev,
struct mlx5_eswitch_rep *in_rep, struct mlx5_eswitch_rep *in_rep,
struct mlx5_core_dev *in_mdev) struct mlx5_core_dev *in_mdev)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct mlx5e_tc_flow_parse_attr *parse_attr; struct mlx5e_tc_flow_parse_attr *parse_attr;
struct mlx5e_tc_flow *flow; struct mlx5e_tc_flow *flow;
@ -3221,7 +3221,7 @@ __mlx5e_add_fdb_flow(struct mlx5e_priv *priv,
return ERR_PTR(err); return ERR_PTR(err);
} }
static int mlx5e_tc_add_fdb_peer_flow(struct tc_cls_flower_offload *f, static int mlx5e_tc_add_fdb_peer_flow(struct flow_cls_offload *f,
struct mlx5e_tc_flow *flow, struct mlx5e_tc_flow *flow,
u16 flow_flags) u16 flow_flags)
{ {
@ -3273,7 +3273,7 @@ static int mlx5e_tc_add_fdb_peer_flow(struct tc_cls_flower_offload *f,
static int static int
mlx5e_add_fdb_flow(struct mlx5e_priv *priv, mlx5e_add_fdb_flow(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u16 flow_flags, u16 flow_flags,
struct net_device *filter_dev, struct net_device *filter_dev,
struct mlx5e_tc_flow **__flow) struct mlx5e_tc_flow **__flow)
@ -3307,12 +3307,12 @@ mlx5e_add_fdb_flow(struct mlx5e_priv *priv,
static int static int
mlx5e_add_nic_flow(struct mlx5e_priv *priv, mlx5e_add_nic_flow(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u16 flow_flags, u16 flow_flags,
struct net_device *filter_dev, struct net_device *filter_dev,
struct mlx5e_tc_flow **__flow) struct mlx5e_tc_flow **__flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct mlx5e_tc_flow_parse_attr *parse_attr; struct mlx5e_tc_flow_parse_attr *parse_attr;
struct mlx5e_tc_flow *flow; struct mlx5e_tc_flow *flow;
@ -3358,7 +3358,7 @@ mlx5e_add_nic_flow(struct mlx5e_priv *priv,
static int static int
mlx5e_tc_add_flow(struct mlx5e_priv *priv, mlx5e_tc_add_flow(struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
int flags, int flags,
struct net_device *filter_dev, struct net_device *filter_dev,
struct mlx5e_tc_flow **flow) struct mlx5e_tc_flow **flow)
@ -3383,7 +3383,7 @@ mlx5e_tc_add_flow(struct mlx5e_priv *priv,
} }
int mlx5e_configure_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_configure_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags) struct flow_cls_offload *f, int flags)
{ {
struct netlink_ext_ack *extack = f->common.extack; struct netlink_ext_ack *extack = f->common.extack;
struct rhashtable *tc_ht = get_tc_ht(priv, flags); struct rhashtable *tc_ht = get_tc_ht(priv, flags);
@ -3430,7 +3430,7 @@ static bool same_flow_direction(struct mlx5e_tc_flow *flow, int flags)
} }
int mlx5e_delete_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_delete_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags) struct flow_cls_offload *f, int flags)
{ {
struct rhashtable *tc_ht = get_tc_ht(priv, flags); struct rhashtable *tc_ht = get_tc_ht(priv, flags);
struct mlx5e_tc_flow *flow; struct mlx5e_tc_flow *flow;
@ -3449,7 +3449,7 @@ int mlx5e_delete_flower(struct net_device *dev, struct mlx5e_priv *priv,
} }
int mlx5e_stats_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_stats_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags) struct flow_cls_offload *f, int flags)
{ {
struct mlx5_devcom *devcom = priv->mdev->priv.devcom; struct mlx5_devcom *devcom = priv->mdev->priv.devcom;
struct rhashtable *tc_ht = get_tc_ht(priv, flags); struct rhashtable *tc_ht = get_tc_ht(priv, flags);

View File

@ -54,12 +54,12 @@ int mlx5e_tc_esw_init(struct rhashtable *tc_ht);
void mlx5e_tc_esw_cleanup(struct rhashtable *tc_ht); void mlx5e_tc_esw_cleanup(struct rhashtable *tc_ht);
int mlx5e_configure_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_configure_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags); struct flow_cls_offload *f, int flags);
int mlx5e_delete_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_delete_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags); struct flow_cls_offload *f, int flags);
int mlx5e_stats_flower(struct net_device *dev, struct mlx5e_priv *priv, int mlx5e_stats_flower(struct net_device *dev, struct mlx5e_priv *priv,
struct tc_cls_flower_offload *f, int flags); struct flow_cls_offload *f, int flags);
struct mlx5e_encap_entry; struct mlx5e_encap_entry;
void mlx5e_tc_encap_flows_add(struct mlx5e_priv *priv, void mlx5e_tc_encap_flows_add(struct mlx5e_priv *priv,

View File

@ -1508,21 +1508,21 @@ static int mlxsw_sp_setup_tc_cls_matchall(struct mlxsw_sp_port *mlxsw_sp_port,
static int static int
mlxsw_sp_setup_tc_cls_flower(struct mlxsw_sp_acl_block *acl_block, mlxsw_sp_setup_tc_cls_flower(struct mlxsw_sp_acl_block *acl_block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp *mlxsw_sp = mlxsw_sp_acl_block_mlxsw_sp(acl_block); struct mlxsw_sp *mlxsw_sp = mlxsw_sp_acl_block_mlxsw_sp(acl_block);
switch (f->command) { switch (f->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return mlxsw_sp_flower_replace(mlxsw_sp, acl_block, f); return mlxsw_sp_flower_replace(mlxsw_sp, acl_block, f);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
mlxsw_sp_flower_destroy(mlxsw_sp, acl_block, f); mlxsw_sp_flower_destroy(mlxsw_sp, acl_block, f);
return 0; return 0;
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return mlxsw_sp_flower_stats(mlxsw_sp, acl_block, f); return mlxsw_sp_flower_stats(mlxsw_sp, acl_block, f);
case TC_CLSFLOWER_TMPLT_CREATE: case FLOW_CLS_TMPLT_CREATE:
return mlxsw_sp_flower_tmplt_create(mlxsw_sp, acl_block, f); return mlxsw_sp_flower_tmplt_create(mlxsw_sp, acl_block, f);
case TC_CLSFLOWER_TMPLT_DESTROY: case FLOW_CLS_TMPLT_DESTROY:
mlxsw_sp_flower_tmplt_destroy(mlxsw_sp, acl_block, f); mlxsw_sp_flower_tmplt_destroy(mlxsw_sp, acl_block, f);
return 0; return 0;
default: default:

View File

@ -807,19 +807,19 @@ extern const struct mlxsw_afk_ops mlxsw_sp2_afk_ops;
/* spectrum_flower.c */ /* spectrum_flower.c */
int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp, void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
int mlxsw_sp_flower_tmplt_create(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_tmplt_create(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
void mlxsw_sp_flower_tmplt_destroy(struct mlxsw_sp *mlxsw_sp, void mlxsw_sp_flower_tmplt_destroy(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
/* spectrum_qdisc.c */ /* spectrum_qdisc.c */
int mlxsw_sp_tc_qdisc_init(struct mlxsw_sp_port *mlxsw_sp_port); int mlxsw_sp_tc_qdisc_init(struct mlxsw_sp_port *mlxsw_sp_port);

View File

@ -121,10 +121,10 @@ static int mlxsw_sp_flower_parse_actions(struct mlxsw_sp *mlxsw_sp,
} }
static int mlxsw_sp_flower_parse_meta(struct mlxsw_sp_acl_rule_info *rulei, static int mlxsw_sp_flower_parse_meta(struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
struct mlxsw_sp_acl_block *block) struct mlxsw_sp_acl_block *block)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct mlxsw_sp_port *mlxsw_sp_port; struct mlxsw_sp_port *mlxsw_sp_port;
struct net_device *ingress_dev; struct net_device *ingress_dev;
struct flow_match_meta match; struct flow_match_meta match;
@ -164,7 +164,7 @@ static int mlxsw_sp_flower_parse_meta(struct mlxsw_sp_acl_rule_info *rulei,
} }
static void mlxsw_sp_flower_parse_ipv4(struct mlxsw_sp_acl_rule_info *rulei, static void mlxsw_sp_flower_parse_ipv4(struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_match_ipv4_addrs match; struct flow_match_ipv4_addrs match;
@ -179,7 +179,7 @@ static void mlxsw_sp_flower_parse_ipv4(struct mlxsw_sp_acl_rule_info *rulei,
} }
static void mlxsw_sp_flower_parse_ipv6(struct mlxsw_sp_acl_rule_info *rulei, static void mlxsw_sp_flower_parse_ipv6(struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_match_ipv6_addrs match; struct flow_match_ipv6_addrs match;
@ -213,10 +213,10 @@ static void mlxsw_sp_flower_parse_ipv6(struct mlxsw_sp_acl_rule_info *rulei,
static int mlxsw_sp_flower_parse_ports(struct mlxsw_sp *mlxsw_sp, static int mlxsw_sp_flower_parse_ports(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_rule_info *rulei, struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u8 ip_proto) u8 ip_proto)
{ {
const struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); const struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_match_ports match; struct flow_match_ports match;
if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_PORTS)) if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_PORTS))
@ -240,10 +240,10 @@ static int mlxsw_sp_flower_parse_ports(struct mlxsw_sp *mlxsw_sp,
static int mlxsw_sp_flower_parse_tcp(struct mlxsw_sp *mlxsw_sp, static int mlxsw_sp_flower_parse_tcp(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_rule_info *rulei, struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u8 ip_proto) u8 ip_proto)
{ {
const struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); const struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_match_tcp match; struct flow_match_tcp match;
if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_TCP)) if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_TCP))
@ -265,10 +265,10 @@ static int mlxsw_sp_flower_parse_tcp(struct mlxsw_sp *mlxsw_sp,
static int mlxsw_sp_flower_parse_ip(struct mlxsw_sp *mlxsw_sp, static int mlxsw_sp_flower_parse_ip(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_rule_info *rulei, struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f, struct flow_cls_offload *f,
u16 n_proto) u16 n_proto)
{ {
const struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); const struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_match_ip match; struct flow_match_ip match;
if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IP)) if (!flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IP))
@ -299,9 +299,9 @@ static int mlxsw_sp_flower_parse_ip(struct mlxsw_sp *mlxsw_sp,
static int mlxsw_sp_flower_parse(struct mlxsw_sp *mlxsw_sp, static int mlxsw_sp_flower_parse(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct mlxsw_sp_acl_rule_info *rulei, struct mlxsw_sp_acl_rule_info *rulei,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
u16 n_proto_mask = 0; u16 n_proto_mask = 0;
u16 n_proto_key = 0; u16 n_proto_key = 0;
@ -426,7 +426,7 @@ static int mlxsw_sp_flower_parse(struct mlxsw_sp *mlxsw_sp,
int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp_acl_rule_info *rulei; struct mlxsw_sp_acl_rule_info *rulei;
struct mlxsw_sp_acl_ruleset *ruleset; struct mlxsw_sp_acl_ruleset *ruleset;
@ -473,7 +473,7 @@ int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp,
void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp, void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp_acl_ruleset *ruleset; struct mlxsw_sp_acl_ruleset *ruleset;
struct mlxsw_sp_acl_rule *rule; struct mlxsw_sp_acl_rule *rule;
@ -495,7 +495,7 @@ void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp,
int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp_acl_ruleset *ruleset; struct mlxsw_sp_acl_ruleset *ruleset;
struct mlxsw_sp_acl_rule *rule; struct mlxsw_sp_acl_rule *rule;
@ -531,7 +531,7 @@ int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp,
int mlxsw_sp_flower_tmplt_create(struct mlxsw_sp *mlxsw_sp, int mlxsw_sp_flower_tmplt_create(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp_acl_ruleset *ruleset; struct mlxsw_sp_acl_ruleset *ruleset;
struct mlxsw_sp_acl_rule_info rulei; struct mlxsw_sp_acl_rule_info rulei;
@ -552,7 +552,7 @@ int mlxsw_sp_flower_tmplt_create(struct mlxsw_sp *mlxsw_sp,
void mlxsw_sp_flower_tmplt_destroy(struct mlxsw_sp *mlxsw_sp, void mlxsw_sp_flower_tmplt_destroy(struct mlxsw_sp *mlxsw_sp,
struct mlxsw_sp_acl_block *block, struct mlxsw_sp_acl_block *block,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct mlxsw_sp_acl_ruleset *ruleset; struct mlxsw_sp_acl_ruleset *ruleset;

View File

@ -19,7 +19,7 @@ static u16 get_prio(u32 prio)
return prio >> 16; return prio >> 16;
} }
static int ocelot_flower_parse_action(struct tc_cls_flower_offload *f, static int ocelot_flower_parse_action(struct flow_cls_offload *f,
struct ocelot_ace_rule *rule) struct ocelot_ace_rule *rule)
{ {
const struct flow_action_entry *a; const struct flow_action_entry *a;
@ -44,10 +44,10 @@ static int ocelot_flower_parse_action(struct tc_cls_flower_offload *f,
return 0; return 0;
} }
static int ocelot_flower_parse(struct tc_cls_flower_offload *f, static int ocelot_flower_parse(struct flow_cls_offload *f,
struct ocelot_ace_rule *ocelot_rule) struct ocelot_ace_rule *ocelot_rule)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
if (dissector->used_keys & if (dissector->used_keys &
@ -174,7 +174,7 @@ static int ocelot_flower_parse(struct tc_cls_flower_offload *f,
} }
static static
struct ocelot_ace_rule *ocelot_ace_rule_create(struct tc_cls_flower_offload *f, struct ocelot_ace_rule *ocelot_ace_rule_create(struct flow_cls_offload *f,
struct ocelot_port_block *block) struct ocelot_port_block *block)
{ {
struct ocelot_ace_rule *rule; struct ocelot_ace_rule *rule;
@ -188,7 +188,7 @@ struct ocelot_ace_rule *ocelot_ace_rule_create(struct tc_cls_flower_offload *f,
return rule; return rule;
} }
static int ocelot_flower_replace(struct tc_cls_flower_offload *f, static int ocelot_flower_replace(struct flow_cls_offload *f,
struct ocelot_port_block *port_block) struct ocelot_port_block *port_block)
{ {
struct ocelot_ace_rule *rule; struct ocelot_ace_rule *rule;
@ -212,7 +212,7 @@ static int ocelot_flower_replace(struct tc_cls_flower_offload *f,
return 0; return 0;
} }
static int ocelot_flower_destroy(struct tc_cls_flower_offload *f, static int ocelot_flower_destroy(struct flow_cls_offload *f,
struct ocelot_port_block *port_block) struct ocelot_port_block *port_block)
{ {
struct ocelot_ace_rule rule; struct ocelot_ace_rule rule;
@ -230,7 +230,7 @@ static int ocelot_flower_destroy(struct tc_cls_flower_offload *f,
return 0; return 0;
} }
static int ocelot_flower_stats_update(struct tc_cls_flower_offload *f, static int ocelot_flower_stats_update(struct flow_cls_offload *f,
struct ocelot_port_block *port_block) struct ocelot_port_block *port_block)
{ {
struct ocelot_ace_rule rule; struct ocelot_ace_rule rule;
@ -247,15 +247,15 @@ static int ocelot_flower_stats_update(struct tc_cls_flower_offload *f,
return 0; return 0;
} }
static int ocelot_setup_tc_cls_flower(struct tc_cls_flower_offload *f, static int ocelot_setup_tc_cls_flower(struct flow_cls_offload *f,
struct ocelot_port_block *port_block) struct ocelot_port_block *port_block)
{ {
switch (f->command) { switch (f->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return ocelot_flower_replace(f, port_block); return ocelot_flower_replace(f, port_block);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return ocelot_flower_destroy(f, port_block); return ocelot_flower_destroy(f, port_block);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return ocelot_flower_stats_update(f, port_block); return ocelot_flower_stats_update(f, port_block);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -171,7 +171,7 @@ nfp_fl_output(struct nfp_app *app, struct nfp_fl_output *output,
} }
static bool static bool
nfp_flower_tun_is_gre(struct tc_cls_flower_offload *flow, int start_idx) nfp_flower_tun_is_gre(struct flow_cls_offload *flow, int start_idx)
{ {
struct flow_action_entry *act = flow->rule->action.entries; struct flow_action_entry *act = flow->rule->action.entries;
int num_act = flow->rule->action.num_entries; int num_act = flow->rule->action.num_entries;
@ -188,7 +188,7 @@ nfp_flower_tun_is_gre(struct tc_cls_flower_offload *flow, int start_idx)
static enum nfp_flower_tun_type static enum nfp_flower_tun_type
nfp_fl_get_tun_from_act(struct nfp_app *app, nfp_fl_get_tun_from_act(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
const struct flow_action_entry *act, int act_idx) const struct flow_action_entry *act, int act_idx)
{ {
const struct ip_tunnel_info *tun = act->tunnel; const struct ip_tunnel_info *tun = act->tunnel;
@ -669,11 +669,11 @@ struct nfp_flower_pedit_acts {
}; };
static int static int
nfp_fl_commit_mangle(struct tc_cls_flower_offload *flow, char *nfp_action, nfp_fl_commit_mangle(struct flow_cls_offload *flow, char *nfp_action,
int *a_len, struct nfp_flower_pedit_acts *set_act, int *a_len, struct nfp_flower_pedit_acts *set_act,
u32 *csum_updated) u32 *csum_updated)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
size_t act_size = 0; size_t act_size = 0;
u8 ip_proto = 0; u8 ip_proto = 0;
@ -771,7 +771,7 @@ nfp_fl_commit_mangle(struct tc_cls_flower_offload *flow, char *nfp_action,
static int static int
nfp_fl_pedit(const struct flow_action_entry *act, nfp_fl_pedit(const struct flow_action_entry *act,
struct tc_cls_flower_offload *flow, char *nfp_action, int *a_len, struct flow_cls_offload *flow, char *nfp_action, int *a_len,
u32 *csum_updated, struct nfp_flower_pedit_acts *set_act, u32 *csum_updated, struct nfp_flower_pedit_acts *set_act,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
@ -858,7 +858,7 @@ nfp_flower_output_action(struct nfp_app *app,
static int static int
nfp_flower_loop_action(struct nfp_app *app, const struct flow_action_entry *act, nfp_flower_loop_action(struct nfp_app *app, const struct flow_action_entry *act,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct nfp_fl_payload *nfp_fl, int *a_len, struct nfp_fl_payload *nfp_fl, int *a_len,
struct net_device *netdev, struct net_device *netdev,
enum nfp_flower_tun_type *tun_type, int *tun_out_cnt, enum nfp_flower_tun_type *tun_type, int *tun_out_cnt,
@ -1021,7 +1021,7 @@ static bool nfp_fl_check_mangle_end(struct flow_action *flow_act,
} }
int nfp_flower_compile_action(struct nfp_app *app, int nfp_flower_compile_action(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct net_device *netdev, struct net_device *netdev,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)

View File

@ -343,19 +343,19 @@ int nfp_flower_merge_offloaded_flows(struct nfp_app *app,
struct nfp_fl_payload *sub_flow1, struct nfp_fl_payload *sub_flow1,
struct nfp_fl_payload *sub_flow2); struct nfp_fl_payload *sub_flow2);
int nfp_flower_compile_flow_match(struct nfp_app *app, int nfp_flower_compile_flow_match(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct nfp_fl_key_ls *key_ls, struct nfp_fl_key_ls *key_ls,
struct net_device *netdev, struct net_device *netdev,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,
enum nfp_flower_tun_type tun_type, enum nfp_flower_tun_type tun_type,
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);
int nfp_flower_compile_action(struct nfp_app *app, int nfp_flower_compile_action(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct net_device *netdev, struct net_device *netdev,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);
int nfp_compile_flow_metadata(struct nfp_app *app, int nfp_compile_flow_metadata(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,
struct net_device *netdev, struct net_device *netdev,
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);

View File

@ -10,9 +10,9 @@
static void static void
nfp_flower_compile_meta_tci(struct nfp_flower_meta_tci *ext, nfp_flower_compile_meta_tci(struct nfp_flower_meta_tci *ext,
struct nfp_flower_meta_tci *msk, struct nfp_flower_meta_tci *msk,
struct tc_cls_flower_offload *flow, u8 key_type) struct flow_cls_offload *flow, u8 key_type)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
u16 tmp_tci; u16 tmp_tci;
memset(ext, 0, sizeof(struct nfp_flower_meta_tci)); memset(ext, 0, sizeof(struct nfp_flower_meta_tci));
@ -78,9 +78,9 @@ nfp_flower_compile_port(struct nfp_flower_in_port *frame, u32 cmsg_port,
static void static void
nfp_flower_compile_mac(struct nfp_flower_mac_mpls *ext, nfp_flower_compile_mac(struct nfp_flower_mac_mpls *ext,
struct nfp_flower_mac_mpls *msk, struct nfp_flower_mac_mpls *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
memset(ext, 0, sizeof(struct nfp_flower_mac_mpls)); memset(ext, 0, sizeof(struct nfp_flower_mac_mpls));
memset(msk, 0, sizeof(struct nfp_flower_mac_mpls)); memset(msk, 0, sizeof(struct nfp_flower_mac_mpls));
@ -130,9 +130,9 @@ nfp_flower_compile_mac(struct nfp_flower_mac_mpls *ext,
static void static void
nfp_flower_compile_tport(struct nfp_flower_tp_ports *ext, nfp_flower_compile_tport(struct nfp_flower_tp_ports *ext,
struct nfp_flower_tp_ports *msk, struct nfp_flower_tp_ports *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
memset(ext, 0, sizeof(struct nfp_flower_tp_ports)); memset(ext, 0, sizeof(struct nfp_flower_tp_ports));
memset(msk, 0, sizeof(struct nfp_flower_tp_ports)); memset(msk, 0, sizeof(struct nfp_flower_tp_ports));
@ -151,9 +151,9 @@ nfp_flower_compile_tport(struct nfp_flower_tp_ports *ext,
static void static void
nfp_flower_compile_ip_ext(struct nfp_flower_ip_ext *ext, nfp_flower_compile_ip_ext(struct nfp_flower_ip_ext *ext,
struct nfp_flower_ip_ext *msk, struct nfp_flower_ip_ext *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_BASIC)) { if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_BASIC)) {
struct flow_match_basic match; struct flow_match_basic match;
@ -225,9 +225,9 @@ nfp_flower_compile_ip_ext(struct nfp_flower_ip_ext *ext,
static void static void
nfp_flower_compile_ipv4(struct nfp_flower_ipv4 *ext, nfp_flower_compile_ipv4(struct nfp_flower_ipv4 *ext,
struct nfp_flower_ipv4 *msk, struct nfp_flower_ipv4 *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
struct flow_match_ipv4_addrs match; struct flow_match_ipv4_addrs match;
memset(ext, 0, sizeof(struct nfp_flower_ipv4)); memset(ext, 0, sizeof(struct nfp_flower_ipv4));
@ -247,9 +247,9 @@ nfp_flower_compile_ipv4(struct nfp_flower_ipv4 *ext,
static void static void
nfp_flower_compile_ipv6(struct nfp_flower_ipv6 *ext, nfp_flower_compile_ipv6(struct nfp_flower_ipv6 *ext,
struct nfp_flower_ipv6 *msk, struct nfp_flower_ipv6 *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
memset(ext, 0, sizeof(struct nfp_flower_ipv6)); memset(ext, 0, sizeof(struct nfp_flower_ipv6));
memset(msk, 0, sizeof(struct nfp_flower_ipv6)); memset(msk, 0, sizeof(struct nfp_flower_ipv6));
@ -269,7 +269,7 @@ nfp_flower_compile_ipv6(struct nfp_flower_ipv6 *ext,
static int static int
nfp_flower_compile_geneve_opt(void *ext, void *msk, nfp_flower_compile_geneve_opt(void *ext, void *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_match_enc_opts match; struct flow_match_enc_opts match;
@ -283,9 +283,9 @@ nfp_flower_compile_geneve_opt(void *ext, void *msk,
static void static void
nfp_flower_compile_tun_ipv4_addrs(struct nfp_flower_tun_ipv4 *ext, nfp_flower_compile_tun_ipv4_addrs(struct nfp_flower_tun_ipv4 *ext,
struct nfp_flower_tun_ipv4 *msk, struct nfp_flower_tun_ipv4 *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ENC_IPV4_ADDRS)) { if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ENC_IPV4_ADDRS)) {
struct flow_match_ipv4_addrs match; struct flow_match_ipv4_addrs match;
@ -301,9 +301,9 @@ nfp_flower_compile_tun_ipv4_addrs(struct nfp_flower_tun_ipv4 *ext,
static void static void
nfp_flower_compile_tun_ip_ext(struct nfp_flower_tun_ip_ext *ext, nfp_flower_compile_tun_ip_ext(struct nfp_flower_tun_ip_ext *ext,
struct nfp_flower_tun_ip_ext *msk, struct nfp_flower_tun_ip_ext *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ENC_IP)) { if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ENC_IP)) {
struct flow_match_ip match; struct flow_match_ip match;
@ -319,9 +319,9 @@ nfp_flower_compile_tun_ip_ext(struct nfp_flower_tun_ip_ext *ext,
static void static void
nfp_flower_compile_ipv4_gre_tun(struct nfp_flower_ipv4_gre_tun *ext, nfp_flower_compile_ipv4_gre_tun(struct nfp_flower_ipv4_gre_tun *ext,
struct nfp_flower_ipv4_gre_tun *msk, struct nfp_flower_ipv4_gre_tun *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
memset(ext, 0, sizeof(struct nfp_flower_ipv4_gre_tun)); memset(ext, 0, sizeof(struct nfp_flower_ipv4_gre_tun));
memset(msk, 0, sizeof(struct nfp_flower_ipv4_gre_tun)); memset(msk, 0, sizeof(struct nfp_flower_ipv4_gre_tun));
@ -348,9 +348,9 @@ nfp_flower_compile_ipv4_gre_tun(struct nfp_flower_ipv4_gre_tun *ext,
static void static void
nfp_flower_compile_ipv4_udp_tun(struct nfp_flower_ipv4_udp_tun *ext, nfp_flower_compile_ipv4_udp_tun(struct nfp_flower_ipv4_udp_tun *ext,
struct nfp_flower_ipv4_udp_tun *msk, struct nfp_flower_ipv4_udp_tun *msk,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
memset(ext, 0, sizeof(struct nfp_flower_ipv4_udp_tun)); memset(ext, 0, sizeof(struct nfp_flower_ipv4_udp_tun));
memset(msk, 0, sizeof(struct nfp_flower_ipv4_udp_tun)); memset(msk, 0, sizeof(struct nfp_flower_ipv4_udp_tun));
@ -371,7 +371,7 @@ nfp_flower_compile_ipv4_udp_tun(struct nfp_flower_ipv4_udp_tun *ext,
} }
int nfp_flower_compile_flow_match(struct nfp_app *app, int nfp_flower_compile_flow_match(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct nfp_fl_key_ls *key_ls, struct nfp_fl_key_ls *key_ls,
struct net_device *netdev, struct net_device *netdev,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,

View File

@ -290,7 +290,7 @@ nfp_check_mask_remove(struct nfp_app *app, char *mask_data, u32 mask_len,
} }
int nfp_compile_flow_metadata(struct nfp_app *app, int nfp_compile_flow_metadata(struct nfp_app *app,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
struct nfp_fl_payload *nfp_flow, struct nfp_fl_payload *nfp_flow,
struct net_device *netdev, struct net_device *netdev,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)

View File

@ -121,9 +121,9 @@ nfp_flower_xmit_flow(struct nfp_app *app, struct nfp_fl_payload *nfp_flow,
return 0; return 0;
} }
static bool nfp_flower_check_higher_than_mac(struct tc_cls_flower_offload *f) static bool nfp_flower_check_higher_than_mac(struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
return flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IPV4_ADDRS) || return flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IPV4_ADDRS) ||
flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IPV6_ADDRS) || flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_IPV6_ADDRS) ||
@ -131,9 +131,9 @@ static bool nfp_flower_check_higher_than_mac(struct tc_cls_flower_offload *f)
flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ICMP); flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ICMP);
} }
static bool nfp_flower_check_higher_than_l3(struct tc_cls_flower_offload *f) static bool nfp_flower_check_higher_than_l3(struct flow_cls_offload *f)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(f); struct flow_rule *rule = flow_cls_offload_flow_rule(f);
return flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_PORTS) || return flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_PORTS) ||
flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ICMP); flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_ICMP);
@ -212,11 +212,11 @@ static int
nfp_flower_calculate_key_layers(struct nfp_app *app, nfp_flower_calculate_key_layers(struct nfp_app *app,
struct net_device *netdev, struct net_device *netdev,
struct nfp_fl_key_ls *ret_key_ls, struct nfp_fl_key_ls *ret_key_ls,
struct tc_cls_flower_offload *flow, struct flow_cls_offload *flow,
enum nfp_flower_tun_type *tun_type, enum nfp_flower_tun_type *tun_type,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
struct flow_rule *rule = tc_cls_flower_offload_flow_rule(flow); struct flow_rule *rule = flow_cls_offload_flow_rule(flow);
struct flow_dissector *dissector = rule->match.dissector; struct flow_dissector *dissector = rule->match.dissector;
struct flow_match_basic basic = { NULL, NULL}; struct flow_match_basic basic = { NULL, NULL};
struct nfp_flower_priv *priv = app->priv; struct nfp_flower_priv *priv = app->priv;
@ -866,7 +866,7 @@ int nfp_flower_merge_offloaded_flows(struct nfp_app *app,
struct nfp_fl_payload *sub_flow1, struct nfp_fl_payload *sub_flow1,
struct nfp_fl_payload *sub_flow2) struct nfp_fl_payload *sub_flow2)
{ {
struct tc_cls_flower_offload merge_tc_off; struct flow_cls_offload merge_tc_off;
struct nfp_flower_priv *priv = app->priv; struct nfp_flower_priv *priv = app->priv;
struct netlink_ext_ack *extack = NULL; struct netlink_ext_ack *extack = NULL;
struct nfp_fl_payload *merge_flow; struct nfp_fl_payload *merge_flow;
@ -962,7 +962,7 @@ int nfp_flower_merge_offloaded_flows(struct nfp_app *app,
*/ */
static int static int
nfp_flower_add_offload(struct nfp_app *app, struct net_device *netdev, nfp_flower_add_offload(struct nfp_app *app, struct net_device *netdev,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
enum nfp_flower_tun_type tun_type = NFP_FL_TUNNEL_NONE; enum nfp_flower_tun_type tun_type = NFP_FL_TUNNEL_NONE;
struct nfp_flower_priv *priv = app->priv; struct nfp_flower_priv *priv = app->priv;
@ -1125,7 +1125,7 @@ nfp_flower_del_linked_merge_flows(struct nfp_app *app,
*/ */
static int static int
nfp_flower_del_offload(struct nfp_app *app, struct net_device *netdev, nfp_flower_del_offload(struct nfp_app *app, struct net_device *netdev,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct nfp_flower_priv *priv = app->priv; struct nfp_flower_priv *priv = app->priv;
struct netlink_ext_ack *extack = NULL; struct netlink_ext_ack *extack = NULL;
@ -1232,7 +1232,7 @@ nfp_flower_update_merge_stats(struct nfp_app *app,
*/ */
static int static int
nfp_flower_get_stats(struct nfp_app *app, struct net_device *netdev, nfp_flower_get_stats(struct nfp_app *app, struct net_device *netdev,
struct tc_cls_flower_offload *flow) struct flow_cls_offload *flow)
{ {
struct nfp_flower_priv *priv = app->priv; struct nfp_flower_priv *priv = app->priv;
struct netlink_ext_ack *extack = NULL; struct netlink_ext_ack *extack = NULL;
@ -1265,17 +1265,17 @@ nfp_flower_get_stats(struct nfp_app *app, struct net_device *netdev,
static int static int
nfp_flower_repr_offload(struct nfp_app *app, struct net_device *netdev, nfp_flower_repr_offload(struct nfp_app *app, struct net_device *netdev,
struct tc_cls_flower_offload *flower) struct flow_cls_offload *flower)
{ {
if (!eth_proto_is_802_3(flower->common.protocol)) if (!eth_proto_is_802_3(flower->common.protocol))
return -EOPNOTSUPP; return -EOPNOTSUPP;
switch (flower->command) { switch (flower->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return nfp_flower_add_offload(app, netdev, flower); return nfp_flower_add_offload(app, netdev, flower);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return nfp_flower_del_offload(app, netdev, flower); return nfp_flower_del_offload(app, netdev, flower);
case TC_CLSFLOWER_STATS: case FLOW_CLS_STATS:
return nfp_flower_get_stats(app, netdev, flower); return nfp_flower_get_stats(app, netdev, flower);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
@ -1385,7 +1385,7 @@ static int nfp_flower_setup_indr_block_cb(enum tc_setup_type type,
void *type_data, void *cb_priv) void *type_data, void *cb_priv)
{ {
struct nfp_flower_indr_block_cb_priv *priv = cb_priv; struct nfp_flower_indr_block_cb_priv *priv = cb_priv;
struct tc_cls_flower_offload *flower = type_data; struct flow_cls_offload *flower = type_data;
if (flower->common.chain_index) if (flower->common.chain_index)
return -EOPNOTSUPP; return -EOPNOTSUPP;

View File

@ -551,7 +551,7 @@ int qede_txq_has_work(struct qede_tx_queue *txq);
void qede_recycle_rx_bd_ring(struct qede_rx_queue *rxq, u8 count); void qede_recycle_rx_bd_ring(struct qede_rx_queue *rxq, u8 count);
void qede_update_rx_prod(struct qede_dev *edev, struct qede_rx_queue *rxq); void qede_update_rx_prod(struct qede_dev *edev, struct qede_rx_queue *rxq);
int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto, int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto,
struct tc_cls_flower_offload *f); struct flow_cls_offload *f);
#define RX_RING_SIZE_POW 13 #define RX_RING_SIZE_POW 13
#define RX_RING_SIZE ((u16)BIT(RX_RING_SIZE_POW)) #define RX_RING_SIZE ((u16)BIT(RX_RING_SIZE_POW))

View File

@ -1943,7 +1943,7 @@ qede_parse_flow_attr(struct qede_dev *edev, __be16 proto,
} }
int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto, int qede_add_tc_flower_fltr(struct qede_dev *edev, __be16 proto,
struct tc_cls_flower_offload *f) struct flow_cls_offload *f)
{ {
struct qede_arfs_fltr_node *n; struct qede_arfs_fltr_node *n;
int min_hlen, rc = -EINVAL; int min_hlen, rc = -EINVAL;

View File

@ -548,13 +548,13 @@ static int qede_setup_tc(struct net_device *ndev, u8 num_tc)
} }
static int static int
qede_set_flower(struct qede_dev *edev, struct tc_cls_flower_offload *f, qede_set_flower(struct qede_dev *edev, struct flow_cls_offload *f,
__be16 proto) __be16 proto)
{ {
switch (f->command) { switch (f->command) {
case TC_CLSFLOWER_REPLACE: case FLOW_CLS_REPLACE:
return qede_add_tc_flower_fltr(edev, proto, f); return qede_add_tc_flower_fltr(edev, proto, f);
case TC_CLSFLOWER_DESTROY: case FLOW_CLS_DESTROY:
return qede_delete_flow_filter(edev, f->cookie); return qede_delete_flow_filter(edev, f->cookie);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
@ -564,7 +564,7 @@ qede_set_flower(struct qede_dev *edev, struct tc_cls_flower_offload *f,
static int qede_setup_tc_block_cb(enum tc_setup_type type, void *type_data, static int qede_setup_tc_block_cb(enum tc_setup_type type, void *type_data,
void *cb_priv) void *cb_priv)
{ {
struct tc_cls_flower_offload *f; struct flow_cls_offload *f;
struct qede_dev *edev = cb_priv; struct qede_dev *edev = cb_priv;
if (!tc_cls_can_offload_and_chain0(edev->ndev, type_data)) if (!tc_cls_can_offload_and_chain0(edev->ndev, type_data))

View File

@ -303,4 +303,34 @@ int flow_block_cb_setup_simple(struct flow_block_offload *f,
struct list_head *driver_list, tc_setup_cb_t *cb, struct list_head *driver_list, tc_setup_cb_t *cb,
void *cb_ident, void *cb_priv, bool ingress_only); void *cb_ident, void *cb_priv, bool ingress_only);
enum flow_cls_command {
FLOW_CLS_REPLACE,
FLOW_CLS_DESTROY,
FLOW_CLS_STATS,
FLOW_CLS_TMPLT_CREATE,
FLOW_CLS_TMPLT_DESTROY,
};
struct flow_cls_common_offload {
u32 chain_index;
__be16 protocol;
u32 prio;
struct netlink_ext_ack *extack;
};
struct flow_cls_offload {
struct flow_cls_common_offload common;
enum flow_cls_command command;
unsigned long cookie;
struct flow_rule *rule;
struct flow_stats stats;
u32 classid;
};
static inline struct flow_rule *
flow_cls_offload_flow_rule(struct flow_cls_offload *flow_cmd)
{
return flow_cmd->rule;
}
#endif /* _NET_FLOW_OFFLOAD_H */ #endif /* _NET_FLOW_OFFLOAD_H */

View File

@ -535,13 +535,6 @@ int tc_setup_cb_call(struct tcf_block *block, enum tc_setup_type type,
void *type_data, bool err_stop); void *type_data, bool err_stop);
unsigned int tcf_exts_num_actions(struct tcf_exts *exts); unsigned int tcf_exts_num_actions(struct tcf_exts *exts);
struct tc_cls_common_offload {
u32 chain_index;
__be16 protocol;
u32 prio;
struct netlink_ext_ack *extack;
};
struct tc_cls_u32_knode { struct tc_cls_u32_knode {
struct tcf_exts *exts; struct tcf_exts *exts;
struct tcf_result *res; struct tcf_result *res;
@ -569,7 +562,7 @@ enum tc_clsu32_command {
}; };
struct tc_cls_u32_offload { struct tc_cls_u32_offload {
struct tc_cls_common_offload common; struct flow_cls_common_offload common;
/* knode values */ /* knode values */
enum tc_clsu32_command command; enum tc_clsu32_command command;
union { union {
@ -596,7 +589,7 @@ static inline bool tc_can_offload_extack(const struct net_device *dev,
static inline bool static inline bool
tc_cls_can_offload_and_chain0(const struct net_device *dev, tc_cls_can_offload_and_chain0(const struct net_device *dev,
struct tc_cls_common_offload *common) struct flow_cls_common_offload *common)
{ {
if (!tc_can_offload_extack(dev, common->extack)) if (!tc_can_offload_extack(dev, common->extack))
return false; return false;
@ -638,7 +631,7 @@ static inline bool tc_in_hw(u32 flags)
} }
static inline void static inline void
tc_cls_common_offload_init(struct tc_cls_common_offload *cls_common, tc_cls_common_offload_init(struct flow_cls_common_offload *cls_common,
const struct tcf_proto *tp, u32 flags, const struct tcf_proto *tp, u32 flags,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
@ -649,29 +642,6 @@ tc_cls_common_offload_init(struct tc_cls_common_offload *cls_common,
cls_common->extack = extack; cls_common->extack = extack;
} }
enum tc_fl_command {
TC_CLSFLOWER_REPLACE,
TC_CLSFLOWER_DESTROY,
TC_CLSFLOWER_STATS,
TC_CLSFLOWER_TMPLT_CREATE,
TC_CLSFLOWER_TMPLT_DESTROY,
};
struct tc_cls_flower_offload {
struct tc_cls_common_offload common;
enum tc_fl_command command;
unsigned long cookie;
struct flow_rule *rule;
struct flow_stats stats;
u32 classid;
};
static inline struct flow_rule *
tc_cls_flower_offload_flow_rule(struct tc_cls_flower_offload *tc_flow_cmd)
{
return tc_flow_cmd->rule;
}
enum tc_matchall_command { enum tc_matchall_command {
TC_CLSMATCHALL_REPLACE, TC_CLSMATCHALL_REPLACE,
TC_CLSMATCHALL_DESTROY, TC_CLSMATCHALL_DESTROY,
@ -679,7 +649,7 @@ enum tc_matchall_command {
}; };
struct tc_cls_matchall_offload { struct tc_cls_matchall_offload {
struct tc_cls_common_offload common; struct flow_cls_common_offload common;
enum tc_matchall_command command; enum tc_matchall_command command;
struct flow_rule *rule; struct flow_rule *rule;
struct flow_stats stats; struct flow_stats stats;
@ -692,7 +662,7 @@ enum tc_clsbpf_command {
}; };
struct tc_cls_bpf_offload { struct tc_cls_bpf_offload {
struct tc_cls_common_offload common; struct flow_cls_common_offload common;
enum tc_clsbpf_command command; enum tc_clsbpf_command command;
struct tcf_exts *exts; struct tcf_exts *exts;
struct bpf_prog *prog; struct bpf_prog *prog;

View File

@ -409,14 +409,14 @@ static void fl_destroy_filter_work(struct work_struct *work)
static void fl_hw_destroy_filter(struct tcf_proto *tp, struct cls_fl_filter *f, static void fl_hw_destroy_filter(struct tcf_proto *tp, struct cls_fl_filter *f,
bool rtnl_held, struct netlink_ext_ack *extack) bool rtnl_held, struct netlink_ext_ack *extack)
{ {
struct tc_cls_flower_offload cls_flower = {};
struct tcf_block *block = tp->chain->block; struct tcf_block *block = tp->chain->block;
struct flow_cls_offload cls_flower = {};
if (!rtnl_held) if (!rtnl_held)
rtnl_lock(); rtnl_lock();
tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, extack); tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, extack);
cls_flower.command = TC_CLSFLOWER_DESTROY; cls_flower.command = FLOW_CLS_DESTROY;
cls_flower.cookie = (unsigned long) f; cls_flower.cookie = (unsigned long) f;
tc_setup_cb_call(block, TC_SETUP_CLSFLOWER, &cls_flower, false); tc_setup_cb_call(block, TC_SETUP_CLSFLOWER, &cls_flower, false);
@ -434,8 +434,8 @@ static int fl_hw_replace_filter(struct tcf_proto *tp,
struct netlink_ext_ack *extack) struct netlink_ext_ack *extack)
{ {
struct cls_fl_head *head = fl_head_dereference(tp); struct cls_fl_head *head = fl_head_dereference(tp);
struct tc_cls_flower_offload cls_flower = {};
struct tcf_block *block = tp->chain->block; struct tcf_block *block = tp->chain->block;
struct flow_cls_offload cls_flower = {};
bool skip_sw = tc_skip_sw(f->flags); bool skip_sw = tc_skip_sw(f->flags);
int err = 0; int err = 0;
@ -449,7 +449,7 @@ static int fl_hw_replace_filter(struct tcf_proto *tp,
} }
tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, extack); tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, extack);
cls_flower.command = TC_CLSFLOWER_REPLACE; cls_flower.command = FLOW_CLS_REPLACE;
cls_flower.cookie = (unsigned long) f; cls_flower.cookie = (unsigned long) f;
cls_flower.rule->match.dissector = &f->mask->dissector; cls_flower.rule->match.dissector = &f->mask->dissector;
cls_flower.rule->match.mask = &f->mask->key; cls_flower.rule->match.mask = &f->mask->key;
@ -498,14 +498,14 @@ static int fl_hw_replace_filter(struct tcf_proto *tp,
static void fl_hw_update_stats(struct tcf_proto *tp, struct cls_fl_filter *f, static void fl_hw_update_stats(struct tcf_proto *tp, struct cls_fl_filter *f,
bool rtnl_held) bool rtnl_held)
{ {
struct tc_cls_flower_offload cls_flower = {};
struct tcf_block *block = tp->chain->block; struct tcf_block *block = tp->chain->block;
struct flow_cls_offload cls_flower = {};
if (!rtnl_held) if (!rtnl_held)
rtnl_lock(); rtnl_lock();
tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, NULL); tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, NULL);
cls_flower.command = TC_CLSFLOWER_STATS; cls_flower.command = FLOW_CLS_STATS;
cls_flower.cookie = (unsigned long) f; cls_flower.cookie = (unsigned long) f;
cls_flower.classid = f->res.classid; cls_flower.classid = f->res.classid;
@ -1803,8 +1803,8 @@ fl_get_next_hw_filter(struct tcf_proto *tp, struct cls_fl_filter *f, bool add)
static int fl_reoffload(struct tcf_proto *tp, bool add, tc_setup_cb_t *cb, static int fl_reoffload(struct tcf_proto *tp, bool add, tc_setup_cb_t *cb,
void *cb_priv, struct netlink_ext_ack *extack) void *cb_priv, struct netlink_ext_ack *extack)
{ {
struct tc_cls_flower_offload cls_flower = {};
struct tcf_block *block = tp->chain->block; struct tcf_block *block = tp->chain->block;
struct flow_cls_offload cls_flower = {};
struct cls_fl_filter *f = NULL; struct cls_fl_filter *f = NULL;
int err; int err;
@ -1825,7 +1825,7 @@ static int fl_reoffload(struct tcf_proto *tp, bool add, tc_setup_cb_t *cb,
tc_cls_common_offload_init(&cls_flower.common, tp, f->flags, tc_cls_common_offload_init(&cls_flower.common, tp, f->flags,
extack); extack);
cls_flower.command = add ? cls_flower.command = add ?
TC_CLSFLOWER_REPLACE : TC_CLSFLOWER_DESTROY; FLOW_CLS_REPLACE : FLOW_CLS_DESTROY;
cls_flower.cookie = (unsigned long)f; cls_flower.cookie = (unsigned long)f;
cls_flower.rule->match.dissector = &f->mask->dissector; cls_flower.rule->match.dissector = &f->mask->dissector;
cls_flower.rule->match.mask = &f->mask->key; cls_flower.rule->match.mask = &f->mask->key;
@ -1869,7 +1869,7 @@ static int fl_reoffload(struct tcf_proto *tp, bool add, tc_setup_cb_t *cb,
static int fl_hw_create_tmplt(struct tcf_chain *chain, static int fl_hw_create_tmplt(struct tcf_chain *chain,
struct fl_flow_tmplt *tmplt) struct fl_flow_tmplt *tmplt)
{ {
struct tc_cls_flower_offload cls_flower = {}; struct flow_cls_offload cls_flower = {};
struct tcf_block *block = chain->block; struct tcf_block *block = chain->block;
cls_flower.rule = flow_rule_alloc(0); cls_flower.rule = flow_rule_alloc(0);
@ -1877,7 +1877,7 @@ static int fl_hw_create_tmplt(struct tcf_chain *chain,
return -ENOMEM; return -ENOMEM;
cls_flower.common.chain_index = chain->index; cls_flower.common.chain_index = chain->index;
cls_flower.command = TC_CLSFLOWER_TMPLT_CREATE; cls_flower.command = FLOW_CLS_TMPLT_CREATE;
cls_flower.cookie = (unsigned long) tmplt; cls_flower.cookie = (unsigned long) tmplt;
cls_flower.rule->match.dissector = &tmplt->dissector; cls_flower.rule->match.dissector = &tmplt->dissector;
cls_flower.rule->match.mask = &tmplt->mask; cls_flower.rule->match.mask = &tmplt->mask;
@ -1895,11 +1895,11 @@ static int fl_hw_create_tmplt(struct tcf_chain *chain,
static void fl_hw_destroy_tmplt(struct tcf_chain *chain, static void fl_hw_destroy_tmplt(struct tcf_chain *chain,
struct fl_flow_tmplt *tmplt) struct fl_flow_tmplt *tmplt)
{ {
struct tc_cls_flower_offload cls_flower = {}; struct flow_cls_offload cls_flower = {};
struct tcf_block *block = chain->block; struct tcf_block *block = chain->block;
cls_flower.common.chain_index = chain->index; cls_flower.common.chain_index = chain->index;
cls_flower.command = TC_CLSFLOWER_TMPLT_DESTROY; cls_flower.command = FLOW_CLS_TMPLT_DESTROY;
cls_flower.cookie = (unsigned long) tmplt; cls_flower.cookie = (unsigned long) tmplt;
tc_setup_cb_call(block, TC_SETUP_CLSFLOWER, &cls_flower, false); tc_setup_cb_call(block, TC_SETUP_CLSFLOWER, &cls_flower, false);