]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
sched: Consolidate pick_*_task to task_is_pushable helper
authorConnor O'Brien <connoro@google.com>
Wed, 9 Oct 2024 23:53:38 +0000 (16:53 -0700)
committerPeter Zijlstra <peterz@infradead.org>
Mon, 14 Oct 2024 10:52:41 +0000 (12:52 +0200)
This patch consolidates rt and deadline pick_*_task functions to
a task_is_pushable() helper

This patch was broken out from a larger chain migration
patch originally by Connor O'Brien.

[jstultz: split out from larger chain migration patch,
 renamed helper function]

Signed-off-by: Connor O'Brien <connoro@google.com>
Signed-off-by: John Stultz <jstultz@google.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Metin Kaya <metin.kaya@arm.com>
Reviewed-by: Valentin Schneider <vschneid@redhat.com>
Reviewed-by: Christian Loehle <christian.loehle@arm.com>
Tested-by: K Prateek Nayak <kprateek.nayak@amd.com>
Tested-by: Metin Kaya <metin.kaya@arm.com>
Link: https://lore.kernel.org/r/20241009235352.1614323-6-jstultz@google.com
kernel/sched/deadline.c
kernel/sched/rt.c
kernel/sched/sched.h

index 4acf5e3a5005fbbaa6bfc973c235ba253a2c1bec..a4683f8fe6850dcbfc1a667ffe25ae41bf504bfc 100644 (file)
@@ -2487,14 +2487,6 @@ static void task_fork_dl(struct task_struct *p)
 /* Only try algorithms three times */
 #define DL_MAX_TRIES 3
 
-static int pick_dl_task(struct rq *rq, struct task_struct *p, int cpu)
-{
-       if (!task_on_cpu(rq, p) &&
-           cpumask_test_cpu(cpu, &p->cpus_mask))
-               return 1;
-       return 0;
-}
-
 /*
  * Return the earliest pushable rq's task, which is suitable to be executed
  * on the CPU, NULL otherwise:
@@ -2513,7 +2505,7 @@ next_node:
        if (next_node) {
                p = __node_2_pdl(next_node);
 
-               if (pick_dl_task(rq, p, cpu))
+               if (task_is_pushable(rq, p, cpu))
                        return p;
 
                next_node = rb_next(next_node);
index e2506ab33c979c0b043dc086a21ca9add5eb833f..c5c22fc51824a29b6c09f2557c6628e333a081fa 100644 (file)
@@ -1773,15 +1773,6 @@ static void put_prev_task_rt(struct rq *rq, struct task_struct *p, struct task_s
 /* Only try algorithms three times */
 #define RT_MAX_TRIES 3
 
-static int pick_rt_task(struct rq *rq, struct task_struct *p, int cpu)
-{
-       if (!task_on_cpu(rq, p) &&
-           cpumask_test_cpu(cpu, &p->cpus_mask))
-               return 1;
-
-       return 0;
-}
-
 /*
  * Return the highest pushable rq's task, which is suitable to be executed
  * on the CPU, NULL otherwise
@@ -1795,7 +1786,7 @@ static struct task_struct *pick_highest_pushable_task(struct rq *rq, int cpu)
                return NULL;
 
        plist_for_each_entry(p, head, pushable_tasks) {
-               if (pick_rt_task(rq, p, cpu))
+               if (task_is_pushable(rq, p, cpu))
                        return p;
        }
 
index 71ce1b05ac94bd9ea496f405490a7db0eba21133..449335299d2fdb2713c8433588495dc8f8a73e66 100644 (file)
@@ -3799,6 +3799,16 @@ void move_queued_task_locked(struct rq *src_rq, struct rq *dst_rq, struct task_s
        set_task_cpu(task, dst_rq->cpu);
        activate_task(dst_rq, task, 0);
 }
+
+static inline
+bool task_is_pushable(struct rq *rq, struct task_struct *p, int cpu)
+{
+       if (!task_on_cpu(rq, p) &&
+           cpumask_test_cpu(cpu, &p->cpus_mask))
+               return true;
+
+       return false;
+}
 #endif
 
 #ifdef CONFIG_RT_MUTEXES