From: aurel32 Date: Mon, 10 Mar 2008 00:09:28 +0000 (+0000) Subject: mtfsf: fix FPSCR_VX and FPSCR_FEX computation X-Git-Tag: xen-3.3.0-rc1~326 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=5567025f5352b7177f7040f40c200c6a66aa1cd2;p=qemu-xen-4.1-testing.git mtfsf: fix FPSCR_VX and FPSCR_FEX computation The patch below fixes the computation of FPSCR_VX and FPSCR_FEX when using the mtfsf instruction. As stated in the PowerPC manual the mtfsf instruction can't alter those bit, and thus it should always be computed. Acked by Jocelyn Mayer. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4034 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/target-ppc/op_helper.c b/target-ppc/op_helper.c index 1ea16951b..38467c44e 100644 --- a/target-ppc/op_helper.c +++ b/target-ppc/op_helper.c @@ -888,12 +888,16 @@ void do_store_fpscr (uint32_t mask) /* Update VX and FEX */ if (fpscr_ix != 0) env->fpscr |= 1 << FPSCR_VX; + else + env->fpscr &= ~(1 << FPSCR_VX); if ((fpscr_ex & fpscr_eex) != 0) { env->fpscr |= 1 << FPSCR_FEX; env->exception_index = POWERPC_EXCP_PROGRAM; /* XXX: we should compute it properly */ env->error_code = POWERPC_EXCP_FP; } + else + env->fpscr &= ~(1 << FPSCR_FEX); fpscr_set_rounding_mode(); } #undef WORD0