Merged in lokeshbv/l-nuttx/libc_math (pull request #439)
Libc math: Error fixes in modf() and ceil() API's Approved-by: Gregory Nutt <gnutt@nuttx.org>
This commit is contained in:
commit
1135b96fc8
@ -41,8 +41,10 @@
|
||||
#ifdef CONFIG_HAVE_DOUBLE
|
||||
double ceil(double x)
|
||||
{
|
||||
double x1 = x;
|
||||
|
||||
modf(x, &x);
|
||||
if (x > 0.0)
|
||||
if (x1 > 0.0 && fabs(x1 - x) > 0.0)
|
||||
{
|
||||
x += 1.0;
|
||||
}
|
||||
|
@ -37,8 +37,10 @@
|
||||
|
||||
float ceilf(float x)
|
||||
{
|
||||
float x1 = x;
|
||||
|
||||
modff(x, &x);
|
||||
if (x > 0.0F)
|
||||
if (x1 > 0.0F && fabsf(x1 - x) > 0.0F)
|
||||
{
|
||||
x += 1.0F;
|
||||
}
|
||||
|
@ -41,8 +41,10 @@
|
||||
#ifdef CONFIG_HAVE_LONG_DOUBLE
|
||||
long double ceill(long double x)
|
||||
{
|
||||
long double x1 = x;
|
||||
|
||||
modfl(x, &x);
|
||||
if (x > 0.0)
|
||||
if (x1 > 0.0 && fabsl(x1 - x) > 0.0)
|
||||
{
|
||||
x += 1.0;
|
||||
}
|
||||
|
@ -46,7 +46,7 @@ double modf(double x, double *iptr)
|
||||
}
|
||||
else if (fabs(x) < 1.0)
|
||||
{
|
||||
*iptr = 0.0;
|
||||
*iptr = (x * 0.0);
|
||||
return x;
|
||||
}
|
||||
else
|
||||
|
@ -44,7 +44,7 @@ float modff(float x, float *iptr)
|
||||
}
|
||||
else if (fabsf(x) < 1.0F)
|
||||
{
|
||||
*iptr = 0.0F;
|
||||
*iptr = (x * 0.0F);
|
||||
return x;
|
||||
}
|
||||
else
|
||||
|
@ -49,7 +49,7 @@ long double modfl(long double x, long double *iptr)
|
||||
}
|
||||
else if (fabs(x) < 1.0)
|
||||
{
|
||||
*iptr = 0.0;
|
||||
*iptr = (x * 0.0);
|
||||
return x;
|
||||
}
|
||||
else
|
||||
|
Loading…
Reference in New Issue
Block a user