On Mon, Aug 26, 2024 at 11:25:53PM +0200, Oleg Nesterov wrote: > This is offtopic, sorry for the spam, but... > > On 08/26, Jiri Olsa wrote: > > > > On Mon, Aug 26, 2024 at 01:57:52PM +0200, Oleg Nesterov wrote: > > > > > > Does bpftrace use bpf_uprobe_multi_link_attach/etc ? I guess not... > > > Then which userspace tool uses this code? ;) > > > > yes, it will trigger if you attach to multiple uprobes, like with your > > test example with: > > > > # bpftrace -p xxx -e 'uprobe:./ex:func* { printf("%d\n", pid); }' > > Hmm. I reserved the testing machine with fedora 40 to play with bpftrace. > > dummy.c: > > #include <unistd.h> > > void func1(void) {} > void func2(void) {} > > int main(void) { for (;;) pause(); } > > If I do > > # ./dummy & > # bpftrace -p $! -e 'uprobe:./dummy:func* { printf("%d\n", pid); }' > > and run > > # bpftrace -e 'kprobe:__uprobe_register { printf("%s\n", kstack); }' did you just bpftrace-ed bpftrace? ;-) on my setup I'm getting: [root@qemu ex]# ../bpftrace/build/src/bpftrace -e 'kprobe:uprobe_register { printf("%s\n", kstack); }' Attaching 1 probe... uprobe_register+1 bpf_uprobe_multi_link_attach+685 __sys_bpf+9395 __x64_sys_bpf+26 do_syscall_64+128 entry_SYSCALL_64_after_hwframe+118 I'm not sure what's bpftrace version in fedora 40, I'm using upstream build: [root@qemu ex]# ../bpftrace/build/src/bpftrace --info 2>&1 | grep uprobe_multi uprobe_multi: yes [root@qemu ex]# ../bpftrace/build/src/bpftrace --version bpftrace v0.20.0 jirka > > on another console I get > > Attaching 1 probe... > > __uprobe_register+1 > probe_event_enable+399 > perf_trace_event_init+440 > perf_uprobe_init+152 > perf_uprobe_event_init+74 > perf_try_init_event+71 > perf_event_alloc+1681 > __do_sys_perf_event_open+447 > do_syscall_64+130 > entry_SYSCALL_64_after_hwframe+118 > > __uprobe_register+1 > probe_event_enable+399 > perf_trace_event_init+440 > perf_uprobe_init+152 > perf_uprobe_event_init+74 > perf_try_init_event+71 > perf_event_alloc+1681 > __do_sys_perf_event_open+447 > do_syscall_64+130 > entry_SYSCALL_64_after_hwframe+118 > > so it seems that bpftrace doesn't use bpf_uprobe_multi_link_attach() > (called by sys_bpf(BPF_LINK_CREATE) ?) in this case. > > But again, this is offtopic, please forget. > > Oleg. >