aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/generic/w_exp2f.c
diff options
context:
space:
mode:
Diffstat (limited to 'sysdeps/generic/w_exp2f.c')
-rw-r--r--sysdeps/generic/w_exp2f.c32
1 files changed, 32 insertions, 0 deletions
diff --git a/sysdeps/generic/w_exp2f.c b/sysdeps/generic/w_exp2f.c
new file mode 100644
index 0000000000..13cfc9a19f
--- /dev/null
+++ b/sysdeps/generic/w_exp2f.c
@@ -0,0 +1,32 @@
+/*
+ * wrapper exp2f(x)
+ */
+
+#include <float.h>
+#include "math.h"
+#include "math_private.h"
+
+static const float o_threshold= (float) FLT_MAX_EXP;
+static const float u_threshold= (float) (FLT_MIN_EXP - FLT_MANT_DIG - 1);
+
+float
+__exp2f (float x) /* wrapper exp2f */
+{
+#ifdef _IEEE_LIBM
+ return __ieee754_exp2f (x);
+#else
+ float z;
+ z = __ieee754_exp2f (x);
+ if (_LIB_VERSION != _IEEE_ && __finitef (x))
+ {
+ if (x > o_threshold)
+ /* exp2 overflow */
+ return (float) __kernel_standard ((double) x, (double) x, 144);
+ else if (x <= u_threshold)
+ /* exp2 underflow */
+ return (float) __kernel_standard ((double) x, (double) x, 145);
+ }
+ return z;
+#endif
+}
+weak_alias (__exp2f, exp2f)