2017-01-09 21:41:06 -05:00
;;; Apple IIe Auxiliary memory audit routines
;;; Copyright © 2017 Zellyn Hunter <zellyn@gmail.com>
2017-01-22 21:26:47 -05:00
! zone auxmem {
.MEM_1 = % 00
.MEM_2 = % 01
.MEM_3 = % 10
.MEM_4 = % 11
.MEM_2_1_1_1 = ( .MEM_2 << 0 ) + ( .MEM_1 << 2 ) + ( .MEM_1 << 4 ) + ( .MEM_1 << 6 )
.MEM_3_2_2_2 = ( .MEM_3 << 0 ) + ( .MEM_2 << 2 ) + ( .MEM_2 << 4 ) + ( .MEM_2 << 6 )
2017-01-26 20:46:38 -06:00
.C_8f = % 0001
.C_12 = % 0010
.C_47 = % 0100
.C_3 = % 1000
.C_0 = % 0000
.C_skip = $ 80
.C_1348 = .C_12 | .C_3 | .C_47 | .C_8f
.C_38 = .C_3 | .C_8f
2017-01-22 21:26:47 -05:00
.checkdata = tmp1
.ismain = tmp3
.region = tmp4
.actual = tmp1
.desired = tmp2
2017-01-09 21:41:06 -05:00
AUXMEMTESTS
2017-01-17 21:44:31 -05:00
lda # 0
sta AUXRESULT
2017-01-09 21:41:06 -05:00
lda MEMORY
cmp # 65
bcs +
+ print
! text "64K OR LESS:SKIPPING AUXMEM TEST" , $ 8 D
+ printed
2017-01-17 21:44:31 -05:00
sec
2017-01-09 21:41:06 -05:00
rts
2017-01-17 21:44:31 -05:00
+ + print
! text "TESTING AUX MEM" , $ 8 D
2017-01-09 21:41:06 -05:00
+ printed
2017-01-17 21:44:31 -05:00
lda LCRESULT
bne .auxlc
2017-01-09 21:41:06 -05:00
+ print
2017-01-17 21:44:31 -05:00
! text "LC FAILED BEFORE:SKIPPING AUXMEM LC" , $ 8 D
2017-01-09 21:41:06 -05:00
+ printed
2017-01-22 21:26:47 -05:00
jmp .datadriventests
2017-01-09 21:41:06 -05:00
2017-01-17 21:44:31 -05:00
.auxlc ;; Run langcard tests in auxmem
2017-01-09 21:41:06 -05:00
2017-01-17 21:44:31 -05:00
lda LCRESULT
2017-01-18 20:57:26 -05:00
sta LCRESULT1
2017-01-17 21:44:31 -05:00
lda # 0
sta LCRESULT
;; Store distinct values in RAM areas, to see if they stay safe.
lda $ C08B ; Read and write bank 1
lda $ C08B
lda # $ 44
sta $ D17B ; $D17B is $53 in Apple II/plus/e/enhanced
sta $ FE1F ; FE1F is $60 in Apple II/plus/e/enhanced
lda $ C083 ; Read and write bank 2
lda $ C083
2017-01-18 20:57:26 -05:00
lda # $ 44
2017-01-17 21:44:31 -05:00
sta $ D17B
2017-01-09 21:41:06 -05:00
2017-01-24 23:28:19 -06:00
jsr zptoaux
2017-01-17 21:44:31 -05:00
2017-01-22 21:26:47 -05:00
sta SET_ALTZP
2017-01-17 21:44:31 -05:00
jsr LANGCARDTESTS_NO_CHECK
2017-01-22 21:26:47 -05:00
sta RESET_ALTZP
2017-01-09 21:41:06 -05:00
2017-01-24 23:28:19 -06:00
jsr zpfromaux
2017-01-18 20:57:26 -05:00
lda LCRESULT
bne +
+ prerr $ 0008 ;; E0008: We tried to run the langcard tests again with auxmem (ALTZP active), and they failed, so we're quitting the auxmem test.
! text "QUITTING AUXMEM TEST DUE TO LC FAIL" , $ 8 D
+ prerred
sec
rts
;; Check that the stuff we stashed in main RAM was unaffected.
+
lda $ C088 ; Read bank 1
lda $ D17B
cmp # $ 44
beq +
pha
+ print
! text "WANT BANK1 $D17B"
+ printed
beq .lcerr
+ lda $ C080 ; Read bank 2
lda $ D17B
cmp # $ 44
beq +
pha
+ print
! text "WANT BANK2 $D17B"
+ printed
beq .lcerr
+
lda $ FE1F
cmp # $ 44
2017-01-22 21:26:47 -05:00
beq .datadriventests
2017-01-18 20:57:26 -05:00
pha
+ print
! text "WANT RAM $FE1F"
+ printed
.lcerr
+ print
! text "=$44;GOT $"
+ printed
pla
jsr PRBYTE
+ prerr $ 0009 ;; E0009: We wrote $44 to main RAM in the three test locations used by the LC test. They should have been unaffected by the LC test while it was using auxmem, but at least one of them was modified.
! text ""
+ prerred
sec
rts
2017-01-09 21:41:06 -05:00
2017-01-22 21:26:47 -05:00
.success
lda # ' '
sta $ 427
2017-01-09 21:41:06 -05:00
+ print
2017-01-17 21:44:31 -05:00
! text "AUXMEM TESTS SUCCEEDED" , $ 8 D
2017-01-09 21:41:06 -05:00
+ printed
2017-01-17 21:44:31 -05:00
lda # 1
sta AUXRESULT
clc
rts
2017-01-09 21:41:06 -05:00
2017-01-22 21:26:47 -05:00
;;; Main data-driven test. PCL,PCH holds the address of the next
;;; data-driven test routine. We expect the various softswitches
;;; to be reset each time we loop at .ddloop.
.datadriventests
lda # < .auxtests
sta PCL
lda # > .auxtests
sta PCH
;;; Main data-drive-test loop.
.ddloop
ldy # 0
lda ( PCL ), Y
beq .success
lda # 3
sta SET_ALTZP
sta SET_RAMWRT
sta SET_RAMRD
.initloop ; Loop twice: initialize aux to $3 and main to $1.
ldy # .memorylen
- ldx .memorylocs , y
stx + + 1
ldx .memorylocs + 1 , y
stx + + 2
+ sta $ ffff ;; this address gets replaced
dey
dey
bpl -
sta RESET_ALTZP
sta RESET_RAMWRT
sta RESET_RAMRD
sec
sbc # 2
bcs .initloop
jmp ( PCL ) ; Jump to test routine.
;; Test routine will JSR back to here, so the check data address is on the stack.
;; .checkdata (tmp1/tmp2) is the pointer to the current checkdata byte
;; .ismain (tmp3) is the main/aux loop counter.
;; .region (tmp4) is the zp/main/text/hires loop counter
.check
;; Increment all the test memory locations, so we can see what we were reading and writing.
inc $ ff
inc $ 100
inc $ 200
inc $ 3 ff
inc $ 427
inc $ 7 ff
inc $ 800
inc $ 1 fff
inc $ 2000
inc $ 3 fff
inc $ 4000
inc $ 5 fff
inc $ bfff
;; pull address off of stack: it points just below check data for this test.
pla
sta .checkdata
pla
sta .checkdata + 1
;; First checkdata byte is for Cxxx tests.
jsr .nextcheck
2017-01-26 20:46:38 -06:00
bmi +
2017-01-22 21:26:47 -05:00
jsr .checkCxxx
2017-01-26 20:46:38 -06:00
+ ldx .checkdata
2017-01-22 21:26:47 -05:00
ldy .checkdata + 1
jsr RESETALL
stx .checkdata
sty .checkdata + 1
;; Do the next part twice.
lda # 1
sta .ismain
jsr .nextcheck
.checkloop ; Loop twice here: once for main, once for aux.
lda # 4
sta .region
ldx # $ fe
ldy # 0
.memlp inx
inx
lda .memorylocs , x
sta SRC
lda .memorylocs + 1 , x
sta SRC + 1
ora SRC
beq .memlpinc
;; Perform the actual memory check.
lda ( SRC ), y
cmp ( .checkdata ), y
bne .checkerr
beq .memlp
.memlpinc
jsr .nextcheck
dec .region ; loop four times: zero, main, text, hires
bne .memlp
dec .ismain
bmi .checkdone
ldx .checkdata
ldy .checkdata + 1
lda .ismain
sta SET_ALTZP
sta SET_RAMRD
sta SET_RAMWRT
stx .checkdata
sty .checkdata + 1
sta .ismain
jmp .checkloop
.checkdone
;; Jump PCL,PCH to next test, and loop.
ldx .checkdata
ldy .checkdata + 1
jsr RESETALL
stx PCL
sty PCH
jmp .ddloop
.checkerr
;; X = index of memory location
;; A = actual
;; Y = 0
;; desired = (.checkdata),y
pha
lda .ismain
clc
ror
ror
ora ( .checkdata ), y
tay
pla
;; Now:
;; X = index of memory location
;; A = actual
;; Y = desired | (high bit set if main, unset=aux)
jsr RESETALL
sta .actual
sty .desired
lda .memorylocs , x
sta SRC
lda .memorylocs + 1 , x
sta SRC + 1
+ print
! text "GOT $"
+ printed
lda .actual
jsr PRBYTE
+ print
! text " AT $"
+ printed
ldx SRC
ldy SRC + 1
jsr PRNTYX
lda .desired
bpl +
eor # $ 80
sta .desired
+ print
! text " OF MAIN MEM (WANT $"
+ printed
beq ++
+ + print
! text " OF AUX MEM (WANT $"
+ printed
+ +
lda .desired
jsr PRBYTE
lda # ')'
jsr COUT
lda # $ 8 D
jsr COUT
jsr .printtest
+ prerr $ 000 A ;; E000A: This is a data-driven test of main and auxiliary memory softswitch operation. We initialize $FF, $100, $200, $3FF, $427, $7FF, $800, $1FFF, $2000, $3FFF, $4000, $5FFF, and $BFFF in main RAM to value 1, and in auxiliary RAM to value 3. Then, we perform a testdata-driven sequence of instructions. Finally we (try to) increment all test locations. Then we test the expected values of the test locations in main and auxiliary memory. For more information on the operation of the auxiliary memory soft-switches, see Understanding the Apple IIe, by James Fielding Sather, Pg 5-22 to 5-28.
! text "FOLLOWED BY INC OF TEST LOCATIONS. SEE"
+ prerred
sec
rts
;;; Check that the expected ROM areas are visible.
.checkCxxx
2017-01-26 20:46:38 -06:00
.gotCxxx = tmp0
.wantCxxx = SCRATCH
pha
jsr .genCxxxFingerprint
pla
cmp .gotCxxx
beq .checkCxxxDone
lda .gotCxxx
;; Reset, but copy .checkdata over.
ldx .checkdata
ldy .checkdata + 1
jsr RESETALL
stx .checkdata
sty .checkdata + 1
sta .gotCxxx
ldy # 0
lda ( .checkdata ), y
sta .wantCxxx
jsr .printtest
+ print
! text "WANT:" , $ 8 D
+ printed
lda .wantCxxx
jsr .printCxxxBits
+ print
! text "GOT:" , $ 8 D
+ printed
lda .gotCxxx
jsr .printCxxxBits
+ prerr $ 000B ;; E000B: This is a the Cxxx-ROM check part of the auxiliary memory data-driven test (see E000A for a description of the other part). After a full reset, we perform a testdata-driven sequence of instructions. Finally we check which parts of Cxxx ROM seem to be visible. We check C100-C2FF, C300-C3FF, C400-C7FF (which should be the same as C100-C2FF), and C800-CFFE. For more details, see Understanding the Apple IIe, by James Fielding Sather, Pg 5-28.
! text "CXXX ROM TEST FAILED"
+ prerred
;; Don't continue with auxmem check: return from parent JSR.
pla
pla
sec
rts
.checkCxxxDone
rts
.genCxxxFingerprint
.dataptr = SCRATCH2
.want = SCRATCH3
.loopctr = SCRATCH
lda # 0
sta .gotCxxx
lda # 0
sta .dataptr
lda # 4
sta .loopctr
- - clc
ror .gotCxxx
ldx # 4 ; four check bytes per region
lda # $ 8 ; start out with positive match bit
ora .gotCxxx
sta .gotCxxx
- ldy .dataptr
lda .cxtestdata , y
iny
sta SRC
lda .cxtestdata , y
iny
sta SRC + 1
lda .cxtestdata , y
iny
sta .want
sty .dataptr
ldy # 0
lda ( SRC ), y
cmp .want
beq +
lda # ( $ ff - $ 8 ) ; mismatch: clear current bit
and .gotCxxx
sta .gotCxxx
+ dex
bne -
dec .loopctr
bne --
rts
.printCxxxBits
tax
+ print
! text "- C100-C2FF: "
+ printed
txa
and # .C_12
jsr .printCxxxBit
+ print
! text "- C300-C3FF: "
+ printed
txa
and # .C_3
jsr .printCxxxBit
+ print
! text "- C400-C7FF: "
+ printed
txa
and # .C_47
jsr .printCxxxBit
+ print
! text "- C800-CFFE: "
+ printed
txa
and # .C_8f
jsr .printCxxxBit
2017-01-22 21:26:47 -05:00
rts
2017-01-26 20:46:38 -06:00
.printCxxxBit
bne +
+ print
! text "?" , $ 8 D
+ printed
rts
+ + print
! text "ROM" , $ 8 D
+ printed
rts
2017-01-22 21:26:47 -05:00
;;; Increment .checkdata pointer to the next memory location, and load
;;; it into the accumulator. X and Y are preserved.
.nextcheck
inc .checkdata
bne +
inc .checkdata + 1
+ sty SCRATCH
ldy # 0
lda ( .checkdata ), y
ldy SCRATCH
ora # 0
rts
2017-01-09 21:41:06 -05:00
2017-01-22 21:26:47 -05:00
;;; Print out the sequence of instructions at PCL,PCH, until we hit a JSR.
.printtest
+ print
! text "AFTER SEQUENCE" , $ 8 D
+ printed
-
ldy # 0
lda ( PCL ), y
cmp # $ 20
beq +++
lda # '-'
jsr COUT
lda # ' '
jsr COUT
ldx # 0
lda ( PCL , x )
jsr $ f88e
ldx # 3
jsr $ f8ea
jsr $ f953
sta PCL
sty PCH
lda # $ 8 D
jsr COUT
jmp -
+ + + rts
2017-01-17 21:44:31 -05:00
;;; Copy zero page to aux mem. Assumes zp pointing at main mem, and leaves it that way.
2017-01-24 23:28:19 -06:00
zptoaux
2017-01-17 21:44:31 -05:00
ldx # 0
2017-01-22 21:26:47 -05:00
- sta RESET_ALTZP
2017-01-17 21:44:31 -05:00
lda 0 , x
2017-01-22 21:26:47 -05:00
sta SET_ALTZP
2017-01-17 21:44:31 -05:00
sta 0 , x
inx
bne -
2017-01-22 21:26:47 -05:00
sta RESET_ALTZP
2017-01-09 21:41:06 -05:00
rts
2017-01-17 21:44:31 -05:00
;;; Copy zero page from aux mem. Assumes zp pointing at main mem, and leaves it that way.
2017-01-24 23:28:19 -06:00
zpfromaux
2017-01-17 21:44:31 -05:00
ldx # 0
2017-01-22 21:26:47 -05:00
- sta SET_ALTZP
2017-01-17 21:44:31 -05:00
lda 0 , x
2017-01-22 21:26:47 -05:00
sta RESET_ALTZP
2017-01-17 21:44:31 -05:00
sta 0 , x
inx
2017-01-09 21:41:06 -05:00
bne -
rts
2017-01-22 21:26:47 -05:00
.auxtests
;; Our four basic tests --------------------------------------
;; Test 1: everything reset.
lda # 1
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test 2: write to AUX but read from Main RAM, everything else normal.
lda # 2
sta SET_RAMWRT
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 2 , 2 , 2
2017-01-22 21:26:47 -05:00
;; Test 3: write to main but read AUX, everything else normal.
lda # 3
sta SET_RAMRD
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 4 , 4 , 4 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test 4: write to AUX, read from AUX, everything else normal.
lda # 4
sta SET_RAMRD
sta SET_RAMWRT
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 4 , 4 , 4
2017-01-22 21:26:47 -05:00
;; Our four basic tests, but with 80STORE ON -----------------
;; (400-7ff is pointing at main mem)
;; Test 5: everything reset.
lda # 5
sta SET_80STORE
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test 6: write to aux
lda # 6
sta SET_RAMWRT
sta SET_80STORE
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 2 , 1 , 3 , 2 , 3 , 2
2017-01-22 21:26:47 -05:00
;; Test 7: read from aux
lda # 7
sta SET_RAMRD
sta SET_80STORE
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 4 , 2 , 4 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test 8: read and write aux
lda # 8
sta SET_RAMRD
sta SET_RAMWRT
sta SET_80STORE
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 2 , 1 , 3 , 4 , 3 , 4
2017-01-22 21:26:47 -05:00
;; Our four basic tests, but with 80STORE and PAGE2 ON -------
;; (400-7ff is pointing at aux mem)
;; Test 9: everything reset.
lda # 9
sta SET_80STORE
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 2 , 1 , 2 , 3 , 3 , 4 , 3
2017-01-22 21:26:47 -05:00
;; Test A: write to aux
lda # $ a
sta SET_RAMWRT
sta SET_80STORE
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 2 , 4 , 2
2017-01-22 21:26:47 -05:00
;; Test B: read from aux
lda # $ b
sta SET_RAMRD
sta SET_80STORE
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 4 , 1 , 4 , 3 , 3 , 4 , 3
2017-01-22 21:26:47 -05:00
;; Test C: read and write aux
lda # $ c
sta SET_RAMRD
sta SET_RAMWRT
sta SET_80STORE
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 4 , 4 , 4
2017-01-22 21:26:47 -05:00
;; Our four basic tests, but with 80STORE and HIRES ON -------
;; (400-7ff and 2000-3fff are pointing at main mem)
;; Test D: everything reset.
lda # $ d
sta SET_80STORE
sta SET_HIRES
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test E: write to aux
lda # $ e
sta SET_RAMWRT
sta SET_80STORE
sta SET_HIRES
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 2 , 2 , 3 , 2 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test F: read from aux
lda # $ f
sta SET_RAMRD
sta SET_80STORE
sta SET_HIRES
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 4 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Test 10: read and write aux
lda # $ 10
sta SET_RAMRD
sta SET_RAMWRT
sta SET_80STORE
sta SET_HIRES
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 2 , 2 , 3 , 4 , 3 , 3
2017-01-22 21:26:47 -05:00
;; Our four basic tests, but with 80STORE, HIRES, PAGE2 ON ---
;; (400-7ff and 2000-3fff are pointing at aux mem)
;; Test 11: everything reset.
lda # $ 11
sta SET_80STORE
sta SET_HIRES
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 2 , 1 , 1 , 3 , 3 , 4 , 4
2017-01-22 21:26:47 -05:00
;; Test 12: write to aux
lda # $ 12
sta SET_RAMWRT
sta SET_80STORE
sta SET_HIRES
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 2 , 4 , 4
2017-01-22 21:26:47 -05:00
;; Test 13: read from aux
lda # $ 13
sta SET_RAMRD
sta SET_80STORE
sta SET_HIRES
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 4 , 1 , 1 , 3 , 3 , 4 , 4
2017-01-22 21:26:47 -05:00
;; Test 14: read and write aux
lda # $ 14
sta SET_RAMRD
sta SET_RAMWRT
sta SET_80STORE
sta SET_HIRES
sta SET_PAGE2
jsr .check
2017-01-26 20:46:38 -06:00
! byte .C_skip , 2 , 1 , 1 , 1 , 3 , 4 , 4 , 4
;; Test 15: Cxxx test with everything reset.
lda # $ 15
jsr .check
! byte .C_3 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 16: Cxxx test with SLOTC3ROM set
lda # $ 16
sta SET_SLOTC3ROM
jsr .check
! byte .C_0 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 17: Cxxx test with INTCXROM set.
lda # $ 17
sta SET_INTCXROM
jsr .check
! byte .C_1348 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 18: Cxxx test with SLOTC3ROM and INTCXROM set
lda # $ 18
sta SET_SLOTC3ROM
sta SET_INTCXROM
jsr .check
! byte .C_1348 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 19: Cxxx test with "INTC8ROM" set
lda # $ 19
lda $ C300
jsr .check
! byte .C_38 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 1A: Cxxx test showing inability to reset "INTC8ROM" with softswitches.
lda # $ 1 A
lda $ C300
sta SET_SLOTC3ROM
jsr .check
! byte .C_8f , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 1B: Cxxx test showing ability to reset "INTC8ROM" with CFFF reference.
lda # $ 1B
lda $ C300
sta SET_SLOTC3ROM
lda RESET_INTC8ROM
jsr .check
! byte .C_0 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
2017-02-05 15:26:58 -05:00
;; Test 1C: Cxxx test showing inability to reset "INTC8ROM" with CFFF reference.
lda # $ 1B
sta SET_SLOTC3ROM
sta SET_INTCXROM
lda RESET_INTC8ROM
jsr .check
! byte .C_1348 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
;; Test 1D: Cxxx test showing that "INTC8ROM" isn't set if SLOTC3ROM isn't reset.
lda # $ 1 D
sta SET_INTCXROM
sta SET_SLOTC3ROM
lda $ C300
sta RESET_INTCXROM
jsr .check
! byte .C_0 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 3
2017-01-22 21:26:47 -05:00
! byte 0 ; end of tests
.memorylocs
;; zero page locations
! word $ ff , $ 100 , 0
;; main memory locations
! word $ 200 , $ 3 ff , $ 800 , $ 1 fff , $ 4000 , $ 5 fff , $ bfff , 0
;; text locations
! word $ 427 , $ 7 ff , 0
;; hires locations
! word $ 2000 , $ 3 fff , 0
;; end
.memorylen = * - .memorylocs - 2
! word 0
2017-01-26 20:46:38 -06:00
.cxtestdata
;; C800-Cffe
! byte $ 00 , $ c8 , $ 4 c
! byte $ 21 , $ ca , $ 8 d
! byte $ 43 , $ cc , $ f0
! byte $ b5 , $ ce , $ 7 b
;; C100-C2ff
! byte $ 4 d , $ c1 , $ a5
! byte $ 6 c , $ c1 , $ 2 a
! byte $ b5 , $ c2 , $ ad
! byte $ ff , $ c2 , $ 00
;; C400-C7ff
! byte $ 36 , $ c4 , $ 8 d
! byte $ 48 , $ c5 , $ 18
! byte $ 80 , $ c6 , $ 8 b
! byte $ 6 e , $ c7 , $ cb
;; C300-C3ff
! byte $ 00 , $ c3 , $ 2 c
! byte $ 0 a , $ c3 , $ 0 c
! byte $ 2 b , $ c3 , $ 04
! byte $ e2 , $ c3 , $ ed
2017-01-16 22:45:29 -05:00
} ;auxmem