aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2013-06-09 03:01:24 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2013-06-20 03:05:09 -0400
commit4e63f8edfe4d6f20b1af176efc022c2b2f5e7aeb (patch)
tree5fd40bcbe3b23b8c055e1f8bd543ec125c9f98d6 /arch
parent04ae9001719c3f0012d239a7c5aa4136f6b6541d (diff)
powerpc/math-emu: Allow math-emu to be used for HW FPU
(Including 64-bit ones) This allow SW emulation by the kernel of optional instructions such as fsqrt which aren't implemented on some processors, and thus fixes some Fedora 19 issues such as Anaconda since the compiler is set to generate those by default on 64-bit. Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/powerpc/Kconfig6
-rw-r--r--arch/powerpc/kernel/traps.c12
2 files changed, 16 insertions, 2 deletions
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig
index c33e3ad2c8fd..e3009abc7f75 100644
--- a/arch/powerpc/Kconfig
+++ b/arch/powerpc/Kconfig
@@ -298,7 +298,7 @@ config HUGETLB_PAGE_SIZE_VARIABLE
298 298
299config MATH_EMULATION 299config MATH_EMULATION
300 bool "Math emulation" 300 bool "Math emulation"
301 depends on 4xx || 8xx || E200 || PPC_MPC832x || E500 301 depends on 4xx || 8xx || PPC_MPC832x || BOOKE
302 ---help--- 302 ---help---
303 Some PowerPC chips designed for embedded applications do not have 303 Some PowerPC chips designed for embedded applications do not have
304 a floating-point unit and therefore do not implement the 304 a floating-point unit and therefore do not implement the
@@ -307,6 +307,10 @@ config MATH_EMULATION
307 unit, which will allow programs that use floating-point 307 unit, which will allow programs that use floating-point
308 instructions to run. 308 instructions to run.
309 309
310 This is also useful to emulate missing (optional) instructions
311 such as fsqrt on cores that do have an FPU but do not implement
312 them (such as Freescale BookE).
313
310config PPC_TRANSACTIONAL_MEM 314config PPC_TRANSACTIONAL_MEM
311 bool "Transactional Memory support for POWERPC" 315 bool "Transactional Memory support for POWERPC"
312 depends on PPC_BOOK3S_64 316 depends on PPC_BOOK3S_64
diff --git a/arch/powerpc/kernel/traps.c b/arch/powerpc/kernel/traps.c
index f18c79c324ef..f4b5687b0c66 100644
--- a/arch/powerpc/kernel/traps.c
+++ b/arch/powerpc/kernel/traps.c
@@ -1125,7 +1125,17 @@ void __kprobes program_check_exception(struct pt_regs *regs)
1125 * ESR_DST (!?) or 0. In the process of chasing this with the 1125 * ESR_DST (!?) or 0. In the process of chasing this with the
1126 * hardware people - not sure if it can happen on any illegal 1126 * hardware people - not sure if it can happen on any illegal
1127 * instruction or only on FP instructions, whether there is a 1127 * instruction or only on FP instructions, whether there is a
1128 * pattern to occurrences etc. -dgibson 31/Mar/2003 */ 1128 * pattern to occurrences etc. -dgibson 31/Mar/2003
1129 */
1130
1131 /*
1132 * If we support a HW FPU, we need to ensure the FP state
1133 * if flushed into the thread_struct before attempting
1134 * emulation
1135 */
1136#ifdef CONFIG_PPC_FPU
1137 flush_fp_to_thread(current);
1138#endif
1129 switch (do_mathemu(regs)) { 1139 switch (do_mathemu(regs)) {
1130 case 0: 1140 case 0:
1131 emulate_single_step(regs); 1141 emulate_single_step(regs);