aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/perf_counter.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/perf_counter.c')
-rw-r--r--kernel/perf_counter.c15
1 files changed, 5 insertions, 10 deletions
diff --git a/kernel/perf_counter.c b/kernel/perf_counter.c
index 4d8f97375f3a..64113e6d1942 100644
--- a/kernel/perf_counter.c
+++ b/kernel/perf_counter.c
@@ -1120,8 +1120,7 @@ void perf_counter_task_tick(struct task_struct *curr, int cpu)
1120 __perf_counter_task_sched_out(ctx); 1120 __perf_counter_task_sched_out(ctx);
1121 1121
1122 rotate_ctx(&cpuctx->ctx); 1122 rotate_ctx(&cpuctx->ctx);
1123 if (ctx->rr_allowed) 1123 rotate_ctx(ctx);
1124 rotate_ctx(ctx);
1125 1124
1126 perf_counter_cpu_sched_in(cpuctx, cpu); 1125 perf_counter_cpu_sched_in(cpuctx, cpu);
1127 perf_counter_task_sched_in(curr, cpu); 1126 perf_counter_task_sched_in(curr, cpu);
@@ -3109,7 +3108,6 @@ __perf_counter_init_context(struct perf_counter_context *ctx,
3109 mutex_init(&ctx->mutex); 3108 mutex_init(&ctx->mutex);
3110 INIT_LIST_HEAD(&ctx->counter_list); 3109 INIT_LIST_HEAD(&ctx->counter_list);
3111 INIT_LIST_HEAD(&ctx->event_list); 3110 INIT_LIST_HEAD(&ctx->event_list);
3112 ctx->rr_allowed = 1;
3113 ctx->task = task; 3111 ctx->task = task;
3114} 3112}
3115 3113
@@ -3350,14 +3348,14 @@ void perf_counter_init_task(struct task_struct *child)
3350 */ 3348 */
3351 mutex_lock(&parent_ctx->mutex); 3349 mutex_lock(&parent_ctx->mutex);
3352 3350
3353 parent_ctx->rr_allowed = 0;
3354 barrier(); /* irqs */
3355
3356 /* 3351 /*
3357 * We dont have to disable NMIs - we are only looking at 3352 * We dont have to disable NMIs - we are only looking at
3358 * the list, not manipulating it: 3353 * the list, not manipulating it:
3359 */ 3354 */
3360 list_for_each_entry(counter, &parent_ctx->counter_list, list_entry) { 3355 list_for_each_entry_rcu(counter, &parent_ctx->event_list, event_entry) {
3356 if (counter != counter->group_leader)
3357 continue;
3358
3361 if (!counter->hw_event.inherit) 3359 if (!counter->hw_event.inherit)
3362 continue; 3360 continue;
3363 3361
@@ -3366,9 +3364,6 @@ void perf_counter_init_task(struct task_struct *child)
3366 break; 3364 break;
3367 } 3365 }
3368 3366
3369 barrier(); /* irqs */
3370 parent_ctx->rr_allowed = 1;
3371
3372 mutex_unlock(&parent_ctx->mutex); 3367 mutex_unlock(&parent_ctx->mutex);
3373} 3368}
3374 3369