瀏覽代碼

sched: Remove rq argument from ttwu_stat()

In order to call ttwu_stat() without holding rq->lock we must remove
its rq argument. Since we need to change rq stats, account to the
local rq instead of the task rq, this is safe since we have IRQs
disabled.

Reviewed-by: Frank Rowand <frank.rowand@am.sony.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Nick Piggin <npiggin@kernel.dk>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/20110405152729.394638826@chello.nl
Peter Zijlstra 14 年之前
父節點
當前提交
b84cb5df1f
共有 1 個文件被更改,包括 6 次插入3 次删除
  1. 6 3
      kernel/sched.c

+ 6 - 3
kernel/sched.c

@@ -2410,9 +2410,11 @@ static void update_avg(u64 *avg, u64 sample)
 #endif
 #endif
 
 
 static void
 static void
-ttwu_stat(struct rq *rq, struct task_struct *p, int cpu, int wake_flags)
+ttwu_stat(struct task_struct *p, int cpu, int wake_flags)
 {
 {
 #ifdef CONFIG_SCHEDSTATS
 #ifdef CONFIG_SCHEDSTATS
+	struct rq *rq = this_rq();
+
 #ifdef CONFIG_SMP
 #ifdef CONFIG_SMP
 	int this_cpu = smp_processor_id();
 	int this_cpu = smp_processor_id();
 
 
@@ -2561,9 +2563,10 @@ out_activate:
 	ttwu_activate(rq, p, ENQUEUE_WAKEUP | ENQUEUE_WAKING);
 	ttwu_activate(rq, p, ENQUEUE_WAKEUP | ENQUEUE_WAKING);
 out_running:
 out_running:
 	ttwu_post_activation(p, rq, wake_flags);
 	ttwu_post_activation(p, rq, wake_flags);
-	ttwu_stat(rq, p, cpu, wake_flags);
 	success = 1;
 	success = 1;
 	__task_rq_unlock(rq);
 	__task_rq_unlock(rq);
+
+	ttwu_stat(p, cpu, wake_flags);
 out:
 out:
 	raw_spin_unlock_irqrestore(&p->pi_lock, flags);
 	raw_spin_unlock_irqrestore(&p->pi_lock, flags);
 	put_cpu();
 	put_cpu();
@@ -2600,7 +2603,7 @@ static void try_to_wake_up_local(struct task_struct *p)
 		ttwu_activate(rq, p, ENQUEUE_WAKEUP);
 		ttwu_activate(rq, p, ENQUEUE_WAKEUP);
 
 
 	ttwu_post_activation(p, rq, 0);
 	ttwu_post_activation(p, rq, 0);
-	ttwu_stat(rq, p, smp_processor_id(), 0);
+	ttwu_stat(p, smp_processor_id(), 0);
 out:
 out:
 	raw_spin_unlock(&p->pi_lock);
 	raw_spin_unlock(&p->pi_lock);
 }
 }