Hello,
This is RFC v3 to allow AMD IBS to regular users on the default settings
where kernel-level profiling is disabled (perf_event_paranoid=2).
Currently AMD IBS doesn't allow any kind of exclusion in the event
attribute. But users needs to set attr.exclude_kernel to open an event
on such an environment.
v4 changes)
* remove RFC tag
* fix sysfs attribute for ibs_fetch/format (Ravi)
* handle exclude_hv as well, so ":u" modifier would work for IBS
* add Acked and Reviewed-by from Kyle and Madhavan
v3 https://lore.kernel.org/lkml/20240905031027.2567913-1-namhyung@kernel.org
* fix build on s390
* add swfilt format for attr.config2
* count powerpc core-book3s dropped samples
v2) https://lore.kernel.org/lkml/20240830232910.1839548-1-namhyung@kernel.org/
* add PERF_FORMAT_DROPPED
* account dropped sw events and from BPF handler
* use precise RIP from IBS record
v1) https://lore.kernel.org/lkml/20240822230816.564262-1-namhyung@kernel.org/
While IBS doesn't support hardware level privilege filters, the kernel
can allow the event and drop samples belongs to the kernel like in the
software events. This is limited but it still contains precise samples
which is important for various analysis like data type profiling.
This version added format/swfilt file in sysfs to expose the software
filtering by setting the attribute config2 value. I think it's easier
to add a new config rather than adding a new PMU in order to handle
event multiplexing across IBS PMU. Users can use the perf tool to
enable this feature manually like below. Probably the perf tool can
handle this automatically in the future.
$ perf record -e ibs_op/swfilt=1/u $PROG
In order to count those dropped samples correctly, I'd propose a new
read format PERF_FORMAT_DROPPED same as we did for the lost samples.
With this, it can count dropped samples in the software events and
from the BPF overflow handler as well.
Let me know what you think.
Thanks,
Namhyung
Namhyung Kim (5):
perf/core: Add PERF_FORMAT_DROPPED
perf/core: Export perf_exclude_event()
perf/core: Account dropped samples from BPF
perf/powerpc: Count dropped samples in core-book3s PMU
perf/x86: Relax privilege filter restriction on AMD IBS
arch/powerpc/perf/core-book3s.c | 4 ++-
arch/s390/kernel/perf_cpum_sf.c | 8 +++--
arch/x86/events/amd/ibs.c | 59 +++++++++++++++++++++++----------
include/linux/perf_event.h | 7 ++++
include/uapi/linux/perf_event.h | 5 ++-
kernel/events/core.c | 27 ++++++++++++---
6 files changed, 82 insertions(+), 28 deletions(-)
base-commit: de20037e1b3c2f2ca97b8c12b8c7bca8abd509a7
--
2.47.0.105.g07ac214952-goog