math: raise invalid flag in ilogb*.c on +-0, +-inf and nan
[musl] / src / math / ilogb.c
index 0a3a6a4..5a1819d 100644 (file)
@@ -8,13 +8,17 @@ int ilogb(double x)
 
        if (!e) {
                u.bits <<= 12;
-               if (u.bits == 0)
+               if (u.bits == 0) {
+                       FORCE_EVAL(0/0.0f);
                        return FP_ILOGB0;
+               }
                /* subnormal x */
                for (e = -0x3ff; u.bits < (uint64_t)1<<63; e--, u.bits<<=1);
                return e;
        }
-       if (e == 0x7ff)
+       if (e == 0x7ff) {
+               FORCE_EVAL(0/0.0f);
                return u.bits<<12 ? FP_ILOGBNAN : INT_MAX;
+       }
        return e - 0x3ff;
 }