diff options
author | Yonghong Song <yhs@fb.com> | 2021-02-26 21:49:24 +0100 |
---|---|---|
committer | Alexei Starovoitov <ast@kernel.org> | 2021-02-26 22:23:52 +0100 |
commit | 282a0f46d6cda7cf843cd77c9b53b4d1d9e31302 (patch) | |
tree | 3c7f7f1ac22b03ed5bc01fda150434cbcc1c3d00 /kernel | |
parent | bpf: Refactor check_func_call() to allow callback function (diff) | |
download | linux-282a0f46d6cda7cf843cd77c9b53b4d1d9e31302.tar.xz linux-282a0f46d6cda7cf843cd77c9b53b4d1d9e31302.zip |
bpf: Change return value of verifier function add_subprog()
Currently, verifier function add_subprog() returns 0 for success
and negative value for failure. Change the return value
to be the subprog number for success. This functionality will be
used in the next patch to save a call to find_subprog().
Signed-off-by: Yonghong Song <yhs@fb.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Andrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20210226204924.3884848-1-yhs@fb.com
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/bpf/verifier.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c index 97e772f44cd7..dbdca49ac6cc 100644 --- a/kernel/bpf/verifier.c +++ b/kernel/bpf/verifier.c @@ -1530,7 +1530,7 @@ static int add_subprog(struct bpf_verifier_env *env, int off) } ret = find_subprog(env, off); if (ret >= 0) - return 0; + return ret; if (env->subprog_cnt >= BPF_MAX_SUBPROGS) { verbose(env, "too many subprograms\n"); return -E2BIG; @@ -1538,7 +1538,7 @@ static int add_subprog(struct bpf_verifier_env *env, int off) env->subprog_info[env->subprog_cnt++].start = off; sort(env->subprog_info, env->subprog_cnt, sizeof(env->subprog_info[0]), cmp_subprogs, NULL); - return 0; + return env->subprog_cnt - 1; } static int check_subprogs(struct bpf_verifier_env *env) |