aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips
diff options
context:
space:
mode:
authorJames Hogan <james.hogan@imgtec.com>2015-02-25 08:08:05 -0500
committerRalf Baechle <ralf@linux-mips.org>2015-04-10 09:41:51 -0400
commitf8483988cadd7dd22de928db29ed3bcbe02faf78 (patch)
tree2eae4e5c7f61784e04076a10a88863d5e9e9684e /arch/mips
parenta7b7aad383c5dd9221a06e378197350dd27c1163 (diff)
MIPS: lose_fpu(): Disable FPU when MSA enabled
The lose_fpu() function only disables the FPU in CP0_Status.CU1 if the FPU is in use and MSA isn't enabled. This isn't necessarily a problem because KSTK_STATUS(current), the version of CP0_Status stored on the kernel stack on entry from user mode, does always get updated and gets restored when returning to user mode, but I don't think it was intended, and it is inconsistent with the case of only the FPU being in use. Sometimes leaving the FPU enabled may also mask kernel bugs where FPU operations are executed when the FPU might not be enabled. So lets disable the FPU in the MSA case too. Fixes: 33c771ba5c5d ("MIPS: save/disable MSA in lose_fpu") Signed-off-by: James Hogan <james.hogan@imgtec.com> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Paul Burton <paul.burton@imgtec.com> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/9323/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
Diffstat (limited to 'arch/mips')
-rw-r--r--arch/mips/include/asm/fpu.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/mips/include/asm/fpu.h b/arch/mips/include/asm/fpu.h
index dd083e999b08..9f26b079cc6a 100644
--- a/arch/mips/include/asm/fpu.h
+++ b/arch/mips/include/asm/fpu.h
@@ -170,6 +170,7 @@ static inline void lose_fpu(int save)
170 } 170 }
171 disable_msa(); 171 disable_msa();
172 clear_thread_flag(TIF_USEDMSA); 172 clear_thread_flag(TIF_USEDMSA);
173 __disable_fpu();
173 } else if (is_fpu_owner()) { 174 } else if (is_fpu_owner()) {
174 if (save) 175 if (save)
175 _save_fp(current); 176 _save_fp(current);