Skip to content

Commit 0120982

Browse files
frankQAQ-wangNobody
authored andcommitted
libbpf: Support repeated legacy kprobes on same function
If repeated legacy kprobes on same function in one process, libbpf will register using the same probe name and got -EBUSY error. So append index to the probe name format to fix this problem. Co-developed-by: Chengming Zhou <[email protected]> Signed-off-by: Qiang Wang <[email protected]> Signed-off-by: Chengming Zhou <[email protected]>
1 parent fbdb60f commit 0120982

File tree

1 file changed

+3
-1
lines changed

1 file changed

+3
-1
lines changed

tools/lib/bpf/libbpf.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9891,7 +9891,9 @@ static int append_to_file(const char *file, const char *fmt, ...)
98919891
static void gen_kprobe_legacy_event_name(char *buf, size_t buf_sz,
98929892
const char *kfunc_name, size_t offset)
98939893
{
9894-
snprintf(buf, buf_sz, "libbpf_%u_%s_0x%zx", getpid(), kfunc_name, offset);
9894+
static int index = 0;
9895+
snprintf(buf, buf_sz, "libbpf_%u_%s_0x%zx_%d", getpid(), kfunc_name, offset
9896+
__sync_fetch_and_add(&index, 1));
98959897
}
98969898

98979899
static int add_kprobe_event_legacy(const char *probe_name, bool retprobe,

0 commit comments

Comments
 (0)