Em Mon, Feb 10, 2020 at 05:17:51PM +0100, Jiri Olsa escreveu: > On Mon, Feb 10, 2020 at 04:51:08PM +0100, Björn Töpel wrote: > > On Sat, 8 Feb 2020 at 16:42, Jiri Olsa <jolsa@xxxxxxxxxx> wrote: > > > this patchset adds trampoline and dispatcher objects > > > to be visible in /proc/kallsyms. The last patch also > > > adds sorting for all bpf objects in /proc/kallsyms. > > Thanks for working on this! > > I'm probably missing something with my perf setup; I've applied your > > patches, and everything seem to work fine from an kallsyms > > perspective: > > # grep bpf_dispatcher_xdp /proc/kallsyms > > ... > > ffffffffc0511000 t bpf_dispatcher_xdp [bpf] > > > > However, when I run > > # perf top > > > > I still see the undecorated one: > > 0.90% [unknown] [k] 0xffffffffc0511037 > > > > Any ideas? > yea strange.. it should be picked up from /proc/kallsyms as > fallback if there's no other source, I'll check on that > (might be the problem with perf depending on address going > only higher in /proc/kallsyms, while bpf symbols are at the > end and start over from the lowest bpf address) > > anyway, in perf we enumerate bpf_progs via the perf events > PERF_BPF_EVENT_PROG_LOAD,PERF_BPF_EVENT_PROG_UNLOAD interface > together with PERF_RECORD_KSYMBOL_TYPE_BPF events > > we might need to add something like: > PERF_RECORD_KSYMBOL_TYPE_BPF_TRAMPOLINE > PERF_RECORD_KSYMBOL_TYPE_BPF_DISPATCHER > > to notify about the area, I'll check on that > > however the /proc/kallsyms fallback should work in any > case.. thanks for report ;-) We should by now move kallsyms to be the preferred source of symbols, not vmlinux, right? Perhaps what is happening is: [root@quaco ~]# strace -f -e open,openat -o /tmp/bla perf top [root@quaco ~]# grep vmlinux /tmp/bla 11013 openat(AT_FDCWD, "vmlinux", O_RDONLY) = -1 ENOENT (No such file or directory) 11013 openat(AT_FDCWD, "/boot/vmlinux", O_RDONLY) = -1 ENOENT (No such file or directory) 11013 openat(AT_FDCWD, "/boot/vmlinux-5.5.0+", O_RDONLY) = -1 ENOENT (No such file or directory) 11013 openat(AT_FDCWD, "/usr/lib/debug/boot/vmlinux-5.5.0+", O_RDONLY) = -1 ENOENT (No such file or directory) 11013 openat(AT_FDCWD, "/lib/modules/5.5.0+/build/vmlinux", O_RDONLY) = 152 [root@quaco ~]# I.e. it is using vmlinux for resolving symbols and he should try with: [root@quaco ~]# strace -f -e open,openat -o /tmp/bla perf top --ignore-vmlinux [root@quaco ~]# perf top -h vmlinux Usage: perf top [<options>] -k, --vmlinux <file> vmlinux pathname --ignore-vmlinux don't load vmlinux even if found [root@quaco ~]# grep vmlinux /tmp/bla [root@quaco ~]# Historically vmlinux was preferred because it contains function sizes, but with all these out of the blue symbols, we need to prefer starting with /proc/kallsyms and, as we do now, continue getting updates via PERF_RECORD_KSYMBOL. Humm, but then trampolines don't generate that, right? Or does it? If it doesn't, then we will know about just the trampolines in place when the record/top session starts, reparsing /proc/kallsyms periodically seems excessive? - Arnaldo