diff options
author | Kumar Kartikeya Dwivedi <memxor@gmail.com> | 2021-10-02 03:17:56 +0200 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2021-10-06 02:07:42 +0200 |
commit | 18f4fccbf314fdb07d276f4cd3eaf53f1825550d (patch) | |
tree | aa75df537590490fe9cd09ec10265cc2ab1c4d3d /net | |
parent | libbpf: Resolve invalid weak kfunc calls with imm = 0, off = 0 (diff) | |
download | linux-18f4fccbf314fdb07d276f4cd3eaf53f1825550d.tar.xz linux-18f4fccbf314fdb07d276f4cd3eaf53f1825550d.zip |
libbpf: Update gen_loader to emit BTF_KIND_FUNC relocations
This change updates the BPF syscall loader to relocate BTF_KIND_FUNC
relocations, with support for weak kfunc relocations. The general idea
is to move map_fds to loader map, and also use the data for storing
kfunc BTF fds. Since both reuse the fd_array parameter, they need to be
kept together.
For map_fds, we reserve MAX_USED_MAPS slots in a region, and for kfunc,
we reserve MAX_KFUNC_DESCS. This is done so that insn->off has more
chances of being <= INT16_MAX than treating data map as a sparse array
and adding fd as needed.
When the MAX_KFUNC_DESCS limit is reached, we fall back to the sparse
array model, so that as long as it does remain <= INT16_MAX, we pass an
index relative to the start of fd_array.
We store all ksyms in an array where we try to avoid calling the
bpf_btf_find_by_name_kind helper, and also reuse the BTF fd that was
already stored. This also speeds up the loading process compared to
emitting calls in all cases, in later tests.
Signed-off-by: Kumar Kartikeya Dwivedi <memxor@gmail.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Link: https://lore.kernel.org/bpf/20211002011757.311265-9-memxor@gmail.com
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions