Retro68/gcc/newlib/libm/mathfp/sf_fabs.c

45 lines
812 B
C
Raw Normal View History

2017-04-11 21:13:36 +00:00
/* @(#)z_fabsf.c 1.0 98/08/13 */
/******************************************************************
* Floating-Point Absolute Value
*
* Input:
* x - floating-point number
*
* Output:
* absolute value of x
*
* Description:
* fabs computes the absolute value of a floating point number.
*
*****************************************************************/
#include "fdlibm.h"
#include "zmath.h"
float
2018-12-28 15:30:48 +00:00
fabsf (float x)
2017-04-11 21:13:36 +00:00
{
switch (numtestf (x))
{
case NAN:
errno = EDOM;
return (x);
case INF:
errno = ERANGE;
return (x);
case 0:
return (0.0);
default:
return (x < 0.0 ? -x : x);
}
}
#ifdef _DOUBLE_IS_32BITS
double fabs (double x)
{
return (double) fabsf ((float) x);
}
#endif /* defined(_DOUBLE_IS_32BITS) */