X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fmath%2Ftanl.c;h=3b51e011b0fc5cc1a76a88d2a2c9a4da3d171fa4;hp=0194eaf7a9d88c6a4949fdc571ef4c40be9d83ac;hb=1d5ba3bb5a3f55e10db05219638cfcd967d65417;hpb=2e8c8fbe7d65ba0026cb084dc8570d94cbc908ff diff --git a/src/math/tanl.c b/src/math/tanl.c index 0194eaf7..3b51e011 100644 --- a/src/math/tanl.c +++ b/src/math/tanl.c @@ -41,42 +41,27 @@ long double tanl(long double x) long double tanl(long double x) { union IEEEl2bits z; - int e0, s; long double y[2]; - long double hi, lo; + unsigned n; z.e = x; - s = z.bits.sign; z.bits.sign = 0; - /* If x = +-0 or x is subnormal, then tan(x) = x. */ - if (z.bits.exp == 0) - return x; - /* If x = NaN or Inf, then tan(x) = NaN. */ - if (z.bits.exp == 32767) + if (z.bits.exp == 0x7fff) return (x - x) / (x - x); - /* Optimize the case where x is already within range. */ + /* |x| < (double)pi/4 */ if (z.e < M_PI_4) { - hi = __tanl(z.e, 0, 0); - return s ? -hi : hi; + /* x = +-0 or x is subnormal */ + if (z.bits.exp == 0) + /* inexact and underflow if x!=0 */ + return x + x*0x1p-120f; + /* can raise spurious underflow */ + return __tanl(x, 0, 0); } - e0 = __rem_pio2l(x, y); - hi = y[0]; - lo = y[1]; - - switch (e0 & 3) { - case 0: - case 2: - hi = __tanl(hi, lo, 0); - break; - case 1: - case 3: - hi = __tanl(hi, lo, 1); - break; - } - return hi; + n = __rem_pio2l(x, y); + return __tanl(y[0], y[1], n&1); } #endif