On Thu, Jul 23, 2015 at 3:21 AM, Michael Ellerman <m...@ellerman.id.au> wrote: > The seccomp_bpf test uses BPF_LD|BPF_W|BPF_ABS to load 32-bit values > from seccomp_data->args. On big endian machines this will load the high > word of the argument, which is not what the test wants. > > Borrow a hack from samples/seccomp/bpf-helper.h which changes the offset > on big endian to account for this. > > Signed-off-by: Michael Ellerman <m...@ellerman.id.au>
Acked-by: Kees Cook <keesc...@chromium.org> Thanks for fixing the error message! :) -Kees > --- > tools/testing/selftests/seccomp/seccomp_bpf.c | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/tools/testing/selftests/seccomp/seccomp_bpf.c > b/tools/testing/selftests/seccomp/seccomp_bpf.c > index c5abe7fd7590..2303a8dff9a2 100644 > --- a/tools/testing/selftests/seccomp/seccomp_bpf.c > +++ b/tools/testing/selftests/seccomp/seccomp_bpf.c > @@ -82,7 +82,13 @@ struct seccomp_data { > }; > #endif > > +#if __BYTE_ORDER == __LITTLE_ENDIAN > #define syscall_arg(_n) (offsetof(struct seccomp_data, args[_n])) > +#elif __BYTE_ORDER == __BIG_ENDIAN > +#define syscall_arg(_n) (offsetof(struct seccomp_data, args[_n]) + > sizeof(__u32)) > +#else > +#error "wut? Unknown __BYTE_ORDER?!" > +#endif > > #define SIBLING_EXIT_UNKILLED 0xbadbeef > #define SIBLING_EXIT_FAILURE 0xbadface > -- > 2.1.0 > -- Kees Cook Chrome OS Security _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev