Piotr Caban : msvcrt: Use status word flags from public header.

Alexandre Julliard julliard at winehq.org
Tue Dec 1 15:40:35 CST 2020


Module: wine
Branch: master
Commit: 09d018c73d4dbaeddf19333e9c5c6fae51d4c1ec
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=09d018c73d4dbaeddf19333e9c5c6fae51d4c1ec

Author: Piotr Caban <piotr at codeweavers.com>
Date:   Tue Dec  1 13:51:55 2020 +0100

msvcrt: Use status word flags from public header.

Signed-off-by: Piotr Caban <piotr at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/msvcrt/math.c   | 72 ++++++++++++++++++++++++++--------------------------
 dlls/msvcrt/msvcrt.h | 14 ----------
 2 files changed, 36 insertions(+), 50 deletions(-)

diff --git a/dlls/msvcrt/math.c b/dlls/msvcrt/math.c
index 1eaa82624b9..5cbf2068aa6 100644
--- a/dlls/msvcrt/math.c
+++ b/dlls/msvcrt/math.c
@@ -1640,12 +1640,12 @@ void CDECL _statusfp2( unsigned int *x86_sw, unsigned int *sse2_sw )
     {
         __asm__ __volatile__( "fstsw %0" : "=m" (fpword) );
         flags = 0;
-        if (fpword & 0x1)  flags |= MSVCRT__SW_INVALID;
-        if (fpword & 0x2)  flags |= MSVCRT__SW_DENORMAL;
-        if (fpword & 0x4)  flags |= MSVCRT__SW_ZERODIVIDE;
-        if (fpword & 0x8)  flags |= MSVCRT__SW_OVERFLOW;
-        if (fpword & 0x10) flags |= MSVCRT__SW_UNDERFLOW;
-        if (fpword & 0x20) flags |= MSVCRT__SW_INEXACT;
+        if (fpword & 0x1)  flags |= _SW_INVALID;
+        if (fpword & 0x2)  flags |= _SW_DENORMAL;
+        if (fpword & 0x4)  flags |= _SW_ZERODIVIDE;
+        if (fpword & 0x8)  flags |= _SW_OVERFLOW;
+        if (fpword & 0x10) flags |= _SW_UNDERFLOW;
+        if (fpword & 0x20) flags |= _SW_INEXACT;
         *x86_sw = flags;
     }
 
@@ -1655,12 +1655,12 @@ void CDECL _statusfp2( unsigned int *x86_sw, unsigned int *sse2_sw )
     {
         __asm__ __volatile__( "stmxcsr %0" : "=m" (fpword) );
         flags = 0;
-        if (fpword & 0x1)  flags |= MSVCRT__SW_INVALID;
-        if (fpword & 0x2)  flags |= MSVCRT__SW_DENORMAL;
-        if (fpword & 0x4)  flags |= MSVCRT__SW_ZERODIVIDE;
-        if (fpword & 0x8)  flags |= MSVCRT__SW_OVERFLOW;
-        if (fpword & 0x10) flags |= MSVCRT__SW_UNDERFLOW;
-        if (fpword & 0x20) flags |= MSVCRT__SW_INEXACT;
+        if (fpword & 0x1)  flags |= _SW_INVALID;
+        if (fpword & 0x2)  flags |= _SW_DENORMAL;
+        if (fpword & 0x4)  flags |= _SW_ZERODIVIDE;
+        if (fpword & 0x8)  flags |= _SW_OVERFLOW;
+        if (fpword & 0x10) flags |= _SW_UNDERFLOW;
+        if (fpword & 0x20) flags |= _SW_INEXACT;
         *sse2_sw = flags;
     }
     else *sse2_sw = 0;
@@ -1686,12 +1686,12 @@ unsigned int CDECL _statusfp(void)
     ULONG_PTR fpsr;
 
     __asm__ __volatile__( "mrs %0, fpsr" : "=r" (fpsr) );
-    if (fpsr & 0x1)  flags |= MSVCRT__SW_INVALID;
-    if (fpsr & 0x2)  flags |= MSVCRT__SW_ZERODIVIDE;
-    if (fpsr & 0x4)  flags |= MSVCRT__SW_OVERFLOW;
-    if (fpsr & 0x8)  flags |= MSVCRT__SW_UNDERFLOW;
-    if (fpsr & 0x10) flags |= MSVCRT__SW_INEXACT;
-    if (fpsr & 0x80) flags |= MSVCRT__SW_DENORMAL;
+    if (fpsr & 0x1)  flags |= _SW_INVALID;
+    if (fpsr & 0x2)  flags |= _SW_ZERODIVIDE;
+    if (fpsr & 0x4)  flags |= _SW_OVERFLOW;
+    if (fpsr & 0x8)  flags |= _SW_UNDERFLOW;
+    if (fpsr & 0x10) flags |= _SW_INEXACT;
+    if (fpsr & 0x80) flags |= _SW_DENORMAL;
 #else
     FIXME( "not implemented\n" );
 #endif
@@ -1708,22 +1708,22 @@ unsigned int CDECL _clearfp(void)
     unsigned long fpword;
 
     __asm__ __volatile__( "fnstsw %0; fnclex" : "=m" (fpword) );
-    if (fpword & 0x1)  flags |= MSVCRT__SW_INVALID;
-    if (fpword & 0x2)  flags |= MSVCRT__SW_DENORMAL;
-    if (fpword & 0x4)  flags |= MSVCRT__SW_ZERODIVIDE;
-    if (fpword & 0x8)  flags |= MSVCRT__SW_OVERFLOW;
-    if (fpword & 0x10) flags |= MSVCRT__SW_UNDERFLOW;
-    if (fpword & 0x20) flags |= MSVCRT__SW_INEXACT;
+    if (fpword & 0x1)  flags |= _SW_INVALID;
+    if (fpword & 0x2)  flags |= _SW_DENORMAL;
+    if (fpword & 0x4)  flags |= _SW_ZERODIVIDE;
+    if (fpword & 0x8)  flags |= _SW_OVERFLOW;
+    if (fpword & 0x10) flags |= _SW_UNDERFLOW;
+    if (fpword & 0x20) flags |= _SW_INEXACT;
 
     if (sse2_supported)
     {
         __asm__ __volatile__( "stmxcsr %0" : "=m" (fpword) );
-        if (fpword & 0x1)  flags |= MSVCRT__SW_INVALID;
-        if (fpword & 0x2)  flags |= MSVCRT__SW_DENORMAL;
-        if (fpword & 0x4)  flags |= MSVCRT__SW_ZERODIVIDE;
-        if (fpword & 0x8)  flags |= MSVCRT__SW_OVERFLOW;
-        if (fpword & 0x10) flags |= MSVCRT__SW_UNDERFLOW;
-        if (fpword & 0x20) flags |= MSVCRT__SW_INEXACT;
+        if (fpword & 0x1)  flags |= _SW_INVALID;
+        if (fpword & 0x2)  flags |= _SW_DENORMAL;
+        if (fpword & 0x4)  flags |= _SW_ZERODIVIDE;
+        if (fpword & 0x8)  flags |= _SW_OVERFLOW;
+        if (fpword & 0x10) flags |= _SW_UNDERFLOW;
+        if (fpword & 0x20) flags |= _SW_INEXACT;
         fpword &= ~0x3f;
         __asm__ __volatile__( "ldmxcsr %0" : : "m" (fpword) );
     }
@@ -1731,12 +1731,12 @@ unsigned int CDECL _clearfp(void)
     ULONG_PTR fpsr;
 
     __asm__ __volatile__( "mrs %0, fpsr" : "=r" (fpsr) );
-    if (fpsr & 0x1)  flags |= MSVCRT__SW_INVALID;
-    if (fpsr & 0x2)  flags |= MSVCRT__SW_ZERODIVIDE;
-    if (fpsr & 0x4)  flags |= MSVCRT__SW_OVERFLOW;
-    if (fpsr & 0x8)  flags |= MSVCRT__SW_UNDERFLOW;
-    if (fpsr & 0x10) flags |= MSVCRT__SW_INEXACT;
-    if (fpsr & 0x80) flags |= MSVCRT__SW_DENORMAL;
+    if (fpsr & 0x1)  flags |= _SW_INVALID;
+    if (fpsr & 0x2)  flags |= _SW_ZERODIVIDE;
+    if (fpsr & 0x4)  flags |= _SW_OVERFLOW;
+    if (fpsr & 0x8)  flags |= _SW_UNDERFLOW;
+    if (fpsr & 0x10) flags |= _SW_INEXACT;
+    if (fpsr & 0x80) flags |= _SW_DENORMAL;
     fpsr &= ~0x9f;
     __asm__ __volatile__( "msr fpsr, %0" :: "r" (fpsr) );
 #else
diff --git a/dlls/msvcrt/msvcrt.h b/dlls/msvcrt/msvcrt.h
index 56963ad39ab..511640fb1f4 100644
--- a/dlls/msvcrt/msvcrt.h
+++ b/dlls/msvcrt/msvcrt.h
@@ -626,20 +626,6 @@ struct MSVCRT__stat64 {
 #define MSVCRT__O_U16TEXT       0x20000
 #define MSVCRT__O_U8TEXT        0x40000
 
-/* _statusfp bit flags */
-#define MSVCRT__SW_INEXACT      0x00000001 /* inexact (precision) */
-#define MSVCRT__SW_UNDERFLOW    0x00000002 /* underflow */
-#define MSVCRT__SW_OVERFLOW     0x00000004 /* overflow */
-#define MSVCRT__SW_ZERODIVIDE   0x00000008 /* zero divide */
-#define MSVCRT__SW_INVALID      0x00000010 /* invalid */
-
-#define MSVCRT__SW_UNEMULATED     0x00000040  /* unemulated instruction */
-#define MSVCRT__SW_SQRTNEG        0x00000080  /* square root of a neg number */
-#define MSVCRT__SW_STACKOVERFLOW  0x00000200  /* FP stack overflow */
-#define MSVCRT__SW_STACKUNDERFLOW 0x00000400  /* FP stack underflow */
-
-#define MSVCRT__SW_DENORMAL     0x00080000 /* denormal status bit */
-
 /* fpclass constants */
 #define MSVCRT__FPCLASS_SNAN 0x0001  /* Signaling "Not a Number" */
 #define MSVCRT__FPCLASS_QNAN 0x0002  /* Quiet "Not a Number" */




More information about the wine-cvs mailing list