[MSVCRT]
authorJérôme Gardou <jerome.gardou@reactos.org>
Sat, 8 Dec 2012 17:44:38 +0000 (17:44 +0000)
committerJérôme Gardou <jerome.gardou@reactos.org>
Sat, 8 Dec 2012 17:44:38 +0000 (17:44 +0000)
 - Properly implement and export _fpcontrol_s

svn path=/trunk/; revision=57823

reactos/dll/win32/msvcrt/msvcrt.spec
reactos/lib/sdk/crt/float/i386/cntrlfp.c

index 2e238c7..d7d07f6 100644 (file)
 @ extern _commode
 @ cdecl _control87(long long)
 @ cdecl _controlfp(long long)
 @ extern _commode
 @ cdecl _control87(long long)
 @ cdecl _controlfp(long long)
-@ cdecl _controlfp_s(ptr long long)
+@ cdecl _controlfp_s(ptr long long)
 @ cdecl _copysign( double double )
 @ varargs _cprintf(str)
 # stub _cprintf_l
 @ cdecl _copysign( double double )
 @ varargs _cprintf(str)
 # stub _cprintf_l
index 18745ea..f3c3ccf 100644 (file)
@@ -120,15 +120,15 @@ unsigned int CDECL _control87(unsigned int newval, unsigned int mask)
 int CDECL _controlfp_s(unsigned int *cur, unsigned int newval, unsigned int mask)
 {
 #ifdef __i386__
 int CDECL _controlfp_s(unsigned int *cur, unsigned int newval, unsigned int mask)
 {
 #ifdef __i386__
-    unsigned int flags;
-
-    FIXME("(%p %u %u) semi-stub\n", cur, newval, mask);
-
-    flags = _control87( newval, mask & ~_EM_DENORMAL );
-
-    if(cur)
-        *cur = flags;
-
+    unsigned int val;
+
+    if (!MSVCRT_CHECK_PMT( !(newval & mask & ~(_MCW_EM | _MCW_IC | _MCW_RC | _MCW_PC | _MCW_DN))))
+    {
+        if (cur) *cur = _controlfp( 0, 0 );  /* retrieve it anyway */
+        return MSVCRT_EINVAL;
+    }
+    val = _controlfp( newval, mask );
+    if (cur) *cur = val;
     return 0;
 #else
     FIXME(":Not Implemented!\n");
     return 0;
 #else
     FIXME(":Not Implemented!\n");