about summary refs log tree commit diff
path: root/src/math/i386/modfl.s
diff options
context:
space:
mode:
Diffstat (limited to 'src/math/i386/modfl.s')
-rw-r--r--src/math/i386/modfl.s28
1 files changed, 28 insertions, 0 deletions
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