blob: d1b6d8bb2acbc22a49eef319e9d0968b03bc190e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include <math.h> // for FP_INFINITE, FP_NAN, FP_NORMAL, FP_SUBNORMAL
#include <stdint.h> // for uint32_t
int __fpclassifyf(float x)
{
union {
float f;
uint32_t i;
} u = { x };
int e = u.i >> 23 & 0xff;
if (!e)
return u.i << 1 ? FP_SUBNORMAL : FP_ZERO;
if (e == 0xff)
return u.i << 9 ? FP_NAN : FP_INFINITE;
return FP_NORMAL;
}
|