diff options
author | Jean-Philippe Brucker <jean-philippe@linaro.org> | 2020-09-30 11:36:01 +0200 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2020-10-01 03:11:40 +0200 |
commit | 3effc06a4dde3e2f6ee3d82e59d97ec357802a4b (patch) | |
tree | d6edcbdaf08cf0d95cf4ff3613ec2ef2a2cc4fbe /kernel/bpf/arraymap.c | |
parent | selftests/bpf: Test "incremental" btf_dump in C format (diff) | |
download | linux-3effc06a4dde3e2f6ee3d82e59d97ec357802a4b.tar.xz linux-3effc06a4dde3e2f6ee3d82e59d97ec357802a4b.zip |
selftests/bpf: Fix alignment of .BTF_ids
Fix a build failure on arm64, due to missing alignment information for
the .BTF_ids section:
resolve_btfids.test.o: in function `test_resolve_btfids':
tools/testing/selftests/bpf/prog_tests/resolve_btfids.c:140:(.text+0x29c): relocation truncated to fit: R_AARCH64_LDST32_ABS_LO12_NC against `.BTF_ids'
ld: tools/testing/selftests/bpf/prog_tests/resolve_btfids.c:140: warning: one possible cause of this error is that the symbol is being referenced in the indicated code as if it had a larger alignment than was declared where it was defined
In vmlinux, the .BTF_ids section is aligned to 4 bytes by vmlinux.lds.h.
In test_progs however, .BTF_ids doesn't have alignment constraints. The
arm64 linker expects the btf_id_set.cnt symbol, a u32, to be naturally
aligned but finds it misaligned and cannot apply the relocation. Enforce
alignment of .BTF_ids to 4 bytes.
Fixes: cd04b04de119 ("selftests/bpf: Add set test to resolve_btfids")
Signed-off-by: Jean-Philippe Brucker <jean-philippe@linaro.org>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Jiri Olsa <jolsa@redhat.com>
Link: https://lore.kernel.org/bpf/20200930093559.2120126-1-jean-philippe@linaro.org
Diffstat (limited to 'kernel/bpf/arraymap.c')
0 files changed, 0 insertions, 0 deletions