qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [Qemu-devel] [PATCH] FMULX should flushes operators to zero when FZ is set.
@ 2015-01-28 14:51 Xiangyu Hu
  2015-01-28 14:54 ` Peter Maydell
  2015-01-28 15:54 ` Alex Bennée
  0 siblings, 2 replies; 10+ messages in thread
From: Xiangyu Hu @ 2015-01-28 14:51 UTC (permalink / raw)
  To: qemu-devel; +Cc: peter.maydell, Xiangyu Hu

The difference between FMULX and FMUL is that FMULX will return 2.0f when one operator is 
FPInfinity and the other one is FPZero, whilst FMUL will return a Default NaN. Without 
this patch, the emulation would result in inconsistency.

Signed-off-by: Xiangyu Hu <libhu.so@gmail.com>
---
 target-arm/helper-a64.c | 6 ++++++
 1 file changed, 6 insertions(+)

diff --git a/target-arm/helper-a64.c b/target-arm/helper-a64.c
index 81066ca..ebd9247 100644
--- a/target-arm/helper-a64.c
+++ b/target-arm/helper-a64.c
@@ -135,6 +135,9 @@ float32 HELPER(vfp_mulxs)(float32 a, float32 b, void *fpstp)
 {
     float_status *fpst = fpstp;
 
+    a = float32_squash_input_denormal(a, fpst);
+    b = float32_squash_input_denormal(b, fpst);
+
     if ((float32_is_zero(a) && float32_is_infinity(b)) ||
         (float32_is_infinity(a) && float32_is_zero(b))) {
         /* 2.0 with the sign bit set to sign(A) XOR sign(B) */
@@ -148,6 +151,9 @@ float64 HELPER(vfp_mulxd)(float64 a, float64 b, void *fpstp)
 {
     float_status *fpst = fpstp;
 
+    a = float64_squash_input_denormal(a, fpst);
+    b = float64_squash_input_denormal(b, fpst);
+
     if ((float64_is_zero(a) && float64_is_infinity(b)) ||
         (float64_is_infinity(a) && float64_is_zero(b))) {
         /* 2.0 with the sign bit set to sign(A) XOR sign(B) */
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2015-02-03 13:44 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-01-28 14:51 [Qemu-devel] [PATCH] FMULX should flushes operators to zero when FZ is set Xiangyu Hu
2015-01-28 14:54 ` Peter Maydell
2015-01-28 15:42   ` Xiangyu Hu
2015-01-28 15:54 ` Alex Bennée
2015-01-28 15:57   ` Peter Maydell
2015-01-28 16:11     ` Xiangyu Hu
2015-01-28 16:12     ` Claudio Fontana
2015-01-28 16:25       ` Peter Maydell
2015-01-29 19:22     ` Peter Maydell
2015-02-03 13:44       ` Alex Bennée

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).