forked from luck/tmp_suning_uos_patched
libbpf: Fix endianness detection in BPF_CORE_READ_BITFIELD_PROBED()
[ Upstream commit 45f2bebc8079788f62f22d9e8b2819afb1789d7b ]
__BYTE_ORDER is supposed to be defined by a libc, and __BYTE_ORDER__ -
by a compiler. bpf_core_read.h checks __BYTE_ORDER == __LITTLE_ENDIAN,
which is true if neither are defined, leading to incorrect behavior on
big-endian hosts if libc headers are not included, which is often the
case.
Fixes: ee26dade0e
("libbpf: Add support for relocatable bitfields")
Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20211026010831.748682-2-iii@linux.ibm.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
227efdda51
commit
3925134eff
|
@ -40,7 +40,7 @@ enum bpf_enum_value_kind {
|
||||||
#define __CORE_RELO(src, field, info) \
|
#define __CORE_RELO(src, field, info) \
|
||||||
__builtin_preserve_field_info((src)->field, BPF_FIELD_##info)
|
__builtin_preserve_field_info((src)->field, BPF_FIELD_##info)
|
||||||
|
|
||||||
#if __BYTE_ORDER == __LITTLE_ENDIAN
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
||||||
#define __CORE_BITFIELD_PROBE_READ(dst, src, fld) \
|
#define __CORE_BITFIELD_PROBE_READ(dst, src, fld) \
|
||||||
bpf_probe_read_kernel( \
|
bpf_probe_read_kernel( \
|
||||||
(void *)dst, \
|
(void *)dst, \
|
||||||
|
|
Loading…
Reference in New Issue
Block a user