summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/sparc/sparcv9/sdiv.S
blob: 45535bb684f8d50bca5d1cbebb2caa6779d62097 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/*
 * Sparc v9 has divide.
 * As divx takes 68 cycles and sdivcc only 36,
 * we use sdivcc eventhough it is deprecated.
 */

	.text
	.align		32
ENTRY(.div)

	sra		%o0, 31, %o2
	wr		%o2, 0, %y
	sdivcc		%o0, %o1, %o0
	xnor		%o0, %g0, %o2
	retl
	 movvs		%icc, %o2, %o0

END(.div)