/*
 * wrapper exp2f(x)
 */

#include <math.h>
#include "math_private.h"

float
exp2f (float x)
{
#if defined(__UCLIBC_HAS_FENV__)
  float z = (float) pow(2.0, (double) x);
  if (__builtin_expect (!isfinite (z) || z == 0, 0)
      && isfinite (x) && _LIB_VERSION != _IEEE_)
    /* exp2 overflow: 144, exp2 underflow: 145 */
    return __kernel_standard_f (x, x, 144 + !!signbit (x));

  return z;
#else
  return (float) pow(2.0, (double) x);
#endif
}