add armwrestler.
This commit is contained in:
parent
533c294023
commit
6a04e0323a
|
@ -155,6 +155,7 @@
|
|||
<TargetName Condition="'$(Configuration)|$(Platform)'=='Release|x64'">$(ProjectName)_x64_release</TargetName>
|
||||
<TargetName Condition="'$(Configuration)|$(Platform)'=='Dev+|x64'">$(ProjectName)_x64_dev+</TargetName>
|
||||
<TargetName Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">$(ProjectName)_x64_debug</TargetName>
|
||||
<TargetName Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(ProjectName)</TargetName>
|
||||
</PropertyGroup>
|
||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||
<PreBuildEvent>
|
||||
|
|
|
@ -0,0 +1,10 @@
|
|||
@ armwrestler arm7 binary
|
||||
@ mic, 2006
|
||||
|
||||
.text
|
||||
.global arm7_main
|
||||
|
||||
arm7_main:
|
||||
b arm7_main
|
||||
|
||||
.end
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,5 @@
|
|||
.arm
|
||||
|
||||
.include "armwrestler-ds.asm"
|
||||
.include "thumbwrestler-ds.asm"
|
||||
|
Binary file not shown.
|
@ -0,0 +1,10 @@
|
|||
arm-eabi-as -march=armv5te -mthumb -EL -o armwrestler9.o armwrestler9.asm
|
||||
arm-eabi-ld -Ttext 0x02004000 -EL -e main armwrestler9.o
|
||||
arm-eabi-objcopy -O binary a.out armwrestler.arm9
|
||||
arm-eabi-as -mcpu=arm7tdmi -EL -o armwrestler-arm7.o armwrestler-arm7.asm
|
||||
arm-eabi-ld -Ttext 0x3800000 -EL -e arm7_main armwrestler-arm7.o
|
||||
arm-eabi-objcopy -O binary a.out armwrestler.arm7
|
||||
ndstool -c armwrestler.nds -r9 0x2004000 -e9 0x2004000 -r7 0x3800000 -e7 0x3800000 -9 armwrestler.arm9 -7 armwrestler.arm7
|
||||
del *.o
|
||||
del a.out
|
||||
pause
|
|
@ -0,0 +1,904 @@
|
|||
@ Thumbwrestler
|
||||
@ mic, 2005-2006 | micol972@gmail.com
|
||||
@
|
||||
@ Runs THUMB instructions and checks for valid results. Useful for people developing THUMB emulators
|
||||
@ Compile with devkitarm
|
||||
|
||||
.text
|
||||
.global _tmbmain
|
||||
.thumb
|
||||
|
||||
.equ VARBASE, 0x2200000
|
||||
.equ TESTNUM, (VARBASE+8)
|
||||
.equ CURSEL, (VARBASE+16)
|
||||
.equ C_MASK, 0x01
|
||||
.equ C_SHIFT, 0
|
||||
.equ V_MASK, 0x02
|
||||
.equ V_SHIFT, 1
|
||||
.equ Rd_MASK, 0x100
|
||||
.equ Rd_SHIFT, 8
|
||||
|
||||
|
||||
.macro TEST_Rd reg val
|
||||
|
||||
cmp \reg,\val
|
||||
beq 1f
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
1:
|
||||
.endm
|
||||
|
||||
|
||||
_tmbmain:
|
||||
mov r0,#0
|
||||
|
||||
|
||||
_forever:
|
||||
bl _vsync
|
||||
|
||||
mov r1,r10
|
||||
cmp r1,#0
|
||||
beq _no_cls
|
||||
bl _clearscreen
|
||||
mov r1,#0
|
||||
_no_cls:
|
||||
mov r10,r1
|
||||
|
||||
mov r7,#16
|
||||
mov r5,#1
|
||||
|
||||
ldr r0,=TESTNUM
|
||||
ldr r1,[r0]
|
||||
bl _runtest
|
||||
|
||||
ldr r0,=szStart
|
||||
mov r1,#20
|
||||
mov r2,#151
|
||||
mov r3,#5
|
||||
bl _drawtext
|
||||
ldr r0,=szNext
|
||||
mov r1,#76
|
||||
mov r2,#151
|
||||
mov r3,#4
|
||||
bl _drawtext
|
||||
ldr r0,=szSelect2
|
||||
mov r1,#132
|
||||
mov r2,#151
|
||||
mov r3,#5
|
||||
bl _drawtext
|
||||
ldr r0,=szMenu
|
||||
mov r1,#192
|
||||
mov r2,#151
|
||||
mov r3,#4
|
||||
bl _drawtext
|
||||
|
||||
bl _checkkeys
|
||||
|
||||
mov r3,#0x4
|
||||
tst r2,r3
|
||||
beq not_select_tmb
|
||||
bl _menu
|
||||
not_select_tmb:
|
||||
|
||||
mov r3,#0x8
|
||||
tst r2,r3
|
||||
beq not_start_tmb
|
||||
ldr r0,=TESTNUM
|
||||
ldr r1,[r0]
|
||||
add r1,#1
|
||||
str r1,[r0]
|
||||
mov r10,r1
|
||||
not_start_tmb:
|
||||
|
||||
b _forever
|
||||
|
||||
.align
|
||||
.pool
|
||||
|
||||
|
||||
_runtest:
|
||||
push {lr}
|
||||
lsl r1,r1,#2 @ r1 *= sizeof(word)
|
||||
ldr r0,=_jumptable
|
||||
mov r2,#1
|
||||
add r0,r1
|
||||
ldr r1,[r0] @ r1 = jumptable[test_number]
|
||||
orr r1,r2 @ We want to stay in Thumb mode
|
||||
bx r1
|
||||
|
||||
|
||||
_clearscreen:
|
||||
ldr r0,=0x6800000
|
||||
mov r4,#0
|
||||
ldr r5,=24576
|
||||
_cs_repeat:
|
||||
str r4,[r0]
|
||||
add r0,#4
|
||||
sub r5,#1
|
||||
bne _cs_repeat
|
||||
bx lr
|
||||
|
||||
|
||||
.align 1
|
||||
_test0:
|
||||
ldr r0,=_szALU
|
||||
mov r1,#88
|
||||
mov r2,#1
|
||||
mov r3,#4
|
||||
bl _drawtext
|
||||
|
||||
@ ADD
|
||||
mov r6,#0
|
||||
mov r0,#0
|
||||
mov r1,#1
|
||||
mov r2,#4
|
||||
mov r3,#5
|
||||
add r0,r1,#2
|
||||
TEST_Rd r0,#3
|
||||
add r0,r1,r2
|
||||
TEST_Rd r0,#5
|
||||
mov r0,#2
|
||||
mov r1,#0
|
||||
mov r2,#0
|
||||
add r1,r1,#0 @ clear carry
|
||||
add r0,r11
|
||||
bcc _add_ok_1
|
||||
orr r6,r5
|
||||
_add_ok_1:
|
||||
TEST_Rd r0,#1
|
||||
mov r0,#0
|
||||
add r0,pc,#4
|
||||
beq _add_ok_2
|
||||
lsl r4,r5,#3
|
||||
_add_labelpc:
|
||||
orr r6,r4
|
||||
_add_ok_2:
|
||||
ldr r1,=_add_labelpc
|
||||
TEST_Rd r0,r1
|
||||
|
||||
ldr r0,=0xFFFFFF01
|
||||
mov r1,r0
|
||||
add r0,#0xFF
|
||||
beq _add_ok_3
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_add_ok_3:
|
||||
TEST_Rd r0,#0
|
||||
add r1,#0xFF
|
||||
bcs _add_ok_4
|
||||
orr r6,r5
|
||||
_add_ok_4:
|
||||
ldr r0,=_szADD
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
|
||||
@ ASR
|
||||
mov r6,#0
|
||||
|
||||
@ Test ASR by imm==32
|
||||
ldr r0,=0x80000000
|
||||
ldr r1,=0xFFFFFFFF
|
||||
mov r2,#0
|
||||
add r2,r2,#0 @ clear carry
|
||||
asr r0,r0,#32
|
||||
bcs _asr_ok_1
|
||||
orr r6,r5
|
||||
_asr_ok_1:
|
||||
TEST_Rd r1,r0
|
||||
|
||||
ldr r0,=0x80000000
|
||||
asr r0,r0,#32
|
||||
bmi _asr_ok_3
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_asr_ok_3:
|
||||
ldr r0,=0x80000000
|
||||
asr r0,r0,#32
|
||||
bne _asr_ok_4
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_asr_ok_4:
|
||||
ldr r0,=_szASR
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ BIC
|
||||
mov r1,#0
|
||||
add r2,r2,#0 @ clear carry
|
||||
ldr r2,=0xFFFFFFFF
|
||||
ldr r3,=0xC000000D
|
||||
bic r2,r3
|
||||
bcc _bic_cc
|
||||
bmi _bic_mi
|
||||
beq _bic_eq
|
||||
|
||||
_bic_cc:
|
||||
mov r3,#1
|
||||
orr r1,r3
|
||||
b _bic_fin
|
||||
|
||||
_bic_mi:
|
||||
mov r3,#2
|
||||
orr r1,r3
|
||||
b _bic_fin
|
||||
|
||||
_bic_eq:
|
||||
mov r3,#8
|
||||
orr r1,r3
|
||||
b _bic_fin
|
||||
|
||||
_bic_fin:
|
||||
ldr r3,=0x1FFFFFF9
|
||||
cmp r2,r3
|
||||
bne _bic_ne
|
||||
b _bic_fin2
|
||||
|
||||
_bic_ne:
|
||||
mov r3,#16
|
||||
orr r1,r3
|
||||
b _bic_fin2
|
||||
|
||||
_bic_fin2:
|
||||
ldr r0,=_szBIC
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ CMP
|
||||
mov r6,#0
|
||||
|
||||
mov r0, #1
|
||||
neg r1,r0
|
||||
cmp r1,#0
|
||||
blt cmp_end
|
||||
mov r6,#V_MASK
|
||||
|
||||
cmp_end:
|
||||
ldr r0,=_szCMP
|
||||
bl _drawresult
|
||||
|
||||
add r7,#8
|
||||
|
||||
@ LSL
|
||||
mov r6,#0
|
||||
|
||||
@ Test LSL by reg==32
|
||||
mov r0,#3
|
||||
mov r1,#32
|
||||
lsl r0,r1
|
||||
bcs _lsl_ok_1
|
||||
orr r6,r5
|
||||
_lsl_ok_1:
|
||||
cmp r0,#0
|
||||
beq _lsl_ok_2
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_lsl_ok_2:
|
||||
mov r0,#3
|
||||
lsl r0,r1
|
||||
bpl _lsl_ok_3
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_lsl_ok_3:
|
||||
mov r0,#3
|
||||
lsl r0,r1
|
||||
beq _lsl_ok_4
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_lsl_ok_4:
|
||||
ldr r0,=_szLSL
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
|
||||
@ LSR
|
||||
mov r6,#0
|
||||
|
||||
@ Test LSR by imm==32
|
||||
ldr r0,=0x80000000
|
||||
mov r1,#2
|
||||
mov r2,#0
|
||||
|
||||
add r2,r2,#0 @ clear carry
|
||||
lsr r1,r0,#32
|
||||
bcs _lsr_ok_1
|
||||
orr r6,r5
|
||||
_lsr_ok_1:
|
||||
cmp r1,#0
|
||||
beq _lsr_ok_2
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_lsr_ok_2:
|
||||
ldr r0,=_szLSR
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
|
||||
@ MUL
|
||||
mov r6,#0
|
||||
|
||||
mov r0,#1
|
||||
mov r1,#20
|
||||
ldr r2,=0xFFFFFFF6
|
||||
ldr r3,=0xFFFFFF38
|
||||
|
||||
lsr r0,r0,#1 @ set carry
|
||||
mul r1,r2
|
||||
@bcs _mul_ok_1
|
||||
@orr r6,r5
|
||||
@_mul_ok_1:
|
||||
TEST_Rd r1,r3
|
||||
mov r1,#20
|
||||
mul r1,r2
|
||||
bmi _mul_ok_2
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_mul_ok_2:
|
||||
mov r1,#20
|
||||
mul r1,r2
|
||||
bne _mul_ok_3
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_mul_ok_3:
|
||||
ldr r0,=_szMUL
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
|
||||
@ MVN
|
||||
mov r6,#0
|
||||
|
||||
ldr r0,=0xFFFFFF00
|
||||
mvn r0,r0
|
||||
bpl _mvn_ok_1
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_mvn_ok_1:
|
||||
TEST_Rd r0,#0xFF
|
||||
ldr r0,=_szMVN
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
|
||||
@ NEG
|
||||
mov r6,#0
|
||||
|
||||
mov r0,#1
|
||||
neg r1,r0
|
||||
bne _neg_ok_1
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_neg_ok_1:
|
||||
neg r1,r0
|
||||
bmi _neg_ok_2
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_neg_ok_2:
|
||||
neg r1,r1
|
||||
bpl _neg_ok_3
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_neg_ok_3:
|
||||
neg r0,r0
|
||||
ldr r2,=0xFFFFFFFF
|
||||
TEST_Rd r0,r2
|
||||
ldr r0,=_szNEG
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ SUB
|
||||
mov r6,#0
|
||||
|
||||
mov r0, #1
|
||||
neg r1,r0
|
||||
sub r2,r1,#1
|
||||
blt sub_end
|
||||
mov r6,#V_MASK
|
||||
|
||||
sub_end:
|
||||
ldr r0,=_szSUB
|
||||
bl _drawresult
|
||||
|
||||
add r7,#8
|
||||
|
||||
@ ROR
|
||||
mov r6,#0
|
||||
|
||||
@ Test ROR by reg==0
|
||||
ldr r0,=0x80000000
|
||||
mov r1,r0
|
||||
mov r2,#1
|
||||
mov r3,#0
|
||||
lsr r2,r2,#1 @ set carry
|
||||
ror r0,r3
|
||||
bcs _ror_ok_1
|
||||
orr r6,r5
|
||||
_ror_ok_1:
|
||||
cmp r0,r1
|
||||
beq _ror_ok_2
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_ror_ok_2:
|
||||
|
||||
@ Test ROR by reg==16
|
||||
ldr r0,=0x80000000
|
||||
ldr r1,=0x8000
|
||||
mov r2,#1
|
||||
mov r3,#16
|
||||
lsr r2,r2,#1 @ set carry
|
||||
ror r0,r3
|
||||
cmp r0,r1
|
||||
bcs _ror_ok_3
|
||||
orr r6,r5
|
||||
_ror_ok_3:
|
||||
cmp r0,r1
|
||||
beq _ror_ok_4
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_ror_ok_4:
|
||||
|
||||
@ Test ROR by reg>32
|
||||
ldr r0,=0x80000000
|
||||
mov r1,#66
|
||||
ror r0,r1
|
||||
bcc _ror_ok_5
|
||||
|
||||
orr r6,r5
|
||||
_ror_ok_5:
|
||||
ldr r2,=0x20000000
|
||||
cmp r0,r2
|
||||
beq _ror_ok_6
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_ror_ok_6:
|
||||
|
||||
@ Test ROR by reg==32
|
||||
ldr r0,=0x80000000
|
||||
mov r2,r0
|
||||
mov r1,#32
|
||||
ror r0,r1
|
||||
bcs _ror_ok_7
|
||||
orr r6,r5
|
||||
_ror_ok_7:
|
||||
ldr r0,=0x80000000
|
||||
ror r0,r1
|
||||
bmi _ror_ok_8
|
||||
lsl r4,r5,#1
|
||||
orr r6,r4
|
||||
_ror_ok_8:
|
||||
ldr r0,=0x80000000
|
||||
ror r0,r1
|
||||
bne _ror_ok_9
|
||||
lsl r4,r5,#3
|
||||
orr r6,r4
|
||||
_ror_ok_9:
|
||||
cmp r0,r2
|
||||
beq _ror_ok_10
|
||||
lsl r4,r5,#Rd_SHIFT
|
||||
orr r6,r4
|
||||
_ror_ok_10:
|
||||
ldr r0,=_szROR
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
pop {pc}
|
||||
.pool
|
||||
.align
|
||||
|
||||
|
||||
_test1:
|
||||
ldr r0,=_szLDR1
|
||||
mov r1,#64
|
||||
mov r2,#1
|
||||
mov r3,#4
|
||||
bl _drawtext
|
||||
|
||||
@ LDR Rd,[Rb,#imm]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2-2
|
||||
ldr r1,[r0,#4]
|
||||
ldr r2,=0x8f00ff00
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDR
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDR Rd,[Rb,Ro]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0x8f00ff00
|
||||
mov r3,#2
|
||||
ldr r1,[r0,r3]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDR
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDRB Rd,[Rb,Ro]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0x8f
|
||||
mov r3,#1
|
||||
ldrb r1,[r0,r3]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDRB
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDRH Rd,[Rb,Ro]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0x8f00
|
||||
mov r3,#0
|
||||
ldrh r1,[r0,r3]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDRH1
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDRH Rd,[Rb,#nn]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0x8f00
|
||||
ldrh r1,[r0,#0]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDRH2
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDRSH Rd,[Rb,Ro]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0xFFFF8F00
|
||||
mov r3,#0
|
||||
ldsh r1,[r0,r3]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDRSH
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ LDRSB Rd,[Rb,Ro]
|
||||
mov r6,#0
|
||||
ldr r0,=romvar2
|
||||
ldr r2,=0xFFFFFF8F
|
||||
mov r3,#1
|
||||
ldsb r1,[r0,r3]
|
||||
TEST_Rd r1,r2
|
||||
ldr r0,=_szLDRSB
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
pop {pc}
|
||||
.pool
|
||||
.align 1
|
||||
|
||||
|
||||
_test2:
|
||||
ldr r0,=_szLDM1
|
||||
mov r1,#72
|
||||
mov r2,#1
|
||||
mov r3,#4
|
||||
bl _drawtext
|
||||
|
||||
|
||||
@ LDMIA Rb!,{Rlist}
|
||||
mov r6,#0 @clear flags
|
||||
mov r1,#0
|
||||
ldr r3,=_var64
|
||||
sub r3,r3,#4
|
||||
ldmia r3!,{r1,r2}
|
||||
ldr r0,=_var64+4
|
||||
cmp r3,r0
|
||||
beq _ldm_r2_r0
|
||||
b _ldm_done
|
||||
|
||||
_ldm_r2_r0:
|
||||
ldr r0,=_var64
|
||||
ldr r0,[r0]
|
||||
cmp r1,r0
|
||||
beq _ldm_r1_r0
|
||||
b _ldm_done
|
||||
|
||||
_ldm_r1_r0:
|
||||
ldr r0,=_var64+4
|
||||
ldr r0,[r0]
|
||||
cmp r2,r0
|
||||
|
||||
_ldm_done:
|
||||
ldr r0,=_szLDMIA
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
@ STMIA Rb!,{Rlist}
|
||||
mov r6,#0 @clear flags
|
||||
ldr r1,=0x44332211
|
||||
ldr r2,=0x88776655
|
||||
ldr r3,=_tvar64
|
||||
sub r3,r3,#4
|
||||
stmia r3!,{r1,r2}
|
||||
ldr r0,=_tvar64+4
|
||||
cmp r3,r0
|
||||
beq _stm_r2_r0
|
||||
b _stm_done
|
||||
|
||||
_stm_r2_r0:
|
||||
ldr r0,=_tvar64
|
||||
ldr r0,[r0]
|
||||
cmp r1,r0
|
||||
beq _stm_r1_r0
|
||||
b _stm_done
|
||||
|
||||
_stm_r1_r0:
|
||||
ldr r0,=_tvar64+4
|
||||
ldr r0,[r0]
|
||||
cmp r2,r0
|
||||
|
||||
_stm_done:
|
||||
ldr r0,=_szSTMIA
|
||||
bl _drawresult
|
||||
add r7,#8
|
||||
|
||||
pop {pc}
|
||||
|
||||
|
||||
_menu:
|
||||
pop {r1} @ Remove the return address from the stack
|
||||
ldr r4,=TESTNUM
|
||||
mov r0,#1
|
||||
mov r10,r0 @ Clear screen needed
|
||||
mov r3,#10 @ 10 = Menu
|
||||
strb r3,[r4]
|
||||
|
||||
ldr r0,=forever
|
||||
bx r0 @ Branch back to ARM code
|
||||
|
||||
|
||||
|
||||
_vsync:
|
||||
push {r0-r1,lr}
|
||||
ldr r0,=0x4000004
|
||||
_vs_loop_1:
|
||||
ldrh r1,[r0]
|
||||
lsr r1,r1,#1
|
||||
bcs _vs_loop_1
|
||||
|
||||
_vs_loop_2:
|
||||
ldrh r1,[r0]
|
||||
lsr r1,r1,#1
|
||||
bcc _vs_loop_2
|
||||
|
||||
pop {r0-r1,pc}
|
||||
.align
|
||||
.pool
|
||||
|
||||
|
||||
|
||||
_checkkeys:
|
||||
push {lr}
|
||||
|
||||
ldr r0,=0x4000130
|
||||
ldrh r2,[r0]
|
||||
ldr r0,=(VARBASE+12)
|
||||
ldrh r3,[r0]
|
||||
mov r5,#0xff
|
||||
and r2,r5
|
||||
eor r2,r5
|
||||
strh r2,[r0]
|
||||
cmp r2,#0
|
||||
beq _ck_no_mask
|
||||
eor r2,r3
|
||||
_ck_no_mask:
|
||||
pop {pc}
|
||||
|
||||
.align
|
||||
.pool
|
||||
|
||||
|
||||
_drawresult:
|
||||
@ r0: lpszText
|
||||
@ r6: bitmask
|
||||
push {r4-r5,lr}
|
||||
|
||||
mov r1,#16
|
||||
mov r2,r7
|
||||
mov r3,#3
|
||||
bl _drawtext
|
||||
|
||||
cmp r6,#0
|
||||
beq _dr_ok
|
||||
|
||||
ldr r0,=_szBad
|
||||
mov r1,#72
|
||||
mov r2,r7
|
||||
mov r3,#2
|
||||
bl _drawtext
|
||||
|
||||
mov r5,#C_MASK
|
||||
ldr r0,=_szC
|
||||
mov r1,#104
|
||||
mov r2,r7
|
||||
mov r3,#2
|
||||
_dr_test_flags:
|
||||
tst r6,r5
|
||||
beq _dr_flag_ok
|
||||
bl _drawtext
|
||||
_dr_flag_ok:
|
||||
add r0,#2
|
||||
add r1,#8
|
||||
lsl r5,r5,#1
|
||||
cmp r5,#16
|
||||
bne _dr_test_flags
|
||||
|
||||
mov r5,#V_MASK
|
||||
ldr r0,=_szV
|
||||
mov r1,#112
|
||||
mov r2,r7
|
||||
mov r3,#2
|
||||
_dv_test_flags:
|
||||
tst r6,r5
|
||||
beq _dv_flag_ok
|
||||
bl _drawtext
|
||||
_dv_flag_ok:
|
||||
add r0,#2
|
||||
add r1,#8
|
||||
lsl r5,r5,#1
|
||||
cmp r5,#16
|
||||
bne _dv_test_flags
|
||||
|
||||
ldr r5,=Rd_MASK
|
||||
tst r6,r5
|
||||
beq _dr_rd_ok
|
||||
ldr r0,=_szRd
|
||||
mov r1,#144
|
||||
mov r2,r7
|
||||
mov r3,#2
|
||||
bl _drawtext
|
||||
_dr_rd_ok:
|
||||
|
||||
b _dr_done
|
||||
|
||||
_dr_ok:
|
||||
ldr r0,=_szOK
|
||||
mov r1,#72
|
||||
mov r2,r7
|
||||
mov r3,#1
|
||||
bl _drawtext
|
||||
|
||||
_dr_done:
|
||||
pop {r4-r5,pc}
|
||||
.align
|
||||
.pool
|
||||
|
||||
|
||||
|
||||
_drawtext:
|
||||
@ r0: lpszText
|
||||
@ r1: x
|
||||
@ r2: y
|
||||
@ r3: color
|
||||
push {r0-r7,lr}
|
||||
|
||||
ldr r6,=palette
|
||||
lsl r3,r3,#1
|
||||
ldrh r3,[r6,r3]
|
||||
|
||||
@ r7 = 0x6800000 + y*512 + x*2
|
||||
mov r6,#0x68
|
||||
lsl r7,r2,#9
|
||||
lsl r6,r6,#20
|
||||
lsl r1,r1,#1
|
||||
add r7,r1
|
||||
add r7,r6
|
||||
|
||||
_dt_chrloop:
|
||||
ldrb r1,[r0]
|
||||
ldr r6,=font
|
||||
add r0,#1
|
||||
cmp r1,#0
|
||||
beq _dt_null
|
||||
|
||||
cmp r1,#32
|
||||
beq _dt_space
|
||||
sub r1,#37
|
||||
lsl r1,r1,#6
|
||||
add r6,r1
|
||||
_dt_space:
|
||||
|
||||
push {r7}
|
||||
mov r4,#8
|
||||
_dt_yloop:
|
||||
push {r4}
|
||||
mov r4,#8
|
||||
mov r5,#0xFF
|
||||
_dt_xloop:
|
||||
ldrb r1,[r6]
|
||||
@lsr r2,r1,#8
|
||||
add r6,#1
|
||||
and r1,r5
|
||||
beq _dt_pixel_1_0
|
||||
mov r1,r3
|
||||
_dt_pixel_1_0:
|
||||
@and r2,r5
|
||||
@beq _dt_pixel_2_0
|
||||
@mov r2,r3
|
||||
@_dt_pixel_2_0:
|
||||
@lsl r2,r2,#8
|
||||
@orr r1,r2
|
||||
strh r1,[r7]
|
||||
add r7,#2
|
||||
sub r4,#1
|
||||
bne _dt_xloop
|
||||
pop {r4}
|
||||
add r7,#248
|
||||
add r7,#248
|
||||
sub r4,#1
|
||||
bne _dt_yloop
|
||||
pop {r7}
|
||||
add r7,#16
|
||||
b _dt_chrloop
|
||||
_dt_null:
|
||||
pop {r0-r7,pc}
|
||||
.align 2
|
||||
.pool
|
||||
|
||||
|
||||
.align 3
|
||||
_var64: .word 0x11223344,0x55667788
|
||||
_tvar64: .word 0x11223344,0x55667788
|
||||
|
||||
.align 2
|
||||
_jumptable: .word _test0,_test1,_test2,_menu
|
||||
|
||||
|
||||
.align 2
|
||||
|
||||
_szALU: .asciz "ALU TEST"
|
||||
_szLDR1: .asciz "LDR/STR TEST 1"
|
||||
_szLDM1: .asciz "LDM/STM TEST"
|
||||
|
||||
_szADC: .asciz "ADC"
|
||||
_szADD: .asciz "ADD"
|
||||
_szAND: .asciz "AND"
|
||||
_szASR: .asciz "ASR"
|
||||
_szBIC: .asciz "BIC"
|
||||
_szCMP: .asciz "CMP"
|
||||
_szLSL: .asciz "LSL"
|
||||
_szLSR: .asciz "LSR"
|
||||
_szMUL: .asciz "MUL"
|
||||
_szMVN: .asciz "MVN"
|
||||
_szNEG: .asciz "NEG"
|
||||
_szORR: .asciz "ORR"
|
||||
_szROR: .asciz "ROR"
|
||||
_szSUB: .asciz "SUB"
|
||||
|
||||
_szLDR: .asciz "LDR"
|
||||
_szLDRH: .asciz "LDRH"
|
||||
_szLDRH1: .asciz "LDRH R"
|
||||
_szLDRH2: .asciz "LDRH \\"
|
||||
_szLDRB: .asciz "LDRB"
|
||||
_szLDRSH: .asciz "LDRSH"
|
||||
_szLDRSB: .asciz "LDRSB"
|
||||
_szLDM: .asciz "LDM"
|
||||
_szLDMIA: .asciz "LDMIA"
|
||||
_szSTR: .asciz "STR"
|
||||
_szSTRH: .asciz "STRH"
|
||||
_szSTRB: .asciz "STRB"
|
||||
_szSTMIA: .asciz "STMIA"
|
||||
|
||||
_szOK: .asciz "OK"
|
||||
_szBad: .asciz "BAD"
|
||||
_szRd: .asciz "R^"
|
||||
_szRn: .asciz "R_"
|
||||
_szC: .asciz "C"
|
||||
_szN: .asciz "N"
|
||||
_szV: .asciz "V"
|
||||
_szZ: .asciz "Z"
|
||||
_szGT: .asciz "+"
|
||||
_szGE: .asciz ","
|
||||
_szLT: .asciz "-"
|
||||
_szLE: .asciz "."
|
||||
|
||||
.align 2
|
||||
.end
|
||||
|
||||
|
Loading…
Reference in New Issue