musl - musl - an implementation of the standard library for Linux-based systems

index : musl
musl - an implementation of the standard library for Linux-based systems
summary refs log tree commit diff
path: root/src/math/exp2f.c
diff options
context:
space:
mode:
authorSzabolcs Nagy <nsz@port70.net>2012年12月16日 20:28:43 +0100
committerSzabolcs Nagy <nsz@port70.net>2012年12月16日 20:28:43 +0100
commitc6383b7b10303457306932584fc23f24b5153a81 (patch)
treeebc0a95cb34bcb501060b1679f14a19c7d92c91c /src/math/exp2f.c
parentd8a7619e371ff0f226200f6316abb46dd1192f3d (diff)
downloadmusl-c6383b7b10303457306932584fc23f24b5153a81.tar.gz
math: use 0x1p-120f and 0x1p120f for tiny and huge values
previously 0x1p-1000 and 0x1p1000 was used for raising inexact exception like x+tiny (when x is big) or x+huge (when x is small) the rational is that these float consts are large enough (0x1p-120 + 1 raises inexact even on ld128 which has 113 mant bits) and float consts maybe smaller or easier to load on some platforms (on i386 this reduced the object file size by 4bytes in some cases)
Diffstat (limited to 'src/math/exp2f.c')
-rw-r--r--src/math/exp2f.c 4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/math/exp2f.c b/src/math/exp2f.c
index 279f32de..ea50db4a 100644
--- a/src/math/exp2f.c
+++ b/src/math/exp2f.c
@@ -97,11 +97,11 @@ float exp2f(float x)
return x;
}
if (x >= 128) {
- STRICT_ASSIGN(float, x, x * 0x1p127);
+ STRICT_ASSIGN(float, x, x * 0x1p127f);
return x;
}
if (x <= -150) {
- STRICT_ASSIGN(float, x, 0x1p-100*0x1p-100);
+ STRICT_ASSIGN(float, x, 0x1p-100f*0x1p-100f);
return x;
}
} else if (ix <= 0x33000000) { /* |x| <= 0x1p-25 */
generated by cgit v1.2.1 (git 2.18.0) at 2025年10月05日 06:57:05 +0000

AltStyle によって変換されたページ (->オリジナル) /