summaryrefslogtreecommitdiff
path: root/src/math/i386/atan.s
blob: d73137b28eb545c543338383b0a5bbc8947345a7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
.global atan
.type atan,@function
atan:
	fldl 4(%esp)
	mov 8(%esp),%eax
	add %eax,%eax
	cmp $0x00200000,%eax
	jb 1f
	fld1
	fpatan
	ret
		# subnormal x, return x with underflow
1:	fnstsw %ax
	and $16,%ax
	jnz 2f
	fsts 4(%esp)
2:	ret