diff options
author | Peter Zijlstra <peterz@infradead.org> | 2018-03-15 06:45:44 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2018-03-20 03:23:23 -0400 |
commit | 6887a56b6e8ef5daf1160f2ebe5cbe38fd8819a2 (patch) | |
tree | f618aea7ea09bfddc275ff0eab7d1cb3673a3489 | |
parent | e24e960c7fe2d6068974efced0ce5bdad8e81866 (diff) |
sched/wait, arch/mips: Fix and convert wait_on_atomic_t() usage to the new wait_var_event() API
The old wait_on_atomic_t() is going to get removed, use the more
flexible wait_var_event() API instead.
And while there, fix a bug and add the missing wakeup...
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: James Hogan <jhogan@kernel.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: linux-kernel@vger.kernel.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | arch/mips/kernel/process.c | 2 | ||||
-rw-r--r-- | arch/mips/kernel/traps.c | 4 |
2 files changed, 4 insertions, 2 deletions
diff --git a/arch/mips/kernel/process.c b/arch/mips/kernel/process.c index 57028d49c202..b9e9bf628849 100644 --- a/arch/mips/kernel/process.c +++ b/arch/mips/kernel/process.c | |||
@@ -781,6 +781,8 @@ int mips_set_process_fp_mode(struct task_struct *task, unsigned int value) | |||
781 | atomic_set(&task->mm->context.fp_mode_switching, 0); | 781 | atomic_set(&task->mm->context.fp_mode_switching, 0); |
782 | preempt_enable(); | 782 | preempt_enable(); |
783 | 783 | ||
784 | wake_up_var(&task->mm->context.fp_mode_switching); | ||
785 | |||
784 | return 0; | 786 | return 0; |
785 | } | 787 | } |
786 | 788 | ||
diff --git a/arch/mips/kernel/traps.c b/arch/mips/kernel/traps.c index 0ae4a731cc12..967e9e4e795e 100644 --- a/arch/mips/kernel/traps.c +++ b/arch/mips/kernel/traps.c | |||
@@ -1248,8 +1248,8 @@ static int enable_restore_fp_context(int msa) | |||
1248 | * If an FP mode switch is currently underway, wait for it to | 1248 | * If an FP mode switch is currently underway, wait for it to |
1249 | * complete before proceeding. | 1249 | * complete before proceeding. |
1250 | */ | 1250 | */ |
1251 | wait_on_atomic_t(¤t->mm->context.fp_mode_switching, | 1251 | wait_var_event(¤t->mm->context.fp_mode_switching, |
1252 | atomic_t_wait, TASK_KILLABLE); | 1252 | !atomic_read(¤t->mm->context.fp_mode_switching)); |
1253 | 1253 | ||
1254 | if (!used_math()) { | 1254 | if (!used_math()) { |
1255 | /* First time FP context user. */ | 1255 | /* First time FP context user. */ |