diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/math/i386/modf.s | 28 | ||||
-rw-r--r-- | src/math/i386/modff.s | 28 | ||||
-rw-r--r-- | src/math/i386/modfl.s | 28 |
3 files changed, 84 insertions, 0 deletions
diff --git a/src/math/i386/modf.s b/src/math/i386/modf.s new file mode 100644 index 00000000..8e3ea50d --- /dev/null +++ b/src/math/i386/modf.s @@ -0,0 +1,28 @@ +.global modf +.type modf,@function +modf: + mov 12(%esp),%ecx + fldl 4(%esp) + fxam + fnstsw %ax + sahf + jnp 1f + jc 2f +1: fld1 + fld %st(1) +1: fprem + fnstsw %ax + sahf + jp 1b + fstp %st(1) + fsubr %st(0),%st(1) + fxch %st(1) + fstpl (%ecx) + ret + +2: fstpl (%ecx) + mov 4(%ecx),%eax + and $0x80000000,%eax + mov %eax,4(%esp) + flds 4(%esp) + ret diff --git a/src/math/i386/modff.s b/src/math/i386/modff.s new file mode 100644 index 00000000..35a08ca9 --- /dev/null +++ b/src/math/i386/modff.s @@ -0,0 +1,28 @@ +.global modff +.type modff,@function +modff: + mov 8(%esp),%ecx + flds 4(%esp) + fxam + fnstsw %ax + sahf + jnp 1f + jc 2f +1: fld1 + fld %st(1) +1: fprem + fnstsw %ax + sahf + jp 1b + fstp %st(1) + fsubr %st(0),%st(1) + fxch %st(1) + fstps (%ecx) + ret + +2: fstps (%ecx) + mov (%ecx),%eax + and $0x80000000,%eax + mov %eax,4(%esp) + flds 4(%esp) + ret diff --git a/src/math/i386/modfl.s b/src/math/i386/modfl.s new file mode 100644 index 00000000..d650debb --- /dev/null +++ b/src/math/i386/modfl.s @@ -0,0 +1,28 @@ +.global modfl +.type modfl,@function +modfl: + mov 16(%esp),%ecx + fldt 4(%esp) + fxam + fnstsw %ax + sahf + jnp 1f + jc 2f +1: fld1 + fld %st(1) +1: fprem + fnstsw %ax + sahf + jp 1b + fstp %st(1) + fsubr %st(0),%st(1) + fxch %st(1) + fstpt (%ecx) + ret + +2: fstpt (%ecx) + mov 6(%ecx),%eax + and $0x80000000,%eax + mov %eax,4(%esp) + flds 4(%esp) + ret |