mirror of
https://github.com/marketideas/qasm.git
synced 2025-01-15 02:30:06 +00:00
428 lines
12 KiB
ArmAsm
428 lines
12 KiB
ArmAsm
;lst off
|
|
*
|
|
* main.s
|
|
* Merlin32 Test
|
|
*
|
|
* Created by Lane Roathe on 8/26/19.
|
|
* Copyright B) 2019 Ideas From the Deep. All rights reserved.
|
|
*
|
|
//]XCODESTART ; Keep this at the start and put your code after this
|
|
|
|
xc off
|
|
xc
|
|
xc
|
|
mx %00
|
|
|
|
|
|
*==========================================================
|
|
* monitor addresses
|
|
|
|
TEXT = $FB39 ;Reset text window
|
|
TABV = $FB5B ;Complete vtab, using contents of 'A'
|
|
MONBELL = $FBE4 ;random bell noise!
|
|
HOME = $FC58 ;Clear text window
|
|
WAIT = $FCA8 ;delay routine
|
|
CROUT = $FD8E ;Print a CR
|
|
PRBYTE = $FDDA ;Print 'A' as a hex number
|
|
PRHEX = $FDE3 ;as above, but bits 0-3 only
|
|
COUT = $FDED ;Monitor char out
|
|
MOVE = $FE2C ;memory move routine
|
|
INVERSE = $FE80 ;Print in inverse
|
|
NORMAL = $FE84 ;Normal print
|
|
|
|
* Jump Vectors
|
|
CONNECT = $3EA ;Connect DOS
|
|
DOSWARM = $3D0 ;exit to DOS prompt
|
|
RSTVEC = $3F2 ;reset vector
|
|
|
|
TSTADDR = $1000 ;absolute address for testing
|
|
|
|
*==========================================================
|
|
* Data Index DUM section test
|
|
|
|
DUM 0
|
|
dum0 ds 1 ;fractional byte
|
|
dum1 ds 1
|
|
dumSize = *
|
|
DEND
|
|
;lst off
|
|
|
|
*==========================================================
|
|
* zero page (all zp var names are prefixed with _)
|
|
|
|
DUM 0
|
|
|
|
_ptr ds 2
|
|
_tmp ds 2
|
|
|
|
_num1 ds dumSize ;first and second operand values
|
|
|
|
; test ORG with DUM section
|
|
|
|
ORG $20
|
|
|
|
_LFT ds 1 ;Window edge 0..39
|
|
|
|
DEND
|
|
|
|
*==========================================================
|
|
* Program Entry
|
|
|
|
;Issue #26 - This should start at the ORG in the linkscript, not at the last ORG in the DUM sections.
|
|
START
|
|
|
|
; PUT current issue here, so it's the first thing assembled.
|
|
; The rest below are unit tests to make sure future changes don't break existing code!
|
|
|
|
|
|
; START OF TESTS KNOWN TO HAVE PASSED IN PREVIOUS BUILDS
|
|
|
|
; --- Test all instructions in all their modes, with as many variants as possible ---
|
|
|
|
|
|
|
|
|
|
;adc (ZP,x)
|
|
adc (0,x)
|
|
|
|
|
|
adc ($80,x)
|
|
adc (_tmp,x)
|
|
adc (_tmp+0,x)
|
|
adc (_tmp+$10,x)
|
|
adc ($10+_tmp,x)
|
|
adc (_tmp+dum0,x)
|
|
adc (_tmp+dum1,x)
|
|
adc (_tmp+dum1+1,x)
|
|
adc (_tmp+dum0+dum1,x)
|
|
|
|
adc 0
|
|
adc $80
|
|
adc _tmp
|
|
adc #0
|
|
adc #$1111
|
|
adc $1111
|
|
|
|
; --- Other tests that have proven helpful ---
|
|
|
|
; Tests regarding issues with math and zp,x
|
|
sta TSTADDR+dum0
|
|
sta TSTADDR+_num1+dum0
|
|
sta TSTADDR+_num1+dum0,x
|
|
|
|
lda _num1+dum0
|
|
adc _num1+dum1
|
|
sbc _num1+dum1
|
|
bit _num1+dum0
|
|
sta _num1+dum0 ;(FIXED): can't use sta _num1+dum0 '
|
|
stz _num1+dum0
|
|
|
|
lda _num1+dum0,x
|
|
adc _num1+dum0,x
|
|
sbc _num1+dum0,x
|
|
bit _num1+dum0,x
|
|
sta _num1+dum0,x
|
|
stz _num1+dum0,x
|
|
|
|
lda _num1+dum0,y ;these assemble to abs accesses: lda $00C0,y
|
|
adc _num1+dum0,y
|
|
sbc _num1+dum0,y
|
|
sta _num1+dum0,y
|
|
|
|
; Label & branching tests
|
|
GetKey ldx $C000
|
|
bpl GetKey
|
|
]loop
|
|
dex
|
|
bne ]loop
|
|
|
|
tya
|
|
and #1
|
|
beq :err
|
|
|
|
tya
|
|
and #1
|
|
bne :good
|
|
:err
|
|
lda #0
|
|
:good
|
|
bne myQuit
|
|
nop
|
|
hex 2C ;bit
|
|
lda #1
|
|
myQuit
|
|
jmp DOSWARM
|
|
|
|
; --- Tests used when addressing issues opened against Merlin32 ---
|
|
|
|
;Issue #26 (lroathe) - ORG in DUM section is ignored, but can't mess up code ORG
|
|
|
|
org $2000
|
|
|
|
lda _LFT
|
|
ldx #_LFT
|
|
cpx #$20
|
|
|
|
org ;return to ongoing address
|
|
|
|
lda $FF
|
|
;Issue #16 (fadden) - Byte reference modifiers are ignored (no way to force DP)
|
|
lda <$fff0 ;zp
|
|
lda >$fff0 ;ABS (lo word)
|
|
lda ^$fff0 ;ABS (hi word)
|
|
lda |$fff0 ;ABS (long in 65816 mode)
|
|
|
|
lda $08
|
|
lda $0008
|
|
lda $FFFF-$FFF7
|
|
lda $FFF0+24
|
|
ldaz $FFF0+24 ; forced DP
|
|
|
|
|
|
ldaz $FFFF ; forced DP
|
|
lda: $FFFF ; forced ABS (any char but 'L', 'D', and 'Z'
|
|
ldal $FFFF ; forced long abs (3 byte address)
|
|
|
|
ldaz $05
|
|
lda: $05
|
|
ldal $05
|
|
|
|
lda $45
|
|
lda $2345
|
|
lda $012345
|
|
ldaz $2345
|
|
lda: $45
|
|
ldal $012345
|
|
ldal $2345
|
|
ldal $45
|
|
lda <$2345
|
|
lda >$2345
|
|
lda <$012345
|
|
lda >$012345
|
|
lda ^$012345
|
|
lda |$012345
|
|
|
|
ora $45
|
|
ora $2345
|
|
ora $012345
|
|
oraz $2345
|
|
ora: $45
|
|
oral $012345
|
|
oral $2345
|
|
oral $45
|
|
ora <$2345
|
|
ora >$2345
|
|
ora <$012345
|
|
ora >$012345
|
|
ora ^$012345
|
|
ora |$012345
|
|
|
|
and $45
|
|
and $2345
|
|
and $012345
|
|
andz $2345
|
|
and: $45
|
|
andl $012345
|
|
andl $2345
|
|
andl $45
|
|
and <$2345
|
|
and >$2345
|
|
and <$012345
|
|
and >$012345
|
|
and ^$012345
|
|
and |$012345
|
|
|
|
eor $45
|
|
eor $2345
|
|
eor $012345
|
|
eorz $2345
|
|
eor: $45
|
|
eorl $012345
|
|
eorl $2345
|
|
eorl $45
|
|
eor <$2345
|
|
eor >$2345
|
|
eor <$012345
|
|
eor >$012345
|
|
eor ^$012345
|
|
eor |$012345
|
|
|
|
adc $45
|
|
adc $2345
|
|
adc $012345
|
|
adcz $2345
|
|
adc: $45
|
|
adcl $012345
|
|
adcl $2345
|
|
adcl $45
|
|
adc <$2345
|
|
adc >$2345
|
|
adc <$012345
|
|
adc >$012345
|
|
adc ^$012345
|
|
adc |$012345
|
|
|
|
sta $45
|
|
sta $2345
|
|
sta $012345
|
|
staz $2345
|
|
sta: $45
|
|
stal $012345
|
|
stal $2345
|
|
stal $45
|
|
sta <$2345
|
|
sta >$2345
|
|
sta <$012345
|
|
sta >$012345
|
|
sta ^$012345
|
|
sta |$012345
|
|
|
|
cmp $45
|
|
cmp $2345
|
|
cmp $012345
|
|
cmpz $2345
|
|
cmp: $45
|
|
cmpl $012345
|
|
cmpl $2345
|
|
cmpl $45
|
|
cmp <$2345
|
|
cmp >$2345
|
|
cmp <$012345
|
|
cmp >$012345
|
|
cmp ^$012345
|
|
cmp |$012345
|
|
|
|
sbc $45
|
|
sbc $2345
|
|
sbc $012345
|
|
sbcz $2345
|
|
sbc: $45
|
|
sbcl $012345
|
|
sbcl $2345
|
|
sbcl $45
|
|
sbc <$2345
|
|
sbc >$2345
|
|
sbc <$012345
|
|
sbc >$012345
|
|
sbc ^$012345
|
|
sbc |$012345
|
|
|
|
;asll $1234
|
|
|
|
lda <$fff0+24 ;zp
|
|
lda >$fff0+24 ;ABS (lo word)
|
|
lda ^$fff0+24 ;ABS (hi word)
|
|
lda |$fff0+24 ;ABS (long in 65816 mode)
|
|
|
|
mx %11
|
|
|
|
lda #<$fff0+24 ;byte
|
|
lda #>$fff0+24 ;page
|
|
lda #^$fff0+24 ;bank
|
|
|
|
lda #<$1234 ;byte
|
|
lda #>$1234 ;page
|
|
lda #^$1234 ;bank
|
|
lda #^$A51234 ;bank
|
|
|
|
|
|
mx %00
|
|
|
|
lda #<$fff0+24 ;byte
|
|
lda #>$fff0+24 ;page
|
|
lda #^$fff0+24 ;bank
|
|
|
|
lda #<$1234 ;byte
|
|
lda #>$1234 ;page
|
|
lda #^$1234 ;bank
|
|
lda #^$A51234 ;bank
|
|
|
|
|
|
lda $0008 ;ZP
|
|
lda $08 ;ZP
|
|
lda $ffff-$fff7 ;ZP
|
|
lda $fff0+24 ;ABS (long in 65816 mode)
|
|
|
|
|
|
;Issue #8 fadden) - STX zp,y fails to assemble
|
|
org $bc
|
|
|
|
L00BC bit L00BC
|
|
|
|
org
|
|
|
|
stx $bc,y
|
|
|
|
ldx L00BC,y
|
|
stx L00BC,y
|
|
|
|
* Data Storage Tests
|
|
|
|
hex ;no error
|
|
hex 11,22,33,44,55,66,77,88,99
|
|
;hex 112233445566778899F
|
|
;hex 112233445I566778899FF
|
|
|
|
hex aabb,CC,0123456789abcdefABCDEF,ff
|
|
|
|
ds 36
|
|
da $A55A
|
|
da $A55A,$1234
|
|
dw $A55A
|
|
dw $A55A,$1234
|
|
ddb $A55A
|
|
ddb $A55A,$1234
|
|
dfb $A55A
|
|
dfb $A55A,$1234
|
|
db $A55A
|
|
db $A55A,$1234
|
|
adr $01A55A
|
|
adr $01A55A,$011234
|
|
adrl $01A55A
|
|
adrl $01A55A,$011234
|
|
|
|
dw >$01A55A,>$011234
|
|
dw <$01A55A,<$011234
|
|
dw ^$01A55A,^$011234
|
|
dw |$01A55A,|$011234
|
|
|
|
db >$01A55A,>$011234
|
|
db <$01A55A,<$011234
|
|
db ^$01A55A,^$011234
|
|
db |$01A55A,|$011234
|
|
|
|
asc 02,15,"123456"
|
|
asc 02,15,z123456z
|
|
asc 0215,"123456"
|
|
asc 02,15,'123456'
|
|
asc 02,15,!123456!
|
|
asc 02,15,@123456@
|
|
asc 02,15,#123456#
|
|
asc 02,15,$123456$
|
|
asc 02,15,%123456%
|
|
asc 02,15,^123456^
|
|
asc 02,15,&123456&
|
|
asc 02,15,*123456*
|
|
asc 02,15,(123456(
|
|
asc 02,15,)123456)
|
|
asc 02,15,/123456/
|
|
asc 02,15,?123456?
|
|
asc 02,15,>123456>
|
|
asc 02,15,<123456<
|
|
asc 02,15,05,"123456"
|
|
asc 02,15,"123456"
|
|
asc 0215"1234"1502
|
|
|
|
|
|
lst
|
|
lup_start:
|
|
lup 0
|
|
db 0 ; outside
|
|
--^
|
|
|
|
|
|
;lst off
|
|
//]XCODEEND ; Keep this at the end and put your code above this
|
|
;lst off
|
|
|