about summary refs log tree commit diff
path: root/sysdeps/sparc/sparc32/sparcv9/urem.S
blob: 76fa49edd474ad792160bbdb7e22cd94cc9a4bce (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/*
 * Sparc v9 has divide.
 * As divx takes 68 cycles and udiv only 37,
 * we use udiv even though it is deprecated.
 */

#include <sysdep.h>

	.text
	.align		32
ENTRY(.urem)

	wr		%g0, 0, %y
	udiv		%o0, %o1, %o2
	umul		%o2, %o1, %o2
	retl
	 sub		%o0, %o2, %o0

END(.urem)