diff options
author | Szabolcs Nagy <nsz@port70.net> | 2013-09-04 15:52:23 +0000 |
---|---|---|
committer | Szabolcs Nagy <nsz@port70.net> | 2013-09-05 11:30:08 +0000 |
commit | 34660d73bd0db29469d2758e1b48d2360edf3a2f (patch) | |
tree | d803e3693b46e4bfe258c4d284fc5c3f7878daae /src/math/scalbnl.c | |
parent | 535104ab6a2d6f22098f79e7107963e3fc3448a3 (diff) | |
download | musl-34660d73bd0db29469d2758e1b48d2360edf3a2f.tar.gz musl-34660d73bd0db29469d2758e1b48d2360edf3a2f.tar.bz2 musl-34660d73bd0db29469d2758e1b48d2360edf3a2f.tar.xz musl-34660d73bd0db29469d2758e1b48d2360edf3a2f.zip |
math: fix remaining old long double code (erfl, fmal, lgammal, scalbnl)
in lgammal don't handle 1 and 2 specially, in fma use the new ldshape
union instead of ld80 one.
Diffstat (limited to 'src/math/scalbnl.c')
-rw-r--r-- | src/math/scalbnl.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/math/scalbnl.c b/src/math/scalbnl.c index 7ad7688b..08a4c587 100644 --- a/src/math/scalbnl.c +++ b/src/math/scalbnl.c @@ -8,7 +8,7 @@ long double scalbnl(long double x, int n) #elif (LDBL_MANT_DIG == 64 || LDBL_MANT_DIG == 113) && LDBL_MAX_EXP == 16384 long double scalbnl(long double x, int n) { - union IEEEl2bits scale; + union ldshape u; if (n > 16383) { x *= 0x1p16383L; @@ -29,8 +29,8 @@ long double scalbnl(long double x, int n) n = -16382; } } - scale.e = 1.0; - scale.bits.exp = 0x3fff + n; - return x * scale.e; + u.f = 1.0; + u.i.se = 0x3fff + n; + return x * u.f; } #endif |