aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/events
diff options
context:
space:
mode:
authorIngo Molnar <mingo@kernel.org>2016-09-05 06:09:59 -0400
committerIngo Molnar <mingo@kernel.org>2016-09-05 06:09:59 -0400
commit2cc538412a1ca103923ec400a339a5b3833e0280 (patch)
treec141b83e1da736c3d069ed491816d0096e1b532a /kernel/events
parent36e674a05164cdbb9d4a5b1b0b279fabae6c13bd (diff)
parent58763148758057ffc447bf990321d3ea86d199a0 (diff)
Merge branch 'perf/urgent' into perf/core, to pick up fixed and resolve conflicts
Conflicts: kernel/events/core.c Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/events')
-rw-r--r--kernel/events/core.c18
1 files changed, 13 insertions, 5 deletions
diff --git a/kernel/events/core.c b/kernel/events/core.c
index 3f07e6cfc1b6..dff00c787867 100644
--- a/kernel/events/core.c
+++ b/kernel/events/core.c
@@ -3578,10 +3578,18 @@ static int perf_event_read(struct perf_event *event, bool group)
3578 cpu_to_read = find_cpu_to_read(event, local_cpu); 3578 cpu_to_read = find_cpu_to_read(event, local_cpu);
3579 put_cpu(); 3579 put_cpu();
3580 3580
3581 ret = smp_call_function_single(cpu_to_read, __perf_event_read, &data, 1); 3581 /*
3582 /* The event must have been read from an online CPU: */ 3582 * Purposely ignore the smp_call_function_single() return
3583 WARN_ON_ONCE(ret); 3583 * value.
3584 ret = ret ? : data.ret; 3584 *
3585 * If event->oncpu isn't a valid CPU it means the event got
3586 * scheduled out and that will have updated the event count.
3587 *
3588 * Therefore, either way, we'll have an up-to-date event count
3589 * after this.
3590 */
3591 (void)smp_call_function_single(cpu_to_read, __perf_event_read, &data, 1);
3592 ret = data.ret;
3585 } else if (event->state == PERF_EVENT_STATE_INACTIVE) { 3593 } else if (event->state == PERF_EVENT_STATE_INACTIVE) {
3586 struct perf_event_context *ctx = event->ctx; 3594 struct perf_event_context *ctx = event->ctx;
3587 unsigned long flags; 3595 unsigned long flags;
@@ -6196,7 +6204,7 @@ static int __perf_pmu_output_stop(void *info)
6196{ 6204{
6197 struct perf_event *event = info; 6205 struct perf_event *event = info;
6198 struct pmu *pmu = event->pmu; 6206 struct pmu *pmu = event->pmu;
6199 struct perf_cpu_context *cpuctx = get_cpu_ptr(pmu->pmu_cpu_context); 6207 struct perf_cpu_context *cpuctx = this_cpu_ptr(pmu->pmu_cpu_context);
6200 struct remote_output ro = { 6208 struct remote_output ro = {
6201 .rb = event->rb, 6209 .rb = event->rb,
6202 }; 6210 };