diff options
author | Rich Felker <dalias@aerifal.cx> | 2012-03-19 05:15:30 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012-03-19 05:15:30 -0400 |
commit | 58ff9e8eaf99f2294232be860daa2ca6f3674faf (patch) | |
tree | b2fc48ab1eb651bdb5e023a3547747d558c888df /src/math/i386/scalbnf.s | |
parent | bc33e617040166e971ec1e6822ac1cc417eb6c9c (diff) | |
download | musl-58ff9e8eaf99f2294232be860daa2ca6f3674faf.tar.gz musl-58ff9e8eaf99f2294232be860daa2ca6f3674faf.tar.xz musl-58ff9e8eaf99f2294232be860daa2ca6f3674faf.zip |
asm for scalbn family
unlike some implementations, these functions perform the equivalent of gcc's -ffloat-store on the result before returning. this is necessary to raise underflow/overflow/inexact exceptions, perform the correct rounding with denormals, etc.
Diffstat (limited to 'src/math/i386/scalbnf.s')
-rw-r--r-- | src/math/i386/scalbnf.s | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/math/i386/scalbnf.s b/src/math/i386/scalbnf.s new file mode 100644 index 00000000..40232b6a --- /dev/null +++ b/src/math/i386/scalbnf.s @@ -0,0 +1,20 @@ +.global ldexpf +.type ldexpf,@function +ldexpf: + nop + +.global scalblnf +.type scalblnf,@function +scalblnf: + nop + +.global scalbnf +.type scalbnf,@function +scalbnf: + fildl 8(%esp) + flds 4(%esp) + fscale + fstp %st(1) + fstps 4(%esp) + flds 4(%esp) + ret |