The ENOTSUPP (which actually should be EOPNOTSUPP for user space) does not trigger a fallback event selection, for example, by perf record. If hardware support for the cycles perf event is available, but the hardware does not provide interrupts, returning ENOTSUPP causes perf to end. Returning ENOENT causes the perf tool to fallback to a software-based cycle PMU that supports interrupts. The commit 53b25335dd ("perf: Disable sampled events if no PMU interrupt") introduced that incompatible change. Reported-by: Michael Holzheu <holzheu@xxxxxxxxxxxxxxxxxx> Signed-off-by: Hendrik Brueckner <brueckner@xxxxxxxxxxxxxxxxxx> --- kernel/events/core.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/kernel/events/core.c b/kernel/events/core.c index eddf1ed..4c66465 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -7964,7 +7964,7 @@ SYSCALL_DEFINE5(perf_event_open, if (is_sampling_event(event)) { if (event->pmu->capabilities & PERF_PMU_CAP_NO_INTERRUPT) { - err = -ENOTSUPP; + err = -ENOENT; goto err_alloc; } } -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-s390" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html