]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
net/sched: act_mirred: Add new tc_action_ops get_dev()
authorHadar Hen Zion <hadarh@mellanox.com>
Thu, 1 Dec 2016 12:06:36 +0000 (14:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Fri, 2 Dec 2016 18:28:36 +0000 (13:28 -0500)
Adding support to a new tc_action_ops.
get_dev is a general option which allows to get the underline
device when trying to offload a tc rule.

In case of mirred action the returned device is the mirred (egress)
device.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Reviewed-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/act_api.h
net/sched/act_mirred.c

index d8eae87ea77830211153be694abcacec133fbc6b..9dddf77a69ccbcb003cfa66bcc0de337f78f3dae 100644 (file)
@@ -119,6 +119,8 @@ struct tc_action_ops {
        int     (*walk)(struct net *, struct sk_buff *,
                        struct netlink_callback *, int, const struct tc_action_ops *);
        void    (*stats_update)(struct tc_action *, u64, u32, u64);
+       int     (*get_dev)(const struct tc_action *a, struct net *net,
+                          struct net_device **mirred_dev);
 };
 
 struct tc_action_net {
index 1af7baa732a362ad1bbe107039c93ed91f0f73f9..bb09ba3ca5c29bc282d19d928ed3f12fb8f0d5c1 100644 (file)
@@ -315,6 +315,17 @@ static struct notifier_block mirred_device_notifier = {
        .notifier_call = mirred_device_event,
 };
 
+static int tcf_mirred_device(const struct tc_action *a, struct net *net,
+                            struct net_device **mirred_dev)
+{
+       int ifindex = tcf_mirred_ifindex(a);
+
+       *mirred_dev = __dev_get_by_index(net, ifindex);
+       if (!mirred_dev)
+               return -EINVAL;
+       return 0;
+}
+
 static struct tc_action_ops act_mirred_ops = {
        .kind           =       "mirred",
        .type           =       TCA_ACT_MIRRED,
@@ -327,6 +338,7 @@ static struct tc_action_ops act_mirred_ops = {
        .walk           =       tcf_mirred_walker,
        .lookup         =       tcf_mirred_search,
        .size           =       sizeof(struct tcf_mirred),
+       .get_dev        =       tcf_mirred_device,
 };
 
 static __net_init int mirred_init_net(struct net *net)