diff options
author | Ingo Molnar <mingo@kernel.org> | 2016-09-05 06:09:59 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2016-09-05 06:09:59 -0400 |
commit | 2cc538412a1ca103923ec400a339a5b3833e0280 (patch) | |
tree | c141b83e1da736c3d069ed491816d0096e1b532a /kernel/events | |
parent | 36e674a05164cdbb9d4a5b1b0b279fabae6c13bd (diff) | |
parent | 58763148758057ffc447bf990321d3ea86d199a0 (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.c | 18 |
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 | }; |