mirror of
https://github.com/st3fan/ewm.git
synced 2025-01-05 06:30:48 +00:00
Code Golf Part 1 - Testing your emulator
This commit is contained in:
parent
f797e02836
commit
c642313461
@ -80,6 +80,12 @@ MEM_BENCH_SOURCES=$(CPU_SOURCES) mem_bench.c
|
||||
MEM_BENCH_OBJECTS=$(MEM_BENCH_SOURCES:.c=.o)
|
||||
MEM_BENCH_LIBS=$(LUA_LIBS)
|
||||
|
||||
CODEGOLF_TEST=codegolf_test
|
||||
CODEGOLF_TEST_SOURCES=$(CPU_SOURCES) codegolf_test.c
|
||||
CODEGOLF_TEST_OBJECTS=$(CODEGOLF_TEST_SOURCES:.c=.o)
|
||||
CODEGOLD_TEST_LIBS=$(LUA_LIBS)
|
||||
|
||||
|
||||
all: $(EWM_SOURCES) $(EWM_EXECUTABLE) $(CPU_TEST_SOURCES) $(CPU_TEST_EXECUTABLE) $(SCR_TEST_EXECUTABLE) $(TTY_TEST_EXECUTABLE) $(CPU_BENCH) $(MEM_BENCH)
|
||||
|
||||
clean:
|
||||
@ -103,5 +109,8 @@ $(CPU_BENCH): $(CPU_BENCH_OBJECTS)
|
||||
$(MEM_BENCH): $(MEM_BENCH_OBJECTS)
|
||||
$(CC) $(LDFLAGS) $(MEM_BENCH_OBJECTS) $(MEM_BENCH_LIBS) -o $@
|
||||
|
||||
$(CODEGOLF_TEST): $(CODEGOLF_TEST_OBJECTS)
|
||||
$(CC) $(LDFLAGS) $(CODEGOLF_TEST_OBJECTS) $(CODEGOLF_TEST_LIBS) -o $@
|
||||
|
||||
.c.o:
|
||||
$(CC) $(CFLAGS) $< -c -o $@
|
||||
|
54
src/codegolf_test.c
Normal file
54
src/codegolf_test.c
Normal file
@ -0,0 +1,54 @@
|
||||
// The MIT License (MIT)
|
||||
//
|
||||
// Copyright (c) 2020 Stefan Arentz - http://github.com/st3fan/ewm
|
||||
//
|
||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
// of this software and associated documentation files (the "Software"), to deal
|
||||
// in the Software without restriction, including without limitation the rights
|
||||
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
// copies of the Software, and to permit persons to whom the Software is
|
||||
// furnished to do so, subject to the following conditions:
|
||||
//
|
||||
// The above copyright notice and this permission notice shall be included in all
|
||||
// copies or substantial portions of the Software.
|
||||
//
|
||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
// SOFTWARE.
|
||||
|
||||
#include <stdio.h>
|
||||
|
||||
#include "cpu.h"
|
||||
#include "mem.h"
|
||||
|
||||
//
|
||||
// This implements the "Testing your emulator" part of the code golf at
|
||||
// https://codegolf.stackexchange.com/questions/12844/emulate-a-mos-6502-cpu
|
||||
//
|
||||
|
||||
int main() {
|
||||
struct cpu_t *cpu = cpu_create(EWM_CPU_MODEL_6502);
|
||||
cpu_add_ram(cpu, 0x0000, 0x3FFF);
|
||||
cpu_add_ram_file(cpu, 0x4000, "rom/AllSuiteA.bin");
|
||||
cpu_reset(cpu);
|
||||
cpu->state.pc = 0x4000;
|
||||
|
||||
while (true) {
|
||||
int ret = cpu_step(cpu);
|
||||
if (ret < 0) {
|
||||
fprintf(stderr, "Unexpected error %d\n", ret);
|
||||
return 1;
|
||||
}
|
||||
|
||||
if (cpu->state.pc == 0x45c0) {
|
||||
fprintf(stderr, "Test finished with status 0x%.2x\n", mem_get_byte(cpu, 0x0210));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
924
src/rom/AllSuiteA.asm
Executable file
924
src/rom/AllSuiteA.asm
Executable file
@ -0,0 +1,924 @@
|
||||
.ORG $4000
|
||||
start:
|
||||
; EXPECTED FINAL RESULTS: $0210 = FF
|
||||
; (any other number will be the
|
||||
; test that failed)
|
||||
|
||||
; initialize:
|
||||
LDA #$00
|
||||
STA $0210
|
||||
; store each test's expected
|
||||
LDA #$55
|
||||
STA $0200
|
||||
LDA #$AA
|
||||
STA $0201
|
||||
LDA #$FF
|
||||
STA $0202
|
||||
LDA #$6E
|
||||
STA $0203
|
||||
LDA #$42
|
||||
STA $0204
|
||||
LDA #$33
|
||||
STA $0205
|
||||
LDA #$9D
|
||||
STA $0206
|
||||
LDA #$7F
|
||||
STA $0207
|
||||
LDA #$A5
|
||||
STA $0208
|
||||
LDA #$1F
|
||||
STA $0209
|
||||
LDA #$CE
|
||||
STA $020A
|
||||
LDA #$29
|
||||
STA $020B
|
||||
LDA #$42
|
||||
STA $020C
|
||||
LDA #$6C
|
||||
STA $020D
|
||||
LDA #$42
|
||||
STA $020E
|
||||
|
||||
|
||||
; expected result: $022A = 0x55
|
||||
test00:
|
||||
LDA #85
|
||||
LDX #42
|
||||
LDY #115
|
||||
STA $81
|
||||
LDA #$01
|
||||
STA $61
|
||||
LDA #$7E
|
||||
LDA $81
|
||||
STA $0910
|
||||
LDA #$7E
|
||||
LDA $0910
|
||||
STA $56,X
|
||||
LDA #$7E
|
||||
LDA $56,X
|
||||
STY $60
|
||||
STA ($60),Y
|
||||
LDA #$7E
|
||||
LDA ($60),Y
|
||||
STA $07ff,X
|
||||
LDA #$7E
|
||||
LDA $07ff,X
|
||||
STA $07ff,Y
|
||||
LDA #$7E
|
||||
LDA $07ff,Y
|
||||
STA ($36,X)
|
||||
LDA #$7E
|
||||
LDA ($36,X)
|
||||
STX $50
|
||||
LDX $60
|
||||
LDY $50
|
||||
STX $0913
|
||||
LDX #$22
|
||||
LDX $0913
|
||||
STY $0914
|
||||
LDY #$99
|
||||
LDY $0914
|
||||
STY $2D,X
|
||||
STX $77,Y
|
||||
LDY #$99
|
||||
LDY $2D,X
|
||||
LDX #$22
|
||||
LDX $77,Y
|
||||
LDY #$99
|
||||
LDY $08A0,X
|
||||
LDX #$22
|
||||
LDX $08A1,Y
|
||||
STA $0200,X
|
||||
|
||||
; CHECK test00:
|
||||
LDA $022A
|
||||
CMP $0200
|
||||
BEQ test00pass
|
||||
JMP theend
|
||||
test00pass:
|
||||
LDA #$FE
|
||||
STA $0210
|
||||
|
||||
|
||||
; expected result: $A9 = 0xAA
|
||||
test01:
|
||||
; imm
|
||||
LDA #85
|
||||
AND #83
|
||||
ORA #56
|
||||
EOR #17
|
||||
|
||||
; zpg
|
||||
STA $99
|
||||
LDA #185
|
||||
STA $10
|
||||
LDA #231
|
||||
STA $11
|
||||
LDA #57
|
||||
STA $12
|
||||
LDA $99
|
||||
AND $10
|
||||
ORA $11
|
||||
EOR $12
|
||||
|
||||
; zpx
|
||||
LDX #16
|
||||
STA $99
|
||||
LDA #188
|
||||
STA $20
|
||||
LDA #49
|
||||
STA $21
|
||||
LDA #23
|
||||
STA $22
|
||||
LDA $99
|
||||
AND $10,X
|
||||
ORA $11,X
|
||||
EOR $12,X
|
||||
|
||||
; abs
|
||||
STA $99
|
||||
LDA #111
|
||||
STA $0110
|
||||
LDA #60
|
||||
STA $0111
|
||||
LDA #39
|
||||
STA $0112
|
||||
LDA $99
|
||||
AND $0110
|
||||
ORA $0111
|
||||
EOR $0112
|
||||
|
||||
; abx
|
||||
STA $99
|
||||
LDA #138
|
||||
STA $0120
|
||||
LDA #71
|
||||
STA $0121
|
||||
LDA #143
|
||||
STA $0122
|
||||
LDA $99
|
||||
AND $0110,X
|
||||
ORA $0111,X
|
||||
EOR $0112,X
|
||||
|
||||
; aby
|
||||
LDY #32
|
||||
STA $99
|
||||
LDA #115
|
||||
STA $0130
|
||||
LDA #42
|
||||
STA $0131
|
||||
LDA #241
|
||||
STA $0132
|
||||
LDA $99
|
||||
AND $0110,Y
|
||||
ORA $0111,Y
|
||||
EOR $0112,Y
|
||||
|
||||
; idx
|
||||
STA $99
|
||||
LDA #112
|
||||
STA $30
|
||||
LDA #$01
|
||||
STA $31
|
||||
LDA #113
|
||||
STA $32
|
||||
LDA #$01
|
||||
STA $33
|
||||
LDA #114
|
||||
STA $34
|
||||
LDA #$01
|
||||
STA $35
|
||||
LDA #197
|
||||
STA $0170
|
||||
LDA #124
|
||||
STA $0171
|
||||
LDA #161
|
||||
STA $0172
|
||||
LDA $99
|
||||
AND ($20,X)
|
||||
ORA ($22,X)
|
||||
EOR ($24,X)
|
||||
|
||||
; idy
|
||||
STA $99
|
||||
LDA #96
|
||||
STA $40
|
||||
LDA #$01
|
||||
STA $41
|
||||
LDA #97
|
||||
STA $42
|
||||
LDA #$01
|
||||
STA $43
|
||||
LDA #98
|
||||
STA $44
|
||||
LDA #$01
|
||||
STA $45
|
||||
LDA #55
|
||||
STA $0250
|
||||
LDA #35
|
||||
STA $0251
|
||||
LDA #157
|
||||
STA $0252
|
||||
LDA $99
|
||||
LDY #$F0
|
||||
AND ($40),Y
|
||||
ORA ($42),Y
|
||||
EOR ($44),Y
|
||||
|
||||
STA $A9
|
||||
|
||||
; CHECK test01
|
||||
LDA $A9
|
||||
CMP $0201
|
||||
BEQ test02
|
||||
LDA #$01
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $71 = 0xFF
|
||||
test02:
|
||||
LDA #$FF
|
||||
LDX #$00
|
||||
|
||||
STA $90
|
||||
INC $90
|
||||
INC $90
|
||||
LDA $90
|
||||
LDX $90
|
||||
|
||||
STA $90,X
|
||||
INC $90,X
|
||||
LDA $90,X
|
||||
LDX $91
|
||||
|
||||
STA $0190,X
|
||||
INC $0192
|
||||
LDA $0190,X
|
||||
LDX $0192
|
||||
|
||||
STA $0190,X
|
||||
INC $0190,X
|
||||
LDA $0190,X
|
||||
LDX $0193
|
||||
|
||||
STA $0170,X
|
||||
DEC $0170,X
|
||||
LDA $0170,X
|
||||
LDX $0174
|
||||
|
||||
STA $0170,X
|
||||
DEC $0173
|
||||
LDA $0170,X
|
||||
LDX $0173
|
||||
|
||||
STA $70,X
|
||||
DEC $70,X
|
||||
LDA $70,X
|
||||
LDX $72
|
||||
|
||||
STA $70,X
|
||||
DEC $71
|
||||
DEC $71
|
||||
|
||||
; CHECK test02
|
||||
LDA $71
|
||||
CMP $0202
|
||||
BEQ test03
|
||||
LDA #$02
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $01DD = 0x6E
|
||||
test03:
|
||||
LDA #$4B
|
||||
LSR
|
||||
ASL
|
||||
|
||||
STA $50
|
||||
ASL $50
|
||||
ASL $50
|
||||
LSR $50
|
||||
LDA $50
|
||||
|
||||
LDX $50
|
||||
ORA #$C9
|
||||
STA $60
|
||||
ASL $4C,X
|
||||
LSR $4C,X
|
||||
LSR $4C,X
|
||||
LDA $4C,X
|
||||
|
||||
LDX $60
|
||||
ORA #$41
|
||||
STA $012E
|
||||
LSR $0100,X
|
||||
LSR $0100,X
|
||||
ASL $0100,X
|
||||
LDA $0100,X
|
||||
|
||||
LDX $012E
|
||||
ORA #$81
|
||||
STA $0100,X
|
||||
LSR $0136
|
||||
LSR $0136
|
||||
ASL $0136
|
||||
LDA $0100,X
|
||||
|
||||
; rol & ror
|
||||
|
||||
ROL
|
||||
ROL
|
||||
ROR
|
||||
STA $70
|
||||
|
||||
LDX $70
|
||||
ORA #$03
|
||||
STA $0C,X
|
||||
ROL $C0
|
||||
ROR $C0
|
||||
ROR $C0
|
||||
LDA $0C,X
|
||||
|
||||
LDX $C0
|
||||
STA $D0
|
||||
ROL $75,X
|
||||
ROL $75,X
|
||||
ROR $75,X
|
||||
LDA $D0
|
||||
|
||||
LDX $D0
|
||||
STA $0100,X
|
||||
ROL $01B7
|
||||
ROL $01B7
|
||||
ROL $01B7
|
||||
ROR $01B7
|
||||
LDA $0100,X
|
||||
|
||||
LDX $01B7
|
||||
STA $01DD
|
||||
ROL $0100,X
|
||||
ROR $0100,X
|
||||
ROR $0100,X
|
||||
|
||||
; CHECK test03
|
||||
LDA $01DD
|
||||
CMP $0203
|
||||
BEQ test04
|
||||
LDA #$03
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $40 = 0x42
|
||||
test04:
|
||||
LDA #$E8 ;originally:#$7C
|
||||
STA $20
|
||||
LDA #$42 ;originally:#$02
|
||||
STA $21
|
||||
LDA #$00
|
||||
ORA #$03
|
||||
JMP jump1
|
||||
ORA #$FF ; not done
|
||||
jump1:
|
||||
ORA #$30
|
||||
JSR subr
|
||||
ORA #$42
|
||||
JMP ($0020)
|
||||
ORA #$FF ; not done
|
||||
subr:
|
||||
STA $30
|
||||
LDX $30
|
||||
LDA #$00
|
||||
RTS
|
||||
final:
|
||||
STA $0D,X
|
||||
|
||||
; CHECK test04
|
||||
LDA $40
|
||||
CMP $0204
|
||||
BEQ test05
|
||||
LDA #$04
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $40 = 0x33
|
||||
test05:
|
||||
LDA #$35
|
||||
|
||||
TAX
|
||||
DEX
|
||||
DEX
|
||||
INX
|
||||
TXA
|
||||
|
||||
TAY
|
||||
DEY
|
||||
DEY
|
||||
INY
|
||||
TYA
|
||||
|
||||
TAX
|
||||
LDA #$20
|
||||
TXS
|
||||
LDX #$10
|
||||
TSX
|
||||
TXA
|
||||
|
||||
STA $40
|
||||
|
||||
; CHECK test05
|
||||
LDA $40
|
||||
CMP $0205
|
||||
BEQ test06
|
||||
LDA #$05
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $30 = 9D
|
||||
test06:
|
||||
|
||||
; RESET TO CARRY FLAG = 0
|
||||
ROL
|
||||
|
||||
LDA #$6A
|
||||
STA $50
|
||||
LDA #$6B
|
||||
STA $51
|
||||
LDA #$A1
|
||||
STA $60
|
||||
LDA #$A2
|
||||
STA $61
|
||||
|
||||
LDA #$FF
|
||||
ADC #$FF
|
||||
ADC #$FF
|
||||
SBC #$AE
|
||||
|
||||
STA $40
|
||||
LDX $40
|
||||
ADC $00,X
|
||||
SBC $01,X
|
||||
|
||||
ADC $60
|
||||
SBC $61
|
||||
|
||||
STA $0120
|
||||
LDA #$4D
|
||||
STA $0121
|
||||
LDA #$23
|
||||
ADC $0120
|
||||
SBC $0121
|
||||
|
||||
STA $F0
|
||||
LDX $F0
|
||||
LDA #$64
|
||||
STA $0124
|
||||
LDA #$62
|
||||
STA $0125
|
||||
LDA #$26
|
||||
ADC $0100,X
|
||||
SBC $0101,X
|
||||
|
||||
STA $F1
|
||||
LDY $F1
|
||||
LDA #$E5
|
||||
STA $0128
|
||||
LDA #$E9
|
||||
STA $0129
|
||||
LDA #$34
|
||||
ADC $0100,Y
|
||||
SBC $0101,Y
|
||||
|
||||
STA $F2
|
||||
LDX $F2
|
||||
LDA #$20
|
||||
STA $70
|
||||
LDA #$01
|
||||
STA $71
|
||||
LDA #$24
|
||||
STA $72
|
||||
LDA #$01
|
||||
STA $73
|
||||
ADC ($41,X)
|
||||
SBC ($3F,X)
|
||||
|
||||
STA $F3
|
||||
LDY $F3
|
||||
LDA #$DA
|
||||
STA $80
|
||||
LDA #$00
|
||||
STA $81
|
||||
LDA #$DC
|
||||
STA $82
|
||||
LDA #$00
|
||||
STA $83
|
||||
LDA #$AA
|
||||
ADC ($80),Y
|
||||
SBC ($82),Y
|
||||
STA $30
|
||||
|
||||
; CHECK test06
|
||||
LDA $30
|
||||
CMP $0206
|
||||
BEQ test07
|
||||
LDA #$06
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $15 = 0x7F
|
||||
test07:
|
||||
; prepare memory
|
||||
LDA #$00
|
||||
STA $34
|
||||
LDA #$FF
|
||||
STA $0130
|
||||
LDA #$99
|
||||
STA $019D
|
||||
LDA #$DB
|
||||
STA $0199
|
||||
LDA #$2F
|
||||
STA $32
|
||||
LDA #$32
|
||||
STA $4F
|
||||
LDA #$30
|
||||
STA $33
|
||||
LDA #$70
|
||||
STA $AF
|
||||
LDA #$18
|
||||
STA $30
|
||||
|
||||
; imm
|
||||
CMP #$18
|
||||
BEQ beq1 ; taken
|
||||
AND #$00 ; not done
|
||||
beq1:
|
||||
; zpg
|
||||
ORA #$01
|
||||
CMP $30
|
||||
BNE bne1 ; taken
|
||||
AND #$00 ; not done
|
||||
bne1:
|
||||
; abs
|
||||
LDX #$00
|
||||
CMP $0130
|
||||
BEQ beq2 ; not taken
|
||||
STA $40
|
||||
LDX $40
|
||||
beq2:
|
||||
; zpx
|
||||
CMP $27,X
|
||||
BNE bne2 ; not taken
|
||||
ORA #$84
|
||||
STA $41
|
||||
LDX $41
|
||||
bne2:
|
||||
; abx
|
||||
AND #$DB
|
||||
CMP $0100,X
|
||||
BEQ beq3 ; taken
|
||||
AND #$00 ; not done
|
||||
beq3:
|
||||
; aby
|
||||
STA $42
|
||||
LDY $42
|
||||
AND #$00
|
||||
CMP $0100,Y
|
||||
BNE bne3 ; taken
|
||||
ORA #$0F ; not done
|
||||
bne3:
|
||||
; idx
|
||||
STA $43
|
||||
LDX $43
|
||||
ORA #$24
|
||||
CMP ($40,X)
|
||||
BEQ beq4 ; not taken
|
||||
ORA #$7F
|
||||
beq4:
|
||||
; idy
|
||||
STA $44
|
||||
LDY $44
|
||||
EOR #$0F
|
||||
CMP ($33),Y
|
||||
BNE bne4 ; not taken
|
||||
LDA $44
|
||||
STA $15
|
||||
bne4:
|
||||
|
||||
; CHECK test07
|
||||
LDA $15
|
||||
CMP $0207
|
||||
BEQ test08
|
||||
LDA #$07
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $42 = 0xA5
|
||||
test08:
|
||||
; prepare memory
|
||||
LDA #$A5
|
||||
STA $20
|
||||
STA $0120
|
||||
LDA #$5A
|
||||
STA $21
|
||||
|
||||
; cpx imm...
|
||||
LDX #$A5
|
||||
CPX #$A5
|
||||
BEQ b1 ; taken
|
||||
LDX #$01 ; not done
|
||||
b1:
|
||||
; cpx zpg...
|
||||
CPX $20
|
||||
BEQ b2 ; taken
|
||||
LDX #$02 ; not done
|
||||
b2:
|
||||
; cpx abs...
|
||||
CPX $0120
|
||||
BEQ b3 ; taken
|
||||
LDX #$03 ; not done
|
||||
b3:
|
||||
; cpy imm...
|
||||
STX $30
|
||||
LDY $30
|
||||
CPY #$A5
|
||||
BEQ b4 ; taken
|
||||
LDY #$04 ; not done
|
||||
b4:
|
||||
; cpy zpg...
|
||||
CPY $20
|
||||
BEQ b5 ; taken
|
||||
LDY #$05 ; not done
|
||||
b5:
|
||||
; cpy abs...
|
||||
CPY $0120
|
||||
BEQ b6 ; taken
|
||||
LDY #$06 ; not done
|
||||
b6:
|
||||
; bit zpg...
|
||||
STY $31
|
||||
LDA $31
|
||||
BIT $20
|
||||
BNE b7 ; taken
|
||||
LDA #$07 ; not done
|
||||
b7:
|
||||
; bit abs...
|
||||
BIT $0120
|
||||
BNE b8 ; taken
|
||||
LDA #$08 ; not done
|
||||
b8:
|
||||
BIT $21
|
||||
BNE b9 ; not taken
|
||||
STA $42
|
||||
b9:
|
||||
|
||||
; CHECK test08
|
||||
LDA $42
|
||||
CMP $0208
|
||||
BEQ test09
|
||||
LDA #$08
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $80 = 0x1F
|
||||
test09:
|
||||
; prepare memory
|
||||
LDA #$54
|
||||
STA $32
|
||||
LDA #$B3
|
||||
STA $A1
|
||||
LDA #$87
|
||||
STA $43
|
||||
|
||||
; BPL
|
||||
LDX #$A1
|
||||
BPL bpl1 ; not taken
|
||||
LDX #$32
|
||||
bpl1:
|
||||
LDY $00,X
|
||||
BPL bpl2 ; taken
|
||||
LDA #$05 ; not done
|
||||
LDX $A1 ; not done
|
||||
bpl2:
|
||||
|
||||
; BMI
|
||||
BMI bmi1 ; not taken
|
||||
SBC #$03
|
||||
bmi1:
|
||||
BMI bmi2 ; taken
|
||||
LDA #$41 ; not done
|
||||
bmi2:
|
||||
|
||||
; BVC
|
||||
EOR #$30
|
||||
STA $32
|
||||
ADC $00,X
|
||||
BVC bvc1 ; not taken
|
||||
LDA #$03
|
||||
bvc1:
|
||||
STA $54
|
||||
LDX $00,Y
|
||||
ADC $51,X
|
||||
BVC bvc2 ; taken
|
||||
LDA #$E5 ; not done
|
||||
bvc2:
|
||||
|
||||
; BVS
|
||||
ADC $40,X
|
||||
BVS bvs1 ; not taken
|
||||
STA $0001,Y
|
||||
ADC $55
|
||||
bvs1:
|
||||
BVS bvs2 ; taken
|
||||
LDA #$00
|
||||
bvs2:
|
||||
|
||||
; BCC
|
||||
ADC #$F0
|
||||
BCC bcc1 ; not taken
|
||||
STA $60
|
||||
ADC $43
|
||||
bcc1:
|
||||
BCC bcc2 ; taken
|
||||
LDA #$FF
|
||||
bcc2:
|
||||
|
||||
; BCS
|
||||
ADC $54
|
||||
BCS bcs1 ; not taken
|
||||
ADC #$87
|
||||
LDX $60
|
||||
bcs1:
|
||||
BCS bcs2 ; taken
|
||||
LDA #$00 ; not done
|
||||
bcs2:
|
||||
STA $73,X
|
||||
|
||||
; CHECK test09
|
||||
LDA $80
|
||||
CMP $0209
|
||||
BEQ test10
|
||||
LDA #$09
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $30 = 0xCE
|
||||
test10:
|
||||
|
||||
; RESET TO CARRY = 0 & OVERFLOW = 0
|
||||
ADC #$00
|
||||
|
||||
LDA #$99
|
||||
ADC #$87
|
||||
CLC
|
||||
NOP
|
||||
BCC t10bcc1 ; taken
|
||||
ADC #$60 ; not done
|
||||
ADC #$93 ; not done
|
||||
t10bcc1:
|
||||
SEC
|
||||
NOP
|
||||
BCC t10bcc2 ; not taken
|
||||
CLV
|
||||
t10bcc2:
|
||||
BVC t10bvc1 ; taken
|
||||
LDA #$00 ; not done
|
||||
t10bvc1:
|
||||
ADC #$AD
|
||||
NOP
|
||||
STA $30
|
||||
|
||||
; CHECK test10
|
||||
LDA $30
|
||||
CMP $020A
|
||||
BEQ test11
|
||||
LDA #$0A
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $30 = 0x29
|
||||
test11:
|
||||
|
||||
; RESET TO CARRY = 0 & ZERO = 0
|
||||
ADC #$01
|
||||
|
||||
LDA #$27
|
||||
ADC #$01
|
||||
SEC
|
||||
PHP
|
||||
CLC
|
||||
PLP
|
||||
ADC #$00
|
||||
PHA
|
||||
LDA #$00
|
||||
PLA
|
||||
STA $30
|
||||
|
||||
; CHECK test11
|
||||
LDA $30
|
||||
CMP $020B
|
||||
BEQ test12
|
||||
LDA #$0B
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $33 = 0x42
|
||||
test12:
|
||||
CLC
|
||||
LDA #$42
|
||||
BCC runstuff
|
||||
STA $33
|
||||
BCS t12end
|
||||
runstuff:
|
||||
LDA #$45
|
||||
PHA
|
||||
LDA #$61
|
||||
PHA
|
||||
SEC
|
||||
PHP
|
||||
CLC
|
||||
RTI
|
||||
t12end:
|
||||
|
||||
; CHECK test12
|
||||
LDA $33
|
||||
CMP $020C
|
||||
BEQ test13
|
||||
LDA #$0C
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expected result: $21 = 0x6C (simulator)
|
||||
; $21 = 0x0C (ours)
|
||||
test13:
|
||||
|
||||
; RESET TO CARRY = 0 & ZERO = 0
|
||||
ADC #$01
|
||||
|
||||
SEI
|
||||
SED
|
||||
PHP
|
||||
PLA
|
||||
STA $20
|
||||
CLI
|
||||
CLD
|
||||
PHP
|
||||
PLA
|
||||
ADC $20
|
||||
STA $21
|
||||
|
||||
; CHECK test13
|
||||
LDA $21
|
||||
CMP $020D
|
||||
BEQ test14
|
||||
LDA #$0D
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
|
||||
; expect result: $60 = 0x42
|
||||
test14:
|
||||
; !!! NOTICE: BRK doesn't work in this
|
||||
; simulator, so commented instructions
|
||||
; are what should be executed...
|
||||
;JMP pass_intrp
|
||||
LDA #$41
|
||||
STA $60
|
||||
;RTI
|
||||
;pass_intrp:
|
||||
;LDA #$FF
|
||||
;STA $60
|
||||
;BRK (two bytes)
|
||||
INC $60
|
||||
|
||||
; CHECK test14
|
||||
LDA $60
|
||||
CMP $020E
|
||||
BEQ suiteafinal
|
||||
LDA #$0E
|
||||
STA $0210
|
||||
JMP theend
|
||||
|
||||
suiteafinal:
|
||||
; IF $0210 == 0xFE, INCREMENT
|
||||
; (checking that it didn't
|
||||
; happen to wander off and
|
||||
; not run our instructions
|
||||
; to say which tests failed...)
|
||||
LDA #$FE
|
||||
CMP $0210
|
||||
BNE theend
|
||||
INC $0210
|
||||
theend:
|
||||
JMP theend
|
BIN
src/rom/AllSuiteA.bin
Normal file
BIN
src/rom/AllSuiteA.bin
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user