sched: Clean up SCHED_RESET_ON_FORK
authorMike Galbraith <efault@gmx.de>
Wed, 17 Jun 2009 08:46:01 +0000 (10:46 +0200)
committerIngo Molnar <mingo@elte.hu>
Wed, 17 Jun 2009 16:34:17 +0000 (18:34 +0200)
Make SCHED_RESET_ON_FORK sched_fork() bits a self-contained unlikely code path.

Signed-off-by: Mike Galbraith <efault@gmx.de>
Acked-by: Lennart Poettering <mzxreary@0pointer.de>
Cc: Peter Zijlstra <peterz@infradead.org>
LKML-Reference: <1245228361.18329.6.camel@marge.simson.net>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
kernel/sched.c

index 32e6ede85255dc64d684fbfa617a5579b0a1aa3d..50e4e3d15e83ead57817f1dbacca3984dacd2729 100644 (file)
@@ -2613,28 +2613,30 @@ void sched_fork(struct task_struct *p, int clone_flags)
        set_task_cpu(p, cpu);
 
        /*
-        * Revert to default priority/policy on fork if requested. Make sure we
-        * do not leak PI boosting priority to the child.
+        * Make sure we do not leak PI boosting priority to the child.
         */
-       if (current->sched_reset_on_fork &&
-                       (p->policy == SCHED_FIFO || p->policy == SCHED_RR))
-               p->policy = SCHED_NORMAL;
+       p->prio = current->normal_prio;
 
-       if (current->sched_reset_on_fork &&
-                       (current->normal_prio < DEFAULT_PRIO))
-               p->prio = DEFAULT_PRIO;
-       else
-               p->prio = current->normal_prio;
+       /*
+        * Revert to default priority/policy on fork if requested.
+        */
+       if (unlikely(p->sched_reset_on_fork)) {
+               if (p->policy == SCHED_FIFO || p->policy == SCHED_RR)
+                       p->policy = SCHED_NORMAL;
+
+               if (p->normal_prio < DEFAULT_PRIO)
+                       p->prio = DEFAULT_PRIO;
+
+               /*
+                * We don't need the reset flag anymore after the fork. It has
+                * fulfilled its duty:
+                */
+               p->sched_reset_on_fork = 0;
+       }
 
        if (!rt_prio(p->prio))
                p->sched_class = &fair_sched_class;
 
-       /*
-        * We don't need the reset flag anymore after the fork. It has
-        * fulfilled its duty:
-        */
-       p->sched_reset_on_fork = 0;
-
 #if defined(CONFIG_SCHEDSTATS) || defined(CONFIG_TASK_DELAY_ACCT)
        if (likely(sched_info_on()))
                memset(&p->sched_info, 0, sizeof(p->sched_info));