+ lower-migration-thread-stop-machine-prio.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled

     lower migration thread/stop machine prio

has been added to the -mm tree.  Its filename is

     lower-migration-thread-stop-machine-prio.patch

See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find
out what to do about this

------------------------------------------------------
Subject: lower migration thread/stop machine prio
From: Daniel Walker <dwalker@xxxxxxxxxx>

We should give some space at the top to allow things to schedule above
everything in a default system.  I think this takes better advantage of all
the priorities we have.

This moves the stop_machine and migration threads to SCHED_FIFO prio 80.

Signed-off-by: Daniel Walker <dwalker@xxxxxxxxxx>
Cc: Ingo Molnar <mingo@xxxxxxx>
Cc: Nick Piggin <nickpiggin@xxxxxxxxxxxx>
Cc: Rusty Russell <rusty@xxxxxxxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxx>
---

 include/linux/sched.h        |    3 +++
 include/linux/stop_machine.h |    3 +++
 kernel/sched.c               |    3 +--
 kernel/stop_machine.c        |    2 +-
 4 files changed, 8 insertions(+), 3 deletions(-)

diff -puN include/linux/sched.h~lower-migration-thread-stop-machine-prio include/linux/sched.h
--- a/include/linux/sched.h~lower-migration-thread-stop-machine-prio
+++ a/include/linux/sched.h
@@ -507,6 +507,9 @@ struct signal_struct {
 #define has_rt_policy(p) \
 	unlikely((p)->policy != SCHED_NORMAL && (p)->policy != SCHED_BATCH)
 
+/* Must be high prio: stop_machine expects to yield to it. */
+#define MIGRATION_THREAD_PRIO (MAX_RT_PRIO-20)
+
 /*
  * Some day this will be a full-fledged user tracking system..
  */
diff -puN include/linux/stop_machine.h~lower-migration-thread-stop-machine-prio include/linux/stop_machine.h
--- a/include/linux/stop_machine.h~lower-migration-thread-stop-machine-prio
+++ a/include/linux/stop_machine.h
@@ -8,6 +8,9 @@
 #include <asm/system.h>
 
 #if defined(CONFIG_STOP_MACHINE) && defined(CONFIG_SMP)
+
+#define STOP_MACHINE_PRIO (MAX_RT_PRIO-20)
+
 /**
  * stop_machine_run: freeze the machine on all CPUs and run this function
  * @fn: the function to run
diff -puN kernel/sched.c~lower-migration-thread-stop-machine-prio kernel/sched.c
--- a/kernel/sched.c~lower-migration-thread-stop-machine-prio
+++ a/kernel/sched.c
@@ -5172,9 +5172,8 @@ migration_call(struct notifier_block *nf
 			return NOTIFY_BAD;
 		p->flags |= PF_NOFREEZE;
 		kthread_bind(p, cpu);
-		/* Must be high prio: stop_machine expects to yield to it. */
 		rq = task_rq_lock(p, &flags);
-		__setscheduler(p, SCHED_FIFO, MAX_RT_PRIO-1);
+		__setscheduler(p, SCHED_FIFO, MIGRATION_THREAD_PRIO);
 		task_rq_unlock(rq, &flags);
 		cpu_rq(cpu)->migration_thread = p;
 		break;
diff -puN kernel/stop_machine.c~lower-migration-thread-stop-machine-prio kernel/stop_machine.c
--- a/kernel/stop_machine.c~lower-migration-thread-stop-machine-prio
+++ a/kernel/stop_machine.c
@@ -86,7 +86,7 @@ static void stopmachine_set_state(enum s
 static int stop_machine(void)
 {
 	int i, ret = 0;
-	struct sched_param param = { .sched_priority = MAX_RT_PRIO-1 };
+	struct sched_param param = { .sched_priority = STOP_MACHINE_PRIO };
 
 	/* One high-prio thread per cpu.  We'll do this one. */
 	sched_setscheduler(current, SCHED_FIFO, &param);
_

Patches currently in -mm which might be from dwalker@xxxxxxxxxx are

buslogic-gcc-41-warning-fixes.patch
megaraid-gcc-41-warning-fix.patch
lower-migration-thread-stop-machine-prio.patch
profile-likely-unlikely-macros.patch

-
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux