#include "SDL_internal.h"
#include "math_libm.h"
#include "math_private.h"
#include <limits.h>
static const double
two54 = 1.80143985094819840000e+16,
twom54 = 5.55111512312578270212e-17,
huge = 1.0e+300,
tiny = 1.0e-300;
double scalbln(double x, long n)
{
int32_t k, hx, lx;
EXTRACT_WORDS(hx, lx, x);
k = (hx & 0x7ff00000) >> 20;
if (k == 0) {
if ((lx | (hx & 0x7fffffff)) == 0)
return x;
x *= two54;
GET_HIGH_WORD(hx, x);
k = ((hx & 0x7ff00000) >> 20) - 54;
}
if (k == 0x7ff)
return x + x;
k = (int32_t)(k + n);
if (k > 0x7fe)
return huge * copysign(huge, x);
if (n < -50000)
return tiny * copysign(tiny, x);
if (k > 0) {
SET_HIGH_WORD(x, (hx & 0x800fffff) | (k << 20));
return x;
}
if (k <= -54) {
if (n > 50000)
return huge * copysign(huge, x);
return tiny * copysign(tiny, x);
}
k += 54;
SET_HIGH_WORD(x, (hx & 0x800fffff) | (k << 20));
return x * twom54;
}
libm_hidden_def(scalbln)
double scalbn(double x, int n)
{
return scalbln(x, n);
}
libm_hidden_def(scalbn)