On Fri, 21 Apr 2017 13:58:42 -0700 Jay Vosburgh <jay.vosburgh@xxxxxxxxxxxxx> wrote: > Johannes Berg <johannes@xxxxxxxxxxxxxxxx> wrote: > > >On Mon, 2017-04-10 at 20:35 -0700, Jay Vosburgh wrote: > >> This patch resolves build issues when compiling the samples on > >> Ubuntu 17.04 with the distro 4.10 kernel and the linux-headers > >> package > >> installed. This permits running the samples using distro packages > >> without needing to rebuild the kernel from source. > >> > >> Tested on a 17.04 VM using virtio_net. > >> > >> Signed-off-by: Jay Vosburgh <jay.vosburgh@xxxxxxxxxxxxx> > >> --- > >> > >> I haven't tried the patched version of this on a built from > >> source kernel yet, so it might break that. > > > >I was able to build on a recent Debian testing by simply inserting the > >following line into samples/bpf/Makefile to force it to use the > >kernel's UAPI instead of the installed headers: > > > >HOSTCFLAGS += -I$(srctree)/include/uapi/ -D__EXPORTED_HEADERS__ > > Getting back to this after a couple of weeks... > > The above changes didn't make any difference for me, but it > turns out all of the various Makefile hacks I did previously aren't > needed for Ubuntu 17.04, the following lets the examples build and run > fine: > > diff --git a/kernel/samples/bpf/xdp_ddos01_blacklist_cmdline.c b/kernel/samples/bpf/xdp_ddos01_blacklist_cmdline.c > index 11157f9..5cf297e 100644 > --- a/kernel/samples/bpf/xdp_ddos01_blacklist_cmdline.c > +++ b/kernel/samples/bpf/xdp_ddos01_blacklist_cmdline.c > @@ -13,7 +13,6 @@ static const char *__doc__= > #include <string.h> > #include <unistd.h> > #include <locale.h> > -#include <linux/bitops.h> This include was added by Andy in commit 888606b5accb ("samples/bpf: xdp_ddos01 add support for port blacklisting"). To Andy, are you okay with this change/patch? > #include <sys/resource.h> > #include <getopt.h> > @@ -212,7 +211,7 @@ static void blacklist_print_proto(int key, __u64 count) > printf("\n\t\"%s\" : %llu", xdp_proto_filter_names[key], count); > } > > -static void blacklist_print_port(int key, u32 val, int countfds[]) > +static void blacklist_print_port(int key, __u32 val, int countfds[]) > { > int i; > __u64 count; > -- Best regards, Jesper Dangaard Brouer MSc.CS, Principal Kernel Engineer at Red Hat LinkedIn: http://www.linkedin.com/in/brouer