]> git.baikalelectronics.ru Git - kernel.git/commit
libbpf: Support CO-RE relocations for LDX/ST/STX instructions
authorAndrii Nakryiko <andriin@fb.com>
Mon, 23 Dec 2019 18:03:05 +0000 (10:03 -0800)
committerDaniel Borkmann <daniel@iogearbox.net>
Thu, 26 Dec 2019 09:31:44 +0000 (10:31 +0100)
commit15e3f2fdc3096f5123c2d1f236d6a966f25e8646
treeca2dd1d41f6f6e3a13c7fafd9435a5adde257e75
parent6a14fc6fd0182ada8b9ec386a74ef213c34a05aa
libbpf: Support CO-RE relocations for LDX/ST/STX instructions

Clang patch [0] enables emitting relocatable generic ALU/ALU64 instructions
(i.e, shifts and arithmetic operations), as well as generic load/store
instructions. The former ones are already supported by libbpf as is. This
patch adds further support for load/store instructions. Relocatable field
offset is encoded in BPF instruction's 16-bit offset section and are adjusted
by libbpf based on target kernel BTF.

These Clang changes and corresponding libbpf changes allow for more succinct
generated BPF code by encoding relocatable field reads as a single
ST/LDX/STX instruction. It also enables relocatable access to BPF context.
Previously, if context struct (e.g., __sk_buff) was accessed with CO-RE
relocations (e.g., due to preserve_access_index attribute), it would be
rejected by BPF verifier due to modified context pointer dereference. With
Clang patch, such context accesses are both relocatable and have a fixed
offset from the point of view of BPF verifier.

  [0] https://reviews.llvm.org/D71790

Signed-off-by: Andrii Nakryiko <andriin@fb.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Acked-by: Yonghong Song <yhs@fb.com>
Link: https://lore.kernel.org/bpf/20191223180305.86417-1-andriin@fb.com
tools/lib/bpf/libbpf.c