38 lines
524 B
ArmAsm
38 lines
524 B
ArmAsm
.define .dvu
|
|
.sect .text
|
|
.sect .rom
|
|
.sect .data
|
|
.sect .bss
|
|
|
|
! unsigned long divide
|
|
! register usage:
|
|
! : d0 divisor
|
|
! d1 dividend
|
|
! exit : d1 quotient
|
|
! d2 remainder
|
|
.sect .text
|
|
.dvu:
|
|
move.l (sp)+,a1 ! return address
|
|
move.l (sp)+,d0
|
|
move.l (sp)+,d1
|
|
move.l d3,-(sp) ! save d3
|
|
tst.l d0
|
|
bne 0f
|
|
move.l (sp)+,d3
|
|
move.w #EIDIVZ,-(sp)
|
|
jsr .trp
|
|
0:
|
|
clr.l d2
|
|
move.l #32,d3
|
|
3:
|
|
lsl.l #1,d1
|
|
roxl.l #1,d2
|
|
cmp.l d0,d2
|
|
blt 4f
|
|
sub.l d0,d2
|
|
add #1,d1
|
|
4:
|
|
sub #1,d3
|
|
bgt 3b
|
|
move.l (sp)+,d3
|
|
jmp (a1)
|