ntdll: Copy floor() implementation from msvcrt.
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
fca34420f6
commit
f0d3a7d33b
|
@ -191,10 +191,31 @@ double CDECL fabs( double d )
|
||||||
|
|
||||||
/*********************************************************************
|
/*********************************************************************
|
||||||
* floor (NTDLL.@)
|
* floor (NTDLL.@)
|
||||||
|
*
|
||||||
|
* Based on musl: src/math/floorf.c
|
||||||
*/
|
*/
|
||||||
double CDECL floor( double d )
|
double CDECL floor( double x )
|
||||||
{
|
{
|
||||||
return unix_funcs->floor( d );
|
union {double f; UINT64 i;} u = {x};
|
||||||
|
int e = (int)(u.i >> 52 & 0x7ff) - 0x3ff;
|
||||||
|
UINT64 m;
|
||||||
|
|
||||||
|
if (e >= 52)
|
||||||
|
return x;
|
||||||
|
if (e >= 0) {
|
||||||
|
m = 0x000fffffffffffffULL >> e;
|
||||||
|
if ((u.i & m) == 0)
|
||||||
|
return x;
|
||||||
|
if (u.i >> 63)
|
||||||
|
u.i += m;
|
||||||
|
u.i &= ~m;
|
||||||
|
} else {
|
||||||
|
if (u.i >> 63 == 0)
|
||||||
|
return 0;
|
||||||
|
else if (u.i << 1)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return u.f;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************
|
/*********************************************************************
|
||||||
|
|
Loading…
Reference in New Issue