diff options
Diffstat (limited to 'kernel/perf_counter.c')
-rw-r--r-- | kernel/perf_counter.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/kernel/perf_counter.c b/kernel/perf_counter.c index a5bdc93ac477..7373b96bc36c 100644 --- a/kernel/perf_counter.c +++ b/kernel/perf_counter.c | |||
@@ -837,6 +837,14 @@ void perf_counter_task_sched_out(struct task_struct *task, int cpu) | |||
837 | cpuctx->task_ctx = NULL; | 837 | cpuctx->task_ctx = NULL; |
838 | } | 838 | } |
839 | 839 | ||
840 | static void __perf_counter_task_sched_out(struct perf_counter_context *ctx) | ||
841 | { | ||
842 | struct perf_cpu_context *cpuctx = &__get_cpu_var(perf_cpu_context); | ||
843 | |||
844 | __perf_counter_sched_out(ctx, cpuctx); | ||
845 | cpuctx->task_ctx = NULL; | ||
846 | } | ||
847 | |||
840 | static void perf_counter_cpu_sched_out(struct perf_cpu_context *cpuctx) | 848 | static void perf_counter_cpu_sched_out(struct perf_cpu_context *cpuctx) |
841 | { | 849 | { |
842 | __perf_counter_sched_out(&cpuctx->ctx, cpuctx); | 850 | __perf_counter_sched_out(&cpuctx->ctx, cpuctx); |
@@ -943,15 +951,13 @@ int perf_counter_task_disable(void) | |||
943 | struct perf_counter *counter; | 951 | struct perf_counter *counter; |
944 | unsigned long flags; | 952 | unsigned long flags; |
945 | u64 perf_flags; | 953 | u64 perf_flags; |
946 | int cpu; | ||
947 | 954 | ||
948 | if (likely(!ctx->nr_counters)) | 955 | if (likely(!ctx->nr_counters)) |
949 | return 0; | 956 | return 0; |
950 | 957 | ||
951 | local_irq_save(flags); | 958 | local_irq_save(flags); |
952 | cpu = smp_processor_id(); | ||
953 | 959 | ||
954 | perf_counter_task_sched_out(curr, cpu); | 960 | __perf_counter_task_sched_out(ctx); |
955 | 961 | ||
956 | spin_lock(&ctx->lock); | 962 | spin_lock(&ctx->lock); |
957 | 963 | ||
@@ -989,7 +995,7 @@ int perf_counter_task_enable(void) | |||
989 | local_irq_save(flags); | 995 | local_irq_save(flags); |
990 | cpu = smp_processor_id(); | 996 | cpu = smp_processor_id(); |
991 | 997 | ||
992 | perf_counter_task_sched_out(curr, cpu); | 998 | __perf_counter_task_sched_out(ctx); |
993 | 999 | ||
994 | spin_lock(&ctx->lock); | 1000 | spin_lock(&ctx->lock); |
995 | 1001 | ||
@@ -1054,7 +1060,7 @@ void perf_counter_task_tick(struct task_struct *curr, int cpu) | |||
1054 | ctx = &curr->perf_counter_ctx; | 1060 | ctx = &curr->perf_counter_ctx; |
1055 | 1061 | ||
1056 | perf_counter_cpu_sched_out(cpuctx); | 1062 | perf_counter_cpu_sched_out(cpuctx); |
1057 | perf_counter_task_sched_out(curr, cpu); | 1063 | __perf_counter_task_sched_out(ctx); |
1058 | 1064 | ||
1059 | rotate_ctx(&cpuctx->ctx); | 1065 | rotate_ctx(&cpuctx->ctx); |
1060 | rotate_ctx(ctx); | 1066 | rotate_ctx(ctx); |