about summary refs log tree commit diff
path: root/src/math/i386/modf.s
blob: 8e3ea50d82f428bd5bc927139ce9b7f3455a93b3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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