aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/kernel/signal.c
diff options
context:
space:
mode:
authorArd Biesheuvel <ard.biesheuvel@linaro.org>2014-05-08 05:20:23 -0400
committerArd Biesheuvel <ard.biesheuvel@linaro.org>2014-05-08 05:31:57 -0400
commit005f78cd88494457ed38ce817f4e3fe5d372f0cb (patch)
treef41fff97609ae7c98bc9841bd85b60a3aa892c08 /arch/arm64/kernel/signal.c
parentc51f92693c35c141cf7d9b7e2fcbb81128324eb4 (diff)
arm64: defer reloading a task's FPSIMD state to userland resume
If a task gets scheduled out and back in again and nothing has touched its FPSIMD state in the mean time, there is really no reason to reload it from memory. Similarly, repeated calls to kernel_neon_begin() and kernel_neon_end() will preserve and restore the FPSIMD state every time. This patch defers the FPSIMD state restore to the last possible moment, i.e., right before the task returns to userland. If a task does not return to userland at all (for any reason), the existing FPSIMD state is preserved and may be reused by the owning task if it gets scheduled in again on the same CPU. This patch adds two more functions to abstract away from straight FPSIMD register file saves and restores: - fpsimd_restore_current_state -> ensure current's FPSIMD state is loaded - fpsimd_flush_task_state -> invalidate live copies of a task's FPSIMD state Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Diffstat (limited to 'arch/arm64/kernel/signal.c')
-rw-r--r--arch/arm64/kernel/signal.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/arm64/kernel/signal.c b/arch/arm64/kernel/signal.c
index 06448a77ff53..882f01774365 100644
--- a/arch/arm64/kernel/signal.c
+++ b/arch/arm64/kernel/signal.c
@@ -413,4 +413,8 @@ asmlinkage void do_notify_resume(struct pt_regs *regs,
413 clear_thread_flag(TIF_NOTIFY_RESUME); 413 clear_thread_flag(TIF_NOTIFY_RESUME);
414 tracehook_notify_resume(regs); 414 tracehook_notify_resume(regs);
415 } 415 }
416
417 if (thread_flags & _TIF_FOREIGN_FPSTATE)
418 fpsimd_restore_current_state();
419
416} 420}