X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=winsup%2Fmingw%2Fmingwex%2Fmath%2Flog1pf.S;fp=winsup%2Fmingw%2Fmingwex%2Fmath%2Flog1pf.S;h=b5b1acb7ef94f96ab144ab7872145a27fade4342;hb=ae4bf010374a9320497af260fa90af3fe8e2c5a5;hp=0000000000000000000000000000000000000000;hpb=3cc729069938336ea54d399c4bbbe7d197295f9a;p=pf3gnuchains%2Fpf3gnuchains3x.git diff --git a/winsup/mingw/mingwex/math/log1pf.S b/winsup/mingw/mingwex/math/log1pf.S new file mode 100644 index 0000000000..b5b1acb7ef --- /dev/null +++ b/winsup/mingw/mingwex/math/log1pf.S @@ -0,0 +1,47 @@ +/* + * Written by J.T. Conklin . + * Public domain. + * Removed header file dependency for use in libmingwex.a by + * Danny Smith + */ + + .file "log1pf.S" + .text + .align 4 + /* The fyl2xp1 can only be used for values in + -1 + sqrt(2) / 2 <= x <= 1 - sqrt(2) / 2 + 0.29 is a safe value. + */ +limit: .float 0.29 +one: .float 1.0 +/* + * Use the fyl2xp1 function when the argument is in the range -0.29 to 0.29, + * otherwise fyl2x with the needed extra computation. + */ +.globl _log1pf; + .def _log1pf; .scl 2; .type 32; .endef +_log1pf: + fldln2 + flds 4(%esp) + fxam + fnstsw + fld %st + sahf + jc 3f /* in case x is NaN or ±Inf */ + +4: fabs + fcomps limit + fnstsw + sahf + jc 2f + fadds one + fyl2x + ret + +2: fyl2xp1 + ret + +3: jp 4b /* in case x is ±Inf */ + fstp %st(1) + fstp %st(1) + ret