]> git.proxmox.com Git - mirror_iproute2.git/commitdiff
iplink: communicate ifindex for xdp offload
authorJakub Kicinski <jakub.kicinski@netronome.com>
Fri, 24 Nov 2017 02:12:08 +0000 (18:12 -0800)
committerStephen Hemminger <stephen@networkplumber.org>
Sun, 26 Nov 2017 19:57:58 +0000 (11:57 -0800)
When xdpoffload option is used, communicate the ifindex down
to the kernel to trigger device-specific load.

Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com>
Reviewed-by: Quentin Monnet <quentin.monnet@netronome.com>
Acked-by: Daniel Borkmann <daniel@iogearbox.net>
ip/iplink.c
ip/iplink_xdp.c
ip/xdp.h

index 2c51ef7dd272b2efc10711181f781f0b704cf80c..0a8eb56fb252822fa38082ec69ef0323abb78976 100644 (file)
@@ -631,8 +631,8 @@ int iplink_parse(int argc, char **argv, struct iplink_req *req,
                        bool offload = strcmp(*argv, "xdpoffload") == 0;
 
                        NEXT_ARG();
-                       if (xdp_parse(&argc, &argv, req, generic, drv,
-                                     offload))
+                       if (xdp_parse(&argc, &argv, req, dev_index,
+                                     generic, drv, offload))
                                exit(-1);
                } else if (strcmp(*argv, "netns") == 0) {
                        NEXT_ARG();
index edaec2a250e79526895c7f226b5bdc21cfad7c09..6eeb820af0c34fed6267bfb2c6e33b9c59b28d2e 100644 (file)
@@ -48,8 +48,8 @@ static int xdp_delete(struct xdp_req *xdp)
        return 0;
 }
 
-int xdp_parse(int *argc, char ***argv, struct iplink_req *req, bool generic,
-             bool drv, bool offload)
+int xdp_parse(int *argc, char ***argv, struct iplink_req *req, __u32 ifindex,
+             bool generic, bool drv, bool offload)
 {
        struct bpf_cfg_in cfg = {
                .type = BPF_PROG_TYPE_XDP,
@@ -60,6 +60,12 @@ int xdp_parse(int *argc, char ***argv, struct iplink_req *req, bool generic,
                .req = req,
        };
 
+       if (offload) {
+               if (!ifindex)
+                       incomplete_command();
+               cfg.ifindex = ifindex;
+       }
+
        if (!force)
                xdp.flags |= XDP_FLAGS_UPDATE_IF_NOEXIST;
        if (generic)
index 215a6dcb9e9050238e88d097c06483b601ba36d4..7e10696adafbce2efd78496af26df7da64c78aee 100644 (file)
--- a/ip/xdp.h
+++ b/ip/xdp.h
@@ -4,8 +4,8 @@
 
 #include "utils.h"
 
-int xdp_parse(int *argc, char ***argv, struct iplink_req *req, bool generic,
-             bool drv, bool offload);
+int xdp_parse(int *argc, char ***argv, struct iplink_req *req, __u32 ifindex,
+             bool generic, bool drv, bool offload);
 void xdp_dump(FILE *fp, struct rtattr *tb, bool link, bool details);
 
 #endif /* __XDP__ */