Commit a83d6e76 authored by Martin KaFai Lau's avatar Martin KaFai Lau Committed by Alexei Starovoitov

bpf: libbpf: Fix bpf_program__next() API

This patch restores the behavior in
commit eac7d845 ("tools: libbpf: don't return '.text' as a program for multi-function programs")
such that bpf_program__next() does not return pseudo programs in ".text".

Fixes: 0c19a9fb ("libbpf: cleanup after partial failure in bpf_object__pin")
Signed-off-by: default avatarMartin KaFai Lau <kafai@fb.com>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parent 5c86d212
...@@ -2193,19 +2193,25 @@ void *bpf_object__priv(struct bpf_object *obj) ...@@ -2193,19 +2193,25 @@ void *bpf_object__priv(struct bpf_object *obj)
} }
static struct bpf_program * static struct bpf_program *
__bpf_program__iter(struct bpf_program *p, struct bpf_object *obj, int i) __bpf_program__iter(struct bpf_program *p, struct bpf_object *obj, bool forward)
{ {
size_t nr_programs = obj->nr_programs;
ssize_t idx; ssize_t idx;
if (!obj->programs) if (!nr_programs)
return NULL; return NULL;
if (!p)
/* Iter from the beginning */
return forward ? &obj->programs[0] :
&obj->programs[nr_programs - 1];
if (p->obj != obj) { if (p->obj != obj) {
pr_warning("error: program handler doesn't match object\n"); pr_warning("error: program handler doesn't match object\n");
return NULL; return NULL;
} }
idx = (p - obj->programs) + i; idx = (p - obj->programs) + (forward ? 1 : -1);
if (idx >= obj->nr_programs || idx < 0) if (idx >= obj->nr_programs || idx < 0)
return NULL; return NULL;
return &obj->programs[idx]; return &obj->programs[idx];
...@@ -2216,11 +2222,8 @@ bpf_program__next(struct bpf_program *prev, struct bpf_object *obj) ...@@ -2216,11 +2222,8 @@ bpf_program__next(struct bpf_program *prev, struct bpf_object *obj)
{ {
struct bpf_program *prog = prev; struct bpf_program *prog = prev;
if (prev == NULL)
return obj->programs;
do { do {
prog = __bpf_program__iter(prog, obj, 1); prog = __bpf_program__iter(prog, obj, true);
} while (prog && bpf_program__is_function_storage(prog, obj)); } while (prog && bpf_program__is_function_storage(prog, obj));
return prog; return prog;
...@@ -2231,14 +2234,8 @@ bpf_program__prev(struct bpf_program *next, struct bpf_object *obj) ...@@ -2231,14 +2234,8 @@ bpf_program__prev(struct bpf_program *next, struct bpf_object *obj)
{ {
struct bpf_program *prog = next; struct bpf_program *prog = next;
if (next == NULL) {
if (!obj->nr_programs)
return NULL;
return obj->programs + obj->nr_programs - 1;
}
do { do {
prog = __bpf_program__iter(prog, obj, -1); prog = __bpf_program__iter(prog, obj, false);
} while (prog && bpf_program__is_function_storage(prog, obj)); } while (prog && bpf_program__is_function_storage(prog, obj));
return prog; return prog;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment