On 13 Aug 2019, at 3:23, Ivan Khoronzhuk wrote: > For arm32 xdp sockets mmap2 is preferred, so use it if it's defined. > > Signed-off-by: Ivan Khoronzhuk <ivan.khoronzhuk@xxxxxxxxxx> Doesn't this change the application API? -- Jonathan > --- > samples/bpf/syscall_nrs.c | 5 +++++ > samples/bpf/tracex5_kern.c | 11 +++++++++++ > 2 files changed, 16 insertions(+) > > diff --git a/samples/bpf/syscall_nrs.c b/samples/bpf/syscall_nrs.c > index 516e255cbe8f..2dec94238350 100644 > --- a/samples/bpf/syscall_nrs.c > +++ b/samples/bpf/syscall_nrs.c > @@ -9,5 +9,10 @@ void syscall_defines(void) > COMMENT("Linux system call numbers."); > SYSNR(__NR_write); > SYSNR(__NR_read); > +#ifdef __NR_mmap2 > + SYSNR(__NR_mmap2); > +#else > SYSNR(__NR_mmap); > +#endif > + > } > diff --git a/samples/bpf/tracex5_kern.c b/samples/bpf/tracex5_kern.c > index f57f4e1ea1ec..300350ad299a 100644 > --- a/samples/bpf/tracex5_kern.c > +++ b/samples/bpf/tracex5_kern.c > @@ -68,12 +68,23 @@ PROG(SYS__NR_read)(struct pt_regs *ctx) > return 0; > } > > +#ifdef __NR_mmap2 > +PROG(SYS__NR_mmap2)(struct pt_regs *ctx) > +{ > + char fmt[] = "mmap2\n"; > + > + bpf_trace_printk(fmt, sizeof(fmt)); > + return 0; > +} > +#else > PROG(SYS__NR_mmap)(struct pt_regs *ctx) > { > char fmt[] = "mmap\n"; > + > bpf_trace_printk(fmt, sizeof(fmt)); > return 0; > } > +#endif > > char _license[] SEC("license") = "GPL"; > u32 _version SEC("version") = LINUX_VERSION_CODE; > -- > 2.17.1