Skip to content

Commit 803f070

Browse files
Tao ChenAlexei Starovoitov
authored andcommitted
bpf: Show precise link_type for {uprobe,kprobe}_multi fdinfo
Alexei suggested, 'link_type' can be more precise and differentiate for human in fdinfo. In fact BPF_LINK_TYPE_KPROBE_MULTI includes kretprobe_multi type, the same as BPF_LINK_TYPE_UPROBE_MULTI, so we can show it more concretely. link_type: kprobe_multi link_id: 1 prog_tag: d2b307e915f0dd37 ... link_type: kretprobe_multi link_id: 2 prog_tag: ab9ea0545870781d ... link_type: uprobe_multi link_id: 9 prog_tag: e729f789e34a8eca ... link_type: uretprobe_multi link_id: 10 prog_tag: 7db356c03e61a4d4 Co-developed-by: Jiri Olsa <[email protected]> Signed-off-by: Jiri Olsa <[email protected]> Signed-off-by: Tao Chen <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Alexei Starovoitov <[email protected]>
1 parent 1f24c0d commit 803f070

File tree

3 files changed

+13
-7
lines changed

3 files changed

+13
-7
lines changed

include/linux/bpf.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1702,6 +1702,7 @@ struct bpf_link {
17021702
* link's semantics is determined by target attach hook
17031703
*/
17041704
bool sleepable;
1705+
u32 flags;
17051706
/* rcu is used before freeing, work can be used to schedule that
17061707
* RCU-based freeing before that, so they never overlap
17071708
*/

kernel/bpf/syscall.c

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3228,7 +3228,14 @@ static void bpf_link_show_fdinfo(struct seq_file *m, struct file *filp)
32283228
char prog_tag[sizeof(prog->tag) * 2 + 1] = { };
32293229

32303230
if (type < ARRAY_SIZE(bpf_link_type_strs) && bpf_link_type_strs[type]) {
3231-
seq_printf(m, "link_type:\t%s\n", bpf_link_type_strs[type]);
3231+
if (link->type == BPF_LINK_TYPE_KPROBE_MULTI)
3232+
seq_printf(m, "link_type:\t%s\n", link->flags == BPF_F_KPROBE_MULTI_RETURN ?
3233+
"kretprobe_multi" : "kprobe_multi");
3234+
else if (link->type == BPF_LINK_TYPE_UPROBE_MULTI)
3235+
seq_printf(m, "link_type:\t%s\n", link->flags == BPF_F_UPROBE_MULTI_RETURN ?
3236+
"uretprobe_multi" : "uprobe_multi");
3237+
else
3238+
seq_printf(m, "link_type:\t%s\n", bpf_link_type_strs[type]);
32323239
} else {
32333240
WARN_ONCE(1, "missing BPF_LINK_TYPE(...) for link type %u\n", type);
32343241
seq_printf(m, "link_type:\t<%u>\n", type);

kernel/trace/bpf_trace.c

Lines changed: 4 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -2466,7 +2466,6 @@ struct bpf_kprobe_multi_link {
24662466
u32 cnt;
24672467
u32 mods_cnt;
24682468
struct module **mods;
2469-
u32 flags;
24702469
};
24712470

24722471
struct bpf_kprobe_multi_run_ctx {
@@ -2586,7 +2585,7 @@ static int bpf_kprobe_multi_link_fill_link_info(const struct bpf_link *link,
25862585

25872586
kmulti_link = container_of(link, struct bpf_kprobe_multi_link, link);
25882587
info->kprobe_multi.count = kmulti_link->cnt;
2589-
info->kprobe_multi.flags = kmulti_link->flags;
2588+
info->kprobe_multi.flags = kmulti_link->link.flags;
25902589
info->kprobe_multi.missed = kmulti_link->fp.nmissed;
25912590

25922591
if (!uaddrs)
@@ -2976,7 +2975,7 @@ int bpf_kprobe_multi_link_attach(const union bpf_attr *attr, struct bpf_prog *pr
29762975
link->addrs = addrs;
29772976
link->cookies = cookies;
29782977
link->cnt = cnt;
2979-
link->flags = flags;
2978+
link->link.flags = flags;
29802979

29812980
if (cookies) {
29822981
/*
@@ -3045,7 +3044,6 @@ struct bpf_uprobe_multi_link {
30453044
struct path path;
30463045
struct bpf_link link;
30473046
u32 cnt;
3048-
u32 flags;
30493047
struct bpf_uprobe *uprobes;
30503048
struct task_struct *task;
30513049
};
@@ -3109,7 +3107,7 @@ static int bpf_uprobe_multi_link_fill_link_info(const struct bpf_link *link,
31093107

31103108
umulti_link = container_of(link, struct bpf_uprobe_multi_link, link);
31113109
info->uprobe_multi.count = umulti_link->cnt;
3112-
info->uprobe_multi.flags = umulti_link->flags;
3110+
info->uprobe_multi.flags = umulti_link->link.flags;
31133111
info->uprobe_multi.pid = umulti_link->task ?
31143112
task_pid_nr_ns(umulti_link->task, task_active_pid_ns(current)) : 0;
31153113

@@ -3369,7 +3367,7 @@ int bpf_uprobe_multi_link_attach(const union bpf_attr *attr, struct bpf_prog *pr
33693367
link->uprobes = uprobes;
33703368
link->path = path;
33713369
link->task = task;
3372-
link->flags = flags;
3370+
link->link.flags = flags;
33733371

33743372
bpf_link_init(&link->link, BPF_LINK_TYPE_UPROBE_MULTI,
33753373
&bpf_uprobe_multi_link_lops, prog);

0 commit comments

Comments
 (0)