libbpf: Preserve kernel error code and remove kprobe prog type guessing
authorAndrii Nakryiko <andrii@kernel.org>
Thu, 9 Dec 2021 19:38:34 +0000 (11:38 -0800)
committerAndrii Nakryiko <andrii@kernel.org>
Fri, 10 Dec 2021 23:29:18 +0000 (15:29 -0800)
Instead of rewriting error code returned by the kernel of prog load with
libbpf-sepcific variants pass through the original error.

There is now also no need to have a backup generic -LIBBPF_ERRNO__LOAD
fallback error as bpf_prog_load() guarantees that errno will be properly
set no matter what.

Also drop a completely outdated and pretty useless BPF_PROG_TYPE_KPROBE
guess logic. It's not necessary and neither it's helpful in modern BPF
applications.

Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Link: https://lore.kernel.org/bpf/20211209193840.1248570-7-andrii@kernel.org
tools/lib/bpf/libbpf.c

index f07ff39a9d2085f51aa66cd7513976aed030f7ce..3fd4e3d5a11fc80b370a9f47e2c2c24701a75688 100644 (file)
@@ -6696,34 +6696,19 @@ retry_load:
                free(log_buf);
                goto retry_load;
        }
-       ret = errno ? -errno : -LIBBPF_ERRNO__LOAD;
+
+       ret = -errno;
        cp = libbpf_strerror_r(errno, errmsg, sizeof(errmsg));
        pr_warn("prog '%s': BPF program load failed: %s\n", prog->name, cp);
        pr_perm_msg(ret);
 
        if (log_buf && log_buf[0] != '\0') {
-               ret = -LIBBPF_ERRNO__VERIFY;
                pr_warn("prog '%s': -- BEGIN PROG LOAD LOG --\n%s-- END PROG LOAD LOG --\n",
                        prog->name, log_buf);
        }
        if (insns_cnt >= BPF_MAXINSNS) {
                pr_warn("prog '%s': program too large (%d insns), at most %d insns\n",
                        prog->name, insns_cnt, BPF_MAXINSNS);
-               ret = -LIBBPF_ERRNO__PROG2BIG;
-       } else if (prog->type != BPF_PROG_TYPE_KPROBE) {
-               /* Wrong program type? */
-               int fd;
-
-               load_attr.expected_attach_type = 0;
-               load_attr.log_buf = NULL;
-               load_attr.log_size = 0;
-               fd = bpf_prog_load(BPF_PROG_TYPE_KPROBE, prog_name, license,
-                                  insns, insns_cnt, &load_attr);
-               if (fd >= 0) {
-                       close(fd);
-                       ret = -LIBBPF_ERRNO__PROGTYPE;
-                       goto out;
-               }
        }
 
 out: