The helper, resched_suitable_idle, is changed to be used in try_preempt.

SOB: Hillf Danton <dhi...@gmail.com>
---

--- a/kernel/sched/bfs.c        Fri Jul  6 20:30:10 2012
+++ b/kernel/sched/bfs.c        Mon Jul  9 20:00:52 2012
@@ -859,10 +859,15 @@ static void resched_best_idle(struct tas
        resched_best_mask(task_cpu(p), task_rq(p), &tmpmask);
 }

-static inline void resched_suitable_idle(struct task_struct *p)
+static inline bool resched_suitable_idle(struct task_struct *p)
 {
-       if (suitable_idle_cpus(p))
+       bool rc = false;
+
+       if (suitable_idle_cpus(p)) {
                resched_best_idle(p);
+               rc = true;
+       }
+       return rc;
 }
 /*
  * Flags to tell us whether this CPU is running a CPU frequency governor that
@@ -915,8 +920,9 @@ static inline bool suitable_idle_cpus(st
        return uprq->curr == uprq->idle;
 }

-static inline void resched_suitable_idle(struct task_struct *p)
+static inline bool resched_suitable_idle(struct task_struct *p)
 {
+       return false;
 }

 void cpu_scaling(int __unused)
@@ -1390,12 +1396,12 @@ static void try_preempt(struct task_stru
         * try_preempt with the sticky flag enabled means some complicated
         * re-scheduling has occurred and we should ignore the sticky flag.
         */
-       clear_sticky(p);
+       if (task_sticky(p))
+               clear_sticky(p);

-       if (suitable_idle_cpus(p)) {
-               resched_best_idle(p);
+       /* check if idle cpu available */
+       if (resched_suitable_idle(p))
                return;
-       }

        /* IDLEPRIO tasks never preempt anything but idle */
        if (p->policy == SCHED_IDLEPRIO)
--
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to