Em Mon, Jun 01, 2015 at 07:37:53AM +0000, Wang Nan escreveu: > Check endianess according to EHDR. Code is taken from > tools/perf/util/symbol-elf.c. > > Libbpf doesn't magically convert missmatched endianess. See discussion > on https://lkml.org/lkml/2015/5/18/650 that, even if we swap
Please don't use URLs like this, I tried accessing this link and it seems lkml.org is not accessible now :-\ Simply avoid having URLs like this, but if you insist, then follow the Link: standard and use: http://lkml.kernel.org/r/MESSAGE-ID This way I can click on it to redirect me to some archive and if it still doesn't work, then I can google for that message-id, but the way you did I can't even google for the subject of that message :-\ BTW: this is what I get for lkml.org now: 504 Gateway Time-out nginx/1.4.6 (Ubuntu) - Arnaldo > eBPF instructions to correct byte order, we are unable to deal with > endianess in code logical generated by LLVM. > > Therefore, libbpf should simply reject missmatched ELF object, and let > LLVM to create good code. > > Signed-off-by: Wang Nan <wangn...@huawei.com> > Acked-by: Alexei Starovoitov <a...@plumgrid.com> > --- > tools/lib/bpf/libbpf.c | 30 ++++++++++++++++++++++++++++++ > 1 file changed, 30 insertions(+) > > diff --git a/tools/lib/bpf/libbpf.c b/tools/lib/bpf/libbpf.c > index 0824822..5d56c40 100644 > --- a/tools/lib/bpf/libbpf.c > +++ b/tools/lib/bpf/libbpf.c > @@ -166,6 +166,34 @@ errout: > return err; > } > > +static int > +bpf_object__check_endianess(struct bpf_object *obj) > +{ > + static unsigned int const endian = 1; > + > + switch (obj->efile.ehdr.e_ident[EI_DATA]) { > + case ELFDATA2LSB: > + /* We are big endian, BPF obj is little endian. */ > + if (*(unsigned char const *)&endian != 1) > + goto mismatch; > + break; > + > + case ELFDATA2MSB: > + /* We are little endian, BPF obj is big endian. */ > + if (*(unsigned char const *)&endian != 0) > + goto mismatch; > + break; > + default: > + return -EINVAL; > + } > + > + return 0; > + > +mismatch: > + pr_warning("Error: endianess mismatch.\n"); > + return -EINVAL; > +} > + > struct bpf_object *bpf_object__open(const char *path) > { > struct bpf_object *obj; > @@ -187,6 +215,8 @@ struct bpf_object *bpf_object__open(const char *path) > > if (bpf_object__elf_init(obj)) > goto out; > + if (bpf_object__check_endianess(obj)) > + goto out; > > bpf_object__elf_finish(obj); > return obj; > -- > 1.8.3.4 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/