lang-bootstrap/05/musl-final/src/math/__fpclassifyl.c
2025-04-05 10:55:40 +01:00

16 lines
372 B
C

#include <stdint.h>
#include <math.h>
/* FIXME: move this to arch-specific file */
int __fpclassifyl(long double __x)
{
union {
long double __ld;
__uint16_t __hw[5];
__uint64_t __m;
} __y = { __x };
int __ee = __y.__hw[4]&0x7fff;
if (!__ee) return __y.__m ? FP_SUBNORMAL : FP_ZERO;
if (__ee==0x7fff) return __y.__m ? FP_NAN : FP_INFINITE;
return FP_NORMAL;
}