[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL v2 1/8] target/m68k: define floatx80_move()
From: |
Laurent Vivier |
Subject: |
[Qemu-devel] [PULL v2 1/8] target/m68k: define floatx80_move() |
Date: |
Fri, 9 Mar 2018 15:57:10 +0100 |
This functions is needed by upcoming m68k softfloat functions.
Source code copied for WinUAE (tag 3500)
(The WinUAE file has been copied from QEMU and has
the QEMU licensing notice)
Signed-off-by: Laurent Vivier <address@hidden>
Message-Id: <address@hidden>
---
target/m68k/softfloat.c | 27 +++++++++++++++++++++++++++
target/m68k/softfloat.h | 1 +
2 files changed, 28 insertions(+)
diff --git a/target/m68k/softfloat.c b/target/m68k/softfloat.c
index 9cb141900c..55eb7a260a 100644
--- a/target/m68k/softfloat.c
+++ b/target/m68k/softfloat.c
@@ -247,3 +247,30 @@ floatx80 floatx80_scale(floatx80 a, floatx80 b,
float_status *status)
return roundAndPackFloatx80(status->floatx80_rounding_precision,
aSign, aExp, aSig, 0, status);
}
+
+floatx80 floatx80_move(floatx80 a, float_status *status)
+{
+ flag aSign;
+ int32_t aExp;
+ uint64_t aSig;
+
+ aSig = extractFloatx80Frac(a);
+ aExp = extractFloatx80Exp(a);
+ aSign = extractFloatx80Sign(a);
+
+ if (aExp == 0x7FFF) {
+ if ((uint64_t)(aSig << 1)) {
+ return propagateFloatx80NaNOneArg(a, status);
+ }
+ return a;
+ }
+ if (aExp == 0) {
+ if (aSig == 0) {
+ return a;
+ }
+ normalizeRoundAndPackFloatx80(status->floatx80_rounding_precision,
+ aSign, aExp, aSig, 0, status);
+ }
+ return roundAndPackFloatx80(status->floatx80_rounding_precision, aSign,
+ aExp, aSig, 0, status);
+}
diff --git a/target/m68k/softfloat.h b/target/m68k/softfloat.h
index 78fbc0cd0c..18561b870d 100644
--- a/target/m68k/softfloat.h
+++ b/target/m68k/softfloat.h
@@ -26,4 +26,5 @@ floatx80 floatx80_mod(floatx80 a, floatx80 b, float_status
*status);
floatx80 floatx80_getman(floatx80 a, float_status *status);
floatx80 floatx80_getexp(floatx80 a, float_status *status);
floatx80 floatx80_scale(floatx80 a, floatx80 b, float_status *status);
+floatx80 floatx80_move(floatx80 a, float_status *status);
#endif
--
2.14.3
- [Qemu-devel] [PULL v2 0/8] M68k for 2.12 patches, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 1/8] target/m68k: define floatx80_move(),
Laurent Vivier <=
- [Qemu-devel] [PULL v2 4/8] target/m68k: implement flog10, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 2/8] target/m68k: implement flognp1, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 3/8] target/m68k: implement flogn, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 5/8] target/m68k: implement flog2, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 8/8] target/m68k: implement ftentox, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 6/8] target/m68k: implement fetox, Laurent Vivier, 2018/03/09
- [Qemu-devel] [PULL v2 7/8] target/m68k: implement ftwotox, Laurent Vivier, 2018/03/09
- Re: [Qemu-devel] [PULL v2 0/8] M68k for 2.12 patches, Peter Maydell, 2018/03/12