diff options
author | Sebastian Andrzej Siewior <bigeasy@linutronix.de> | 2016-02-09 18:18:01 +0100 |
---|---|---|
committer | Steven Rostedt <rostedt@goodmis.org> | 2017-06-07 19:03:17 -0400 |
commit | 44b7ef2aea6f364cdf6a04f0614251643fd30629 (patch) | |
tree | 21a218da12d389dd382bdaccb4bc3b2bfa079136 | |
parent | ea649450e63e75d968ed5e451046115906d5f206 (diff) | |
download | linux-rt-44b7ef2aea6f364cdf6a04f0614251643fd30629.tar.gz |
kernel: migrate_disable() do fastpath in atomic & irqs-off
With interrupts off it makes no sense to do the long path since we can't
leave the CPU anyway. Also we might end up in a recursion with lockdep.
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
-rw-r--r-- | kernel/sched/core.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 711081650ae3..6f495ca73679 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -2490,7 +2490,7 @@ void migrate_disable(void) { struct task_struct *p = current; - if (in_atomic()) { + if (in_atomic() || irqs_disabled()) { #ifdef CONFIG_SCHED_DEBUG p->migrate_disable_atomic++; #endif @@ -2524,7 +2524,7 @@ void migrate_enable(void) unsigned long flags; struct rq *rq; - if (in_atomic()) { + if (in_atomic() || irqs_disabled()) { #ifdef CONFIG_SCHED_DEBUG p->migrate_disable_atomic--; #endif |