diff options
author | bde <bde@FreeBSD.org> | 2008-02-25 18:28:58 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 2008-02-25 18:28:58 +0000 |
commit | 49cb35343eeaa02f4e480228eb7148a3305d3b70 (patch) | |
tree | 153e811e6334da38c490b98538476e022b0711ec /lib/msun/src/e_rem_pio2f.c | |
parent | b9adbf63f9fc44d962bc6da15d5b1fc48c08afb1 (diff) | |
download | FreeBSD-src-49cb35343eeaa02f4e480228eb7148a3305d3b70.zip FreeBSD-src-49cb35343eeaa02f4e480228eb7148a3305d3b70.tar.gz |
Use a temporary array instead of the arg array y[] for calling
__kernel_rem_pio2(). This simplifies analysis of aliasing and thus
results in better code for the usual case where __kernel_rem_pio2()
is not called. In particular, when __ieee854_rem_pio2[f]() is inlined,
it normally results in y[] being returned in registers. I couldn't
get this to work using the restrict qualifier.
In float precision, this saves 2-3% in most cases on amd64 and i386
(A64) despite it not being inlined in float precision yet. In double
precision, this has high variance, with an average gain of 2% for
amd64 and 0.7% for i386 (but a much larger gain for usual cases) and
some losses.
Diffstat (limited to 'lib/msun/src/e_rem_pio2f.c')
-rw-r--r-- | lib/msun/src/e_rem_pio2f.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/lib/msun/src/e_rem_pio2f.c b/lib/msun/src/e_rem_pio2f.c index 4c6ffc8..ac197ba 100644 --- a/lib/msun/src/e_rem_pio2f.c +++ b/lib/msun/src/e_rem_pio2f.c @@ -45,7 +45,7 @@ int __ieee754_rem_pio2f(float x, double *y) { double w,r,fn; - double tx[1]; + double tx[1],ty[1]; float z; int32_t e0,n,ix,hx; @@ -76,7 +76,7 @@ __ieee754_rem_pio2f(float x, double *y) e0 = (ix>>23)-150; /* e0 = ilogb(|x|)-23; */ SET_FLOAT_WORD(z, ix - ((int32_t)(e0<<23))); tx[0] = z; - n = __kernel_rem_pio2(tx,y,e0,1,0); - if(hx<0) {*y = -*y; return -n;} - return n; + n = __kernel_rem_pio2(tx,ty,e0,1,0); + if(hx<0) {*y = -ty[0]; return -n;} + *y = ty[0]; return n; } |