loongarch64: add new syscall numbers
[musl.git] / src / math / scalbn.c
blob182f561068fda7bc8321dfc7991df8b6d58e1b56
1 #include <math.h>
2 #include <stdint.h>
4 double scalbn(double x, int n)
6 union {double f; uint64_t i;} u;
7 double_t y = x;
9 if (n > 1023) {
10 y *= 0x1p1023;
11 n -= 1023;
12 if (n > 1023) {
13 y *= 0x1p1023;
14 n -= 1023;
15 if (n > 1023)
16 n = 1023;
18 } else if (n < -1022) {
19 /* make sure final n < -53 to avoid double
20 rounding in the subnormal range */
21 y *= 0x1p-1022 * 0x1p53;
22 n += 1022 - 53;
23 if (n < -1022) {
24 y *= 0x1p-1022 * 0x1p53;
25 n += 1022 - 53;
26 if (n < -1022)
27 n = -1022;
30 u.i = (uint64_t)(0x3ff+n)<<52;
31 x = y * u.f;
32 return x;