libbpf: Make BTF finalization strict

With valid ELF and valid BTF, there is no reason (apart from bugs) why BTF
finalization should fail. So make it strict and return error if it fails. This
makes CO-RE relocation more reliable, as they are not going to be just
silently skipped, if BTF finalization failed.

Signed-off-by: Andrii Nakryiko <andriin@fb.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/20200708015318.3827358-2-andriin@fb.com
This commit is contained in:
Andrii Nakryiko 2020-07-07 18:53:13 -07:00 committed by Daniel Borkmann
parent b8c50df0cb
commit bfc96656a7
1 changed files with 4 additions and 12 deletions

View File

@ -2473,19 +2473,11 @@ static int bpf_object__finalize_btf(struct bpf_object *obj)
return 0; return 0;
err = btf__finalize_data(obj, obj->btf); err = btf__finalize_data(obj, obj->btf);
if (!err) if (err) {
return 0; pr_warn("Error finalizing %s: %d.\n", BTF_ELF_SEC, err);
return err;
pr_warn("Error finalizing %s: %d.\n", BTF_ELF_SEC, err);
btf__free(obj->btf);
obj->btf = NULL;
btf_ext__free(obj->btf_ext);
obj->btf_ext = NULL;
if (libbpf_needs_btf(obj)) {
pr_warn("BTF is required, but is missing or corrupted.\n");
return -ENOENT;
} }
return 0; return 0;
} }