Commit e56185c7 authored by John Hurley's avatar John Hurley Committed by David S. Miller

net: sched: add tcf_proto_op to offload a rule

Create a new tcf_proto_op called 'reoffload' that generates a new offload
message for each node in a tcf_proto. Pointers to the tcf_proto and
whether the offload request is to add or delete the node are included.
Also included is a callback function to send the offload message to and
the option of priv data to go with the cb.
Signed-off-by: default avatarJohn Hurley <john.hurley@netronome.com>
Signed-off-by: default avatarJakub Kicinski <jakub.kicinski@netronome.com>
Acked-by: default avatarJiri Pirko <jiri@mellanox.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 60513bd8
...@@ -190,9 +190,6 @@ static inline void tcf_action_stats_update(struct tc_action *a, u64 bytes, ...@@ -190,9 +190,6 @@ static inline void tcf_action_stats_update(struct tc_action *a, u64 bytes,
#endif #endif
} }
typedef int tc_setup_cb_t(enum tc_setup_type type,
void *type_data, void *cb_priv);
#ifdef CONFIG_NET_CLS_ACT #ifdef CONFIG_NET_CLS_ACT
int tc_setup_cb_egdev_register(const struct net_device *dev, int tc_setup_cb_egdev_register(const struct net_device *dev,
tc_setup_cb_t *cb, void *cb_priv); tc_setup_cb_t *cb, void *cb_priv);
......
...@@ -20,6 +20,9 @@ struct qdisc_walker; ...@@ -20,6 +20,9 @@ struct qdisc_walker;
struct tcf_walker; struct tcf_walker;
struct module; struct module;
typedef int tc_setup_cb_t(enum tc_setup_type type,
void *type_data, void *cb_priv);
struct qdisc_rate_table { struct qdisc_rate_table {
struct tc_ratespec rate; struct tc_ratespec rate;
u32 data[256]; u32 data[256];
...@@ -256,6 +259,9 @@ struct tcf_proto_ops { ...@@ -256,6 +259,9 @@ struct tcf_proto_ops {
bool *last, bool *last,
struct netlink_ext_ack *); struct netlink_ext_ack *);
void (*walk)(struct tcf_proto*, struct tcf_walker *arg); void (*walk)(struct tcf_proto*, struct tcf_walker *arg);
int (*reoffload)(struct tcf_proto *tp, bool add,
tc_setup_cb_t *cb, void *cb_priv,
struct netlink_ext_ack *extack);
void (*bind_class)(void *, u32, unsigned long); void (*bind_class)(void *, u32, unsigned long);
/* rtnetlink specific */ /* rtnetlink specific */
......
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