176 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			176 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
.global dvu4
 | 
						|
.global dvi4
 | 
						|
.global mathdvi4
 | 
						|
 | 
						|
EIDIVZ=6
 | 
						|
 | 
						|
dvi4:
 | 
						|
! %o0' = %o0 / %o1
 | 
						|
! %o1' = %o0 % %o1
 | 
						|
	tst	%o1
 | 
						|
	be	0f
 | 
						|
	clr	%o5
 | 
						|
	tst	%o0
 | 
						|
	bge	1f
 | 
						|
	nop
 | 
						|
	neg	%o0
 | 
						|
	xor	%o5, 1, %o5
 | 
						|
1:
 | 
						|
	tst	%o1
 | 
						|
	bge	3f
 | 
						|
	nop
 | 
						|
	neg	%o1
 | 
						|
	xor	%o5, 2, %o5
 | 
						|
 | 
						|
3:	/* div common */
 | 
						|
	clr	%o2
 | 
						|
	mov	%o1, %o3
 | 
						|
	clr	%o4
 | 
						|
 | 
						|
4:
 | 
						|
	cmp	%o1, %o0
 | 
						|
	bgeu	5f
 | 
						|
	nop
 | 
						|
	inc	%o4
 | 
						|
	sll	%o1, 1, %o1
 | 
						|
	b	4b
 | 
						|
	nop
 | 
						|
 | 
						|
5:
 | 
						|
	sll	%o2, 1, %o2
 | 
						|
	subcc	%o0, %o1, %o0
 | 
						|
	bgeu	3f
 | 
						|
	nop
 | 
						|
	add	%o0, %o1, %o0
 | 
						|
	b	4f
 | 
						|
	nop
 | 
						|
3:
 | 
						|
	inc	%o2
 | 
						|
4:
 | 
						|
	srl	%o1, 1, %o1
 | 
						|
	tst	%o4
 | 
						|
	bz	5f
 | 
						|
	nop
 | 
						|
	dec	%o4
 | 
						|
	b	5b
 | 
						|
	nop
 | 
						|
 | 
						|
5:
 | 
						|
	andcc	%o5, 1, %g0
 | 
						|
	bz	6f
 | 
						|
	nop
 | 
						|
	neg	%o0
 | 
						|
	neg	%o2
 | 
						|
6:
 | 
						|
	andcc	%o5, 2, %g0
 | 
						|
	bz	8f
 | 
						|
	nop
 | 
						|
	neg	%o2
 | 
						|
8:
 | 
						|
	mov	%o0, %o1
 | 
						|
	mov	%o2, %o0
 | 
						|
	retl
 | 
						|
	nop
 | 
						|
 | 
						|
dvu4:
 | 
						|
! %o0' = %o0 / %o1
 | 
						|
! %o1' = %o0 % %o1
 | 
						|
	tst	%o1
 | 
						|
	be	0f
 | 
						|
	nop
 | 
						|
	clr	%o5
 | 
						|
	tst	%o0
 | 
						|
	bge	3f	/* jump if msb clear */
 | 
						|
	nop
 | 
						|
 | 
						|
	clr	%o2
 | 
						|
	mov	%o1, %o3
 | 
						|
	clr	%o4
 | 
						|
1:	tst	%o1
 | 
						|
	bl	5f	/* jump if msb set */
 | 
						|
	nop
 | 
						|
	sll	%o1, 1, %o1
 | 
						|
	inc	%o4
 | 
						|
	b	1b
 | 
						|
	nop
 | 
						|
 | 
						|
 | 
						|
mathdvi4:
 | 
						|
! %o0' = %o0 / %o1
 | 
						|
! %o1' = %o0 % %o1
 | 
						|
	tst	%o1
 | 
						|
	be	0f
 | 
						|
	clr	%o5
 | 
						|
	tst	%o0
 | 
						|
	bge	1f
 | 
						|
	nop
 | 
						|
	neg	%o0
 | 
						|
	xor	%o5, 1, %o5
 | 
						|
1:
 | 
						|
	tst	%o1
 | 
						|
	bge	3f
 | 
						|
	nop
 | 
						|
	neg	%o1
 | 
						|
	xor	%o5, 3, %o5
 | 
						|
 | 
						|
3:	/* div common */
 | 
						|
	clr	%o2
 | 
						|
	mov	%o1, %o3
 | 
						|
	clr	%o4
 | 
						|
 | 
						|
4:
 | 
						|
	cmp	%o1, %o0
 | 
						|
	bgeu	5f
 | 
						|
	nop
 | 
						|
	inc	%o4
 | 
						|
	sll	%o1, 1, %o1
 | 
						|
	b	4b
 | 
						|
	nop
 | 
						|
 | 
						|
5:	/* div common for dvu4 && ( %o0 & 0x80000000) */
 | 
						|
	sll	%o2, 1, %o2
 | 
						|
	subcc	%o0, %o1, %o0
 | 
						|
	bgeu	3f
 | 
						|
	nop
 | 
						|
	add	%o0, %o1, %o0
 | 
						|
	b	4f
 | 
						|
	nop
 | 
						|
3:
 | 
						|
	inc	%o2
 | 
						|
4:
 | 
						|
	srl	%o1, 1, %o1
 | 
						|
	tst	%o4
 | 
						|
	bz	5f
 | 
						|
	nop
 | 
						|
	dec	%o4
 | 
						|
	b	5b
 | 
						|
	nop
 | 
						|
 | 
						|
5:
 | 
						|
	andcc	%o5, 1, %g0
 | 
						|
	bz	6f
 | 
						|
	nop
 | 
						|
	tst	%o0
 | 
						|
	bz	7f
 | 
						|
	nop
 | 
						|
	inc	%o2
 | 
						|
	sub	%o3, %o0, %o0
 | 
						|
7:
 | 
						|
	neg	%o2
 | 
						|
6:
 | 
						|
	andcc	%o5, 2, %g0
 | 
						|
	bz	8f
 | 
						|
	nop
 | 
						|
	neg	%o0
 | 
						|
8:
 | 
						|
	mov	%o0, %o1
 | 
						|
	mov	%o2, %o0
 | 
						|
	retl
 | 
						|
	nop
 | 
						|
 | 
						|
0:					/* divide by zero */
 | 
						|
	set	EIDIVZ, %o0
 | 
						|
	call	trp
 | 
						|
	nop
 | 
						|
	retl
 | 
						|
	nop
 |