1
0

__fpclassifyl.c 710 B

1234567891011121314151617181920212223242526272829303132
  1. #include "libm.h"
  2. #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
  3. #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
  4. int __fpclassifyl(long double x)
  5. {
  6. union ldshape u = {x};
  7. int e = u.i.se & 0x7fff;
  8. int msb = u.i.m>>63;
  9. if (!e && !msb)
  10. return u.i.m ? FP_SUBNORMAL : FP_ZERO;
  11. if (!msb)
  12. return FP_NAN;
  13. if (e == 0x7fff)
  14. return u.i.m << 1 ? FP_NAN : FP_INFINITE;
  15. return FP_NORMAL;
  16. }
  17. #elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
  18. int __fpclassifyl(long double x)
  19. {
  20. union ldshape u = {x};
  21. int e = u.i.se & 0x7fff;
  22. if (!e)
  23. return u.i2.lo | u.i2.hi ? FP_SUBNORMAL : FP_ZERO;
  24. if (e == 0x7fff) {
  25. u.i.se = 0;
  26. return u.i2.lo | u.i2.hi ? FP_NAN : FP_INFINITE;
  27. }
  28. return FP_NORMAL;
  29. }
  30. #endif