perf report can't annotate kernel and dbgsym package has wrong addresses
Affects | Status | Importance | Assigned to | Milestone | |
---|---|---|---|---|---|
linux (Ubuntu) |
Confirmed
|
Medium
|
Paolo Pisati | ||
Bionic |
New
|
Undecided
|
Unassigned | ||
Cosmic |
New
|
Undecided
|
Unassigned | ||
Disco |
Won't Fix
|
Medium
|
Paolo Pisati |
Bug Description
Impact:
Under some condition, 'perf report' is unable to show the assembly code of a kernel function (perf report -> select a kernel function -> annotate).
This is not an issue of the kernel itself or the perf tool, instead it's your environment that is missing the objdump binary (and perf, unfortunately, doesn't complain about it).
Make sure binutils is not installed, or move away the objdump binary:
# mv /usr/bin/objdump /usr/bin/
Run a perf session and write down all events:
# perf record -a -- sleep 10
# perf report
selct a kernel function, press 'Annotate', a blank screen will appears (instead of the assembly code).
Now put the objdump binary back (or install binutils):
# mv /usr/bin/
and run again perf report:
# perf report
select a kernel function, annotate, the disassembly will show up.
Fix:
Make binutils a Depends in SRCPKGNAME-
How to test:
Install a patched linux-tools-
Regression:
We are adding a new dependency on a package, so code wise there's no regression potential - on the other hand, image creation, or development environment will experience a slight increase in size (1.8MB on x86-64 and 2.1M on arm64) if they didn't install binutils already.
--
Running zesty 4.10.0-13-generic kernel and running:
$ perf record
followed by
$ perf report
results in output that can't be annotated (even when run as root). The following message appears:
Couldn't annotate do_io_submit:
No vmlinux file with build id 81ba79d482fa9e3
was found in the path.
Note that annotation using /proc/kcore requires CAP_SYS_RAWIO capability.
Please use:
perf buildid-cache -vu vmlinux
Note this is being run as root and /proc/kcore is accessible with dd from the same shell:
$ dd if=/proc/kcore bs=8 count=16 | hexdump
0000000 457f 464c 0102 0001 0000 0000 0000 0000
0000010 0004 00b7 0001 0000 0000 0000 0000 0000
0000020 0040 0000 0000 0000 0000 0000 0000 0000
0000030 0000 0000 0040 0038 0003 0000 0000 0000
0000040 0004 0000 0000 0000 00e8 0000 0000 0000
Additionally, installing the linux-image-
Changed in linux (Ubuntu): | |
importance: | Undecided → Medium |
tags: | added: kernel-da-key |
Changed in linux (Ubuntu): | |
assignee: | nobody → Paolo Pisati (p-pisati) |
description: | updated |
tags: | added: cscc |
Changed in linux (Ubuntu Disco): | |
status: | Confirmed → Won't Fix |
This bug is missing log files that will aid in diagnosing the problem. From a terminal window please run:
apport-collect 1675949
and then change the status of the bug to 'Confirmed'.
If, due to the nature of the issue you have encountered, you are unable to run this command, please add a comment stating that fact and change the bug status to 'Confirmed'.
This change has been made by an automated script, maintained by the Ubuntu Kernel Team.