desmume/tools/ds_tests/armwrestler/thumbwrestler-ds.asm

905 lines
13 KiB
NASM

@ 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