Commit e2b2cd59 authored by Jiri Olsa's avatar Jiri Olsa Committed by Andrii Nakryiko

bpf: Add missed value to kprobe_multi link info

Add missed value to kprobe_multi link info to hold the stats of missed
kprobe_multi probe.

The missed counter gets incremented when fprobe fails the recursion
check or there's no rethook available for return probe. In either
case the attached bpf program is not executed.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Tested-by: default avatarSong Liu <song@kernel.org>
Reviewed-by: default avatarSong Liu <song@kernel.org>
Acked-by: default avatarHou Tao <houtao1@huawei.com>
Link: https://lore.kernel.org/bpf/20230920213145.1941596-3-jolsa@kernel.org
parent f915fcb3
...@@ -6532,6 +6532,7 @@ struct bpf_link_info { ...@@ -6532,6 +6532,7 @@ struct bpf_link_info {
__aligned_u64 addrs; __aligned_u64 addrs;
__u32 count; /* in/out: kprobe_multi function count */ __u32 count; /* in/out: kprobe_multi function count */
__u32 flags; __u32 flags;
__u64 missed;
} kprobe_multi; } kprobe_multi;
struct { struct {
__u32 type; /* enum bpf_perf_event_type */ __u32 type; /* enum bpf_perf_event_type */
......
...@@ -2614,6 +2614,7 @@ static int bpf_kprobe_multi_link_fill_link_info(const struct bpf_link *link, ...@@ -2614,6 +2614,7 @@ static int bpf_kprobe_multi_link_fill_link_info(const struct bpf_link *link,
kmulti_link = container_of(link, struct bpf_kprobe_multi_link, link); kmulti_link = container_of(link, struct bpf_kprobe_multi_link, link);
info->kprobe_multi.count = kmulti_link->cnt; info->kprobe_multi.count = kmulti_link->cnt;
info->kprobe_multi.flags = kmulti_link->flags; info->kprobe_multi.flags = kmulti_link->flags;
info->kprobe_multi.missed = kmulti_link->fp.nmissed;
if (!uaddrs) if (!uaddrs)
return 0; return 0;
......
...@@ -6532,6 +6532,7 @@ struct bpf_link_info { ...@@ -6532,6 +6532,7 @@ struct bpf_link_info {
__aligned_u64 addrs; __aligned_u64 addrs;
__u32 count; /* in/out: kprobe_multi function count */ __u32 count; /* in/out: kprobe_multi function count */
__u32 flags; __u32 flags;
__u64 missed;
} kprobe_multi; } kprobe_multi;
struct { struct {
__u32 type; /* enum bpf_perf_event_type */ __u32 type; /* enum bpf_perf_event_type */
......
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