samples: bpf: get ifindex from ifname

Find the ifindex with if_nametoindex() instead of requiring the
numeric ifindex.

Signed-off-by: Matteo Croce <mcroce@redhat.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
This commit is contained in:
Matteo Croce 2018-12-01 01:23:06 +01:00 коммит произвёл Alexei Starovoitov
Родитель d606ee5c1d
Коммит dc378a1ab5
1 изменённых файлов: 7 добавлений и 2 удалений

Просмотреть файл

@ -15,6 +15,7 @@
#include <unistd.h> #include <unistd.h>
#include <libgen.h> #include <libgen.h>
#include <sys/resource.h> #include <sys/resource.h>
#include <net/if.h>
#include "bpf_util.h" #include "bpf_util.h"
#include "bpf/bpf.h" #include "bpf/bpf.h"
@ -59,7 +60,7 @@ static void poll_stats(int map_fd, int interval)
static void usage(const char *prog) static void usage(const char *prog)
{ {
fprintf(stderr, fprintf(stderr,
"usage: %s [OPTS] IFINDEX\n\n" "usage: %s [OPTS] IFACE\n\n"
"OPTS:\n" "OPTS:\n"
" -S use skb-mode\n" " -S use skb-mode\n"
" -N enforce native mode\n", " -N enforce native mode\n",
@ -102,7 +103,11 @@ int main(int argc, char **argv)
return 1; return 1;
} }
ifindex = strtoul(argv[optind], NULL, 0); ifindex = if_nametoindex(argv[1]);
if (!ifindex) {
perror("if_nametoindex");
return 1;
}
snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]); snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]);
prog_load_attr.file = filename; prog_load_attr.file = filename;