summaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorIngo Molnar <mingo@kernel.org>2017-07-11 04:56:54 -0400
committerIngo Molnar <mingo@kernel.org>2017-07-11 04:56:54 -0400
commit6a8a75f3235724c5941a33e287b2f98966ad14c5 (patch)
tree92147e81256d2aa503067ee4d86bff8fb40a681f /kernel
parent1922eec4b5e2d8d6e92f87592b88477a2dbdcf16 (diff)
Revert "perf/core: Drop kernel samples even though :u is specified"
This reverts commit cc1582c231ea041fbc68861dfaf957eaf902b829. This commit introduced a regression that broke rr-project, which uses sampling events to receive a signal on overflow (but does not care about the contents of the sample). These signals are critical to the correct operation of rr. There's been some back and forth about how to fix it - but to not keep applications in limbo queue up a revert. Reported-by: Kyle Huey <me@kylehuey.com> Acked-by: Kyle Huey <me@kylehuey.com> Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Jin Yao <yao.jin@linux.intel.com> Cc: Vince Weaver <vincent.weaver@maine.edu> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Will Deacon <will.deacon@arm.com> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Stephane Eranian <eranian@google.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Jiri Olsa <jolsa@redhat.com> Cc: <stable@vger.kernel.org> Link: http://lkml.kernel.org/r/20170628105600.GC5981@leverpostej Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/events/core.c21
1 files changed, 0 insertions, 21 deletions
diff --git a/kernel/events/core.c b/kernel/events/core.c
index 4d2c32f98482..9747e422ab20 100644
--- a/kernel/events/core.c
+++ b/kernel/events/core.c
@@ -7308,21 +7308,6 @@ int perf_event_account_interrupt(struct perf_event *event)
7308 return __perf_event_account_interrupt(event, 1); 7308 return __perf_event_account_interrupt(event, 1);
7309} 7309}
7310 7310
7311static bool sample_is_allowed(struct perf_event *event, struct pt_regs *regs)
7312{
7313 /*
7314 * Due to interrupt latency (AKA "skid"), we may enter the
7315 * kernel before taking an overflow, even if the PMU is only
7316 * counting user events.
7317 * To avoid leaking information to userspace, we must always
7318 * reject kernel samples when exclude_kernel is set.
7319 */
7320 if (event->attr.exclude_kernel && !user_mode(regs))
7321 return false;
7322
7323 return true;
7324}
7325
7326/* 7311/*
7327 * Generic event overflow handling, sampling. 7312 * Generic event overflow handling, sampling.
7328 */ 7313 */
@@ -7344,12 +7329,6 @@ static int __perf_event_overflow(struct perf_event *event,
7344 ret = __perf_event_account_interrupt(event, throttle); 7329 ret = __perf_event_account_interrupt(event, throttle);
7345 7330
7346 /* 7331 /*
7347 * For security, drop the skid kernel samples if necessary.
7348 */
7349 if (!sample_is_allowed(event, regs))
7350 return ret;
7351
7352 /*
7353 * XXX event_limit might not quite work as expected on inherited 7332 * XXX event_limit might not quite work as expected on inherited
7354 * events 7333 * events
7355 */ 7334 */