diff mbox

[ovs-dev,V11,25/33] netdev-tc-offloads: Add ingress on netdev flow api init

Message ID 1497366235-20892-26-git-send-email-roid@mellanox.com
State Accepted
Headers show

Commit Message

Roi Dayan June 13, 2017, 3:03 p.m. UTC
From: Paul Blakey <paulb@mellanox.com>

Signed-off-by: Paul Blakey <paulb@mellanox.com>
Reviewed-by: Roi Dayan <roid@mellanox.com>
Reviewed-by: Simon Horman <simon.horman@netronome.com>
Acked-by: Flavio Leitner <fbl@sysclose.org>
---
 lib/netdev-tc-offloads.c | 23 ++++++++++++++++++++++-
 1 file changed, 22 insertions(+), 1 deletion(-)
diff mbox

Patch

diff --git a/lib/netdev-tc-offloads.c b/lib/netdev-tc-offloads.c
index 19c4082..72f4546 100644
--- a/lib/netdev-tc-offloads.c
+++ b/lib/netdev-tc-offloads.c
@@ -33,6 +33,7 @@ 
 #include "hash.h"
 #include "dpif.h"
 #include "tc.h"
+#include "netdev-linux.h"
 
 VLOG_DEFINE_THIS_MODULE(netdev_tc_offloads);
 
@@ -921,7 +922,27 @@  netdev_tc_flow_del(struct netdev *netdev OVS_UNUSED,
 }
 
 int
-netdev_tc_init_flow_api(struct netdev *netdev OVS_UNUSED)
+netdev_tc_init_flow_api(struct netdev *netdev)
 {
+    int ifindex;
+    int error;
+
+    ifindex = netdev_get_ifindex(netdev);
+    if (ifindex < 0) {
+        VLOG_ERR_RL(&error_rl, "failed to get ifindex for %s: %s",
+                    netdev_get_name(netdev), ovs_strerror(-ifindex));
+        return -ifindex;
+    }
+
+    error = tc_add_del_ingress_qdisc(ifindex, true);
+
+    if (error && error != EEXIST) {
+        VLOG_ERR("failed adding ingress qdisc required for offloading: %s",
+                 ovs_strerror(error));
+        return error;
+    }
+
+    VLOG_INFO("added ingress qdisc to %s", netdev_get_name(netdev));
+
     return 0;
 }