1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-26 00:30:29 +00:00

Completes the opcode set.

A million bugs yet to find.
This commit is contained in:
Thomas Harte 2020-09-26 21:35:31 -04:00
parent 67c2ce2174
commit e680022b1f
2 changed files with 50 additions and 27 deletions

View File

@ -42,7 +42,7 @@ struct CPU::WDC65816::ProcessorStorageConstructor {
using GeneratorKey = std::tuple<AccessType, Generator>; using GeneratorKey = std::tuple<AccessType, Generator>;
std::map<GeneratorKey, std::pair<size_t, size_t>> installed_patterns; std::map<GeneratorKey, std::pair<size_t, size_t>> installed_patterns;
uint8_t opcode = 0; int opcode = 0;
void install(Generator generator, Operation operation) { void install(Generator generator, Operation operation) {
// Determine the access type implied by this operation. // Determine the access type implied by this operation.
const AccessType access_type = access_type_for_operation(operation); const AccessType access_type = access_type_for_operation(operation);
@ -627,8 +627,8 @@ struct CPU::WDC65816::ProcessorStorageConstructor {
// 22g. Stack; s, RTI. // 22g. Stack; s, RTI.
static void stack_rti(AccessType, bool is8bit, const std::function<void(MicroOp)> &target) { static void stack_rti(AccessType, bool is8bit, const std::function<void(MicroOp)> &target) {
target(CycleFetchIncrementPC); // IO target(CycleFetchPC); // IO
target(CycleFetchIncrementPC); // IO target(CycleFetchPC); // IO
target(CyclePull); // P target(CyclePull); // P
target(CyclePull); // New PCL target(CyclePull); // New PCL
@ -640,8 +640,8 @@ struct CPU::WDC65816::ProcessorStorageConstructor {
// 22h. Stack; s, RTS. // 22h. Stack; s, RTS.
static void stack_rts(AccessType, bool, const std::function<void(MicroOp)> &target) { static void stack_rts(AccessType, bool, const std::function<void(MicroOp)> &target) {
target(CycleFetchIncrementPC); // IO target(CycleFetchPC); // IO
target(CycleFetchIncrementPC); // IO target(CycleFetchPC); // IO
target(CyclePull); // PCL target(CyclePull); // PCL
target(CyclePull); // PCH target(CyclePull); // PCH
@ -667,7 +667,27 @@ struct CPU::WDC65816::ProcessorStorageConstructor {
// Covered by stack_exception. // Covered by stack_exception.
// 23. Stack Relative; d, s. // 23. Stack Relative; d, s.
static void stack_relative(AccessType type, bool is8bit, const std::function<void(MicroOp)> &target) {
target(CycleFetchIncrementPC); // SO
target(CycleFetchPC); // IO
target(OperationConstructStackRelative);
read_write(type, is8bit, target);
}
// 24. Stack Relative Indirect Indexed (d, s), y. // 24. Stack Relative Indirect Indexed (d, s), y.
static void stack_relative_indexed_indirect(AccessType type, bool is8bit, const std::function<void(MicroOp)> &target) {
target(CycleFetchIncrementPC); // SO
target(CycleFetchPC); // IO
target(OperationConstructStackRelative);
target(CycleFetchIncrementData); // AAL
target(CycleFetchData); // AAH
target(CycleFetchData); // IO.
target(OperationConstructStackRelativeIndexedIndirect);
read_write(type, is8bit, target);
}
}; };
// TEMPORARY. Kneejerk way to get a step debug of 65816 storage construction. // TEMPORARY. Kneejerk way to get a step debug of 65816 storage construction.
@ -682,7 +702,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x00 BRK s */ op(stack_exception, BRK); /* 0x00 BRK s */ op(stack_exception, BRK);
/* 0x01 ORA (d, x) */ op(direct_indexed_indirect, ORA); /* 0x01 ORA (d, x) */ op(direct_indexed_indirect, ORA);
/* 0x02 COP s */ op(stack_exception, BRK); /* 0x02 COP s */ op(stack_exception, BRK);
/* 0x03 ORA d, s */ /* 0x03 ORA d, s */ op(stack_relative, ORA);
/* 0x04 TSB d */ op(direct_rmw, TSB); /* 0x04 TSB d */ op(direct_rmw, TSB);
/* 0x05 ORA d */ op(direct, ORA); /* 0x05 ORA d */ op(direct, ORA);
/* 0x06 ASL d */ op(direct_rmw, ASL); /* 0x06 ASL d */ op(direct_rmw, ASL);
@ -699,7 +719,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x10 BPL r */ op(relative, BPL); /* 0x10 BPL r */ op(relative, BPL);
/* 0x11 ORA (d), y */ op(direct_indirect_indexed, ORA); /* 0x11 ORA (d), y */ op(direct_indirect_indexed, ORA);
/* 0x12 ORA (d) */ op(direct_indirect, ORA); /* 0x12 ORA (d) */ op(direct_indirect, ORA);
/* 0x13 ORA (d, s), y */ /* 0x13 ORA (d, s), y */ op(stack_relative_indexed_indirect, ORA);
/* 0x14 TRB d */ op(absolute_rmw, TRB); /* 0x14 TRB d */ op(absolute_rmw, TRB);
/* 0x15 ORA d, x */ op(direct_x, ORA); /* 0x15 ORA d, x */ op(direct_x, ORA);
/* 0x16 ASL d, x */ op(direct_x_rmw, ASL); /* 0x16 ASL d, x */ op(direct_x_rmw, ASL);
@ -716,7 +736,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x20 JSR a */ op(absolute_jsr, JSR); /* 0x20 JSR a */ op(absolute_jsr, JSR);
/* 0x21 AND (d, x) */ op(direct_indexed_indirect, AND); /* 0x21 AND (d, x) */ op(direct_indexed_indirect, AND);
/* 0x22 JSL al */ op(absolute_long_jsl, JSL); /* 0x22 JSL al */ op(absolute_long_jsl, JSL);
/* 0x23 AND d, s */ /* 0x23 AND d, s */ op(stack_relative, AND);
/* 0x24 BIT d */ op(direct, BIT); /* 0x24 BIT d */ op(direct, BIT);
/* 0x25 AND d */ op(direct, AND); /* 0x25 AND d */ op(direct, AND);
/* 0x26 ROL d */ op(absolute_rmw, ROL); /* 0x26 ROL d */ op(absolute_rmw, ROL);
@ -733,7 +753,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x30 BMI r */ op(relative, BMI); /* 0x30 BMI r */ op(relative, BMI);
/* 0x31 AND (d), y */ op(direct_indirect_indexed, AND); /* 0x31 AND (d), y */ op(direct_indirect_indexed, AND);
/* 0x32 AND (d) */ op(direct_indirect, AND); /* 0x32 AND (d) */ op(direct_indirect, AND);
/* 0x33 AND (d, s), y */ /* 0x33 AND (d, s), y */ op(stack_relative_indexed_indirect, AND);
/* 0x34 BIT d, x */ op(direct_x, BIT); /* 0x34 BIT d, x */ op(direct_x, BIT);
/* 0x35 AND d, x */ op(direct_x, AND); /* 0x35 AND d, x */ op(direct_x, AND);
/* 0x36 ROL d, x */ op(absolute_x_rmw, ROL); /* 0x36 ROL d, x */ op(absolute_x_rmw, ROL);
@ -749,8 +769,8 @@ ProcessorStorage::ProcessorStorage() {
/* 0x40 RTI s */ op(stack_rti, RTI); /* 0x40 RTI s */ op(stack_rti, RTI);
/* 0x41 EOR (d, x) */ op(direct_indexed_indirect, EOR); /* 0x41 EOR (d, x) */ op(direct_indexed_indirect, EOR);
/* 0x42 WDM i */ /* 0x42 WDM i */ op(implied, NOP);
/* 0x43 EOR d, s */ /* 0x43 EOR d, s */ op(stack_relative, EOR);
/* 0x44 MVP xyc */ op(block_move, MVP); /* 0x44 MVP xyc */ op(block_move, MVP);
/* 0x45 EOR d */ op(direct, EOR); /* 0x45 EOR d */ op(direct, EOR);
/* 0x46 LSR d */ op(direct_rmw, LSR); /* 0x46 LSR d */ op(direct_rmw, LSR);
@ -767,7 +787,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x50 BVC r */ op(relative, BVC); /* 0x50 BVC r */ op(relative, BVC);
/* 0x51 EOR (d), y */ op(direct_indirect_indexed, EOR); /* 0x51 EOR (d), y */ op(direct_indirect_indexed, EOR);
/* 0x52 EOR (d) */ op(direct_indirect, EOR); /* 0x52 EOR (d) */ op(direct_indirect, EOR);
/* 0x53 EOR (d, s), y */ /* 0x53 EOR (d, s), y */ op(stack_relative_indexed_indirect, EOR);
/* 0x54 MVN xyc */ op(block_move, MVN); /* 0x54 MVN xyc */ op(block_move, MVN);
/* 0x55 EOR d, x */ op(direct_x, EOR); /* 0x55 EOR d, x */ op(direct_x, EOR);
/* 0x56 LSR d, x */ op(direct_x_rmw, LSR); /* 0x56 LSR d, x */ op(direct_x_rmw, LSR);
@ -784,7 +804,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x60 RTS s */ op(stack_rts, JMP); // [sic]; loads the PC from data as per an RTS. /* 0x60 RTS s */ op(stack_rts, JMP); // [sic]; loads the PC from data as per an RTS.
/* 0x61 ADC (d, x) */ op(direct_indexed_indirect, ADC); /* 0x61 ADC (d, x) */ op(direct_indexed_indirect, ADC);
/* 0x62 PER s */ op(stack_per, NOP); /* 0x62 PER s */ op(stack_per, NOP);
/* 0x63 ADC d, s */ /* 0x63 ADC d, s */ op(stack_relative, ADC);
/* 0x64 STZ d */ op(direct, STZ); /* 0x64 STZ d */ op(direct, STZ);
/* 0x65 ADC d */ op(direct, ADC); /* 0x65 ADC d */ op(direct, ADC);
/* 0x66 ROR d */ op(direct_rmw, ROR); /* 0x66 ROR d */ op(direct_rmw, ROR);
@ -801,7 +821,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x70 BVS r */ op(relative, BVS); /* 0x70 BVS r */ op(relative, BVS);
/* 0x71 ADC (d), y */ op(direct_indirect_indexed, ADC); /* 0x71 ADC (d), y */ op(direct_indirect_indexed, ADC);
/* 0x72 ADC (d) */ op(direct_indirect, ADC); /* 0x72 ADC (d) */ op(direct_indirect, ADC);
/* 0x73 ADC (d, s), y */ /* 0x73 ADC (d, s), y */ op(stack_relative_indexed_indirect, ADC);
/* 0x74 STZ d, x */ op(direct_x, STZ); /* 0x74 STZ d, x */ op(direct_x, STZ);
/* 0x75 ADC d, x */ op(direct_x, ADC); /* 0x75 ADC d, x */ op(direct_x, ADC);
/* 0x76 ROR d, x */ op(direct_x_rmw, ROR); /* 0x76 ROR d, x */ op(direct_x_rmw, ROR);
@ -818,7 +838,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x80 BRA r */ op(relative, BRA); /* 0x80 BRA r */ op(relative, BRA);
/* 0x81 STA (d, x) */ op(direct_indexed_indirect, STA); /* 0x81 STA (d, x) */ op(direct_indexed_indirect, STA);
/* 0x82 BRL rl */ op(relative_long, BRL); /* 0x82 BRL rl */ op(relative_long, BRL);
/* 0x83 STA d, s */ /* 0x83 STA d, s */ op(stack_relative, STA);
/* 0x84 STY d */ op(direct, STY); /* 0x84 STY d */ op(direct, STY);
/* 0x85 STA d */ op(direct, STA); /* 0x85 STA d */ op(direct, STA);
/* 0x86 STX d */ op(direct, STX); /* 0x86 STX d */ op(direct, STX);
@ -835,7 +855,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0x90 BCC r */ op(relative, BCC); /* 0x90 BCC r */ op(relative, BCC);
/* 0x91 STA (d), y */ op(direct_indirect_indexed, STA); /* 0x91 STA (d), y */ op(direct_indirect_indexed, STA);
/* 0x92 STA (d) */ op(direct_indirect, STA); /* 0x92 STA (d) */ op(direct_indirect, STA);
/* 0x93 STA (d, x), y */ /* 0x93 STA (d, s), y */ op(stack_relative_indexed_indirect, STA);
/* 0x94 STY d, x */ op(direct_x, STY); /* 0x94 STY d, x */ op(direct_x, STY);
/* 0x95 STA d, x */ op(direct_x, STA); /* 0x95 STA d, x */ op(direct_x, STA);
/* 0x96 STX d, y */ op(direct_y, STX); /* 0x96 STX d, y */ op(direct_y, STX);
@ -852,7 +872,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0xa0 LDY # */ op(immediate, LDY); /* 0xa0 LDY # */ op(immediate, LDY);
/* 0xa1 LDA (d, x) */ op(direct_indexed_indirect, LDA); /* 0xa1 LDA (d, x) */ op(direct_indexed_indirect, LDA);
/* 0xa2 LDX # */ op(immediate, LDX); /* 0xa2 LDX # */ op(immediate, LDX);
/* 0xa3 LDA d, s */ /* 0xa3 LDA d, s */ op(stack_relative, LDA);
/* 0xa4 LDY d */ op(direct, LDY); /* 0xa4 LDY d */ op(direct, LDY);
/* 0xa5 LDA d */ op(direct, LDA); /* 0xa5 LDA d */ op(direct, LDA);
/* 0xa6 LDX d */ op(direct, LDX); /* 0xa6 LDX d */ op(direct, LDX);
@ -869,7 +889,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0xb0 BCS r */ op(relative, BCS); /* 0xb0 BCS r */ op(relative, BCS);
/* 0xb1 LDA (d), y */ op(direct_indirect_indexed, LDA); /* 0xb1 LDA (d), y */ op(direct_indirect_indexed, LDA);
/* 0xb2 LDA (d) */ op(direct_indirect, LDA); /* 0xb2 LDA (d) */ op(direct_indirect, LDA);
/* 0xb3 LDA (d, s), y */ /* 0xb3 LDA (d, s), y */ op(stack_relative_indexed_indirect, LDA);
/* 0xb4 LDY d, x */ op(direct_x, LDY); /* 0xb4 LDY d, x */ op(direct_x, LDY);
/* 0xb5 LDA d, x */ op(direct_x, LDA); /* 0xb5 LDA d, x */ op(direct_x, LDA);
/* 0xb6 LDX d, y */ op(direct_y, LDX); /* 0xb6 LDX d, y */ op(direct_y, LDX);
@ -886,7 +906,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0xc0 CPY # */ op(immediate, CPY); /* 0xc0 CPY # */ op(immediate, CPY);
/* 0xc1 CMP (d, x) */ op(direct_indexed_indirect, CMP); /* 0xc1 CMP (d, x) */ op(direct_indexed_indirect, CMP);
/* 0xc2 REP # */ op(immediate_rep_sep, REP); /* 0xc2 REP # */ op(immediate_rep_sep, REP);
/* 0xc3 CMP d, s */ /* 0xc3 CMP d, s */ op(stack_relative, CMP);
/* 0xc4 CPY d */ op(direct, CPY); /* 0xc4 CPY d */ op(direct, CPY);
/* 0xc5 CMP d */ op(direct, CMP); /* 0xc5 CMP d */ op(direct, CMP);
/* 0xc6 DEC d */ op(direct_rmw, DEC); /* 0xc6 DEC d */ op(direct_rmw, DEC);
@ -903,7 +923,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0xd0 BNE r */ op(relative, BNE); /* 0xd0 BNE r */ op(relative, BNE);
/* 0xd1 CMP (d), y */ op(direct_indirect_indexed, CMP); /* 0xd1 CMP (d), y */ op(direct_indirect_indexed, CMP);
/* 0xd2 CMP (d) */ op(direct_indirect, CMP); /* 0xd2 CMP (d) */ op(direct_indirect, CMP);
/* 0xd3 CMP (d, s), y */ /* 0xd3 CMP (d, s), y */ op(stack_relative_indexed_indirect, CMP);
/* 0xd4 PEI s */ op(stack_pei, NOP); /* 0xd4 PEI s */ op(stack_pei, NOP);
/* 0xd5 CMP d, x */ op(direct_x, CMP); /* 0xd5 CMP d, x */ op(direct_x, CMP);
/* 0xd6 DEC d, x */ op(direct_x_rmw, DEC); /* 0xd6 DEC d, x */ op(direct_x_rmw, DEC);
@ -920,13 +940,13 @@ ProcessorStorage::ProcessorStorage() {
/* 0xe0 CPX # */ op(immediate, CPX); /* 0xe0 CPX # */ op(immediate, CPX);
/* 0xe1 SBC (d, x) */ op(direct_indexed_indirect, SBC); /* 0xe1 SBC (d, x) */ op(direct_indexed_indirect, SBC);
/* 0xe2 SEP # */ op(immediate_rep_sep, SEP); /* 0xe2 SEP # */ op(immediate_rep_sep, SEP);
/* 0xe3 SBC d, s */ /* 0xe3 SBC d, s */ op(stack_relative, SBC);
/* 0xe4 CPX d */ op(direct, CPX); /* 0xe4 CPX d */ op(direct, CPX);
/* 0xe5 SBC d */ op(direct, SBC); /* 0xe5 SBC d */ op(direct, SBC);
/* 0xe6 INC d */ op(direct_rmw, INC); /* 0xe6 INC d */ op(direct_rmw, INC);
/* 0xe7 SBC [d] */ op(direct_indirect_long, SBC); /* 0xe7 SBC [d] */ op(direct_indirect_long, SBC);
/* 0xe8 INX i */ op(implied, INX); /* 0xe8 INX i */ op(implied, INX);
/* 0xe9 SBC # */ /* 0xe9 SBC # */ op(immediate, SBC);
/* 0xea NOP i */ op(implied, NOP); /* 0xea NOP i */ op(implied, NOP);
/* 0xeb XBA i */ op(implied_xba, XBA); /* 0xeb XBA i */ op(implied_xba, XBA);
/* 0xec CPX a */ op(absolute, CPX); /* 0xec CPX a */ op(absolute, CPX);
@ -937,7 +957,7 @@ ProcessorStorage::ProcessorStorage() {
/* 0xf0 BEQ r */ op(relative, BEQ); /* 0xf0 BEQ r */ op(relative, BEQ);
/* 0xf1 SBC (d), y */ op(direct_indirect_indexed, SBC); /* 0xf1 SBC (d), y */ op(direct_indirect_indexed, SBC);
/* 0xf2 SBC (d) */ op(direct_indirect, SBC); /* 0xf2 SBC (d) */ op(direct_indirect, SBC);
/* 0xf3 SBC (d, s), y */ /* 0xf3 SBC (d, s), y */ op(stack_relative_indexed_indirect, SBC);
/* 0xf4 PEA s */ op(stack_pea, NOP); /* 0xf4 PEA s */ op(stack_pea, NOP);
/* 0xf5 SBC d, x */ op(direct_x, SBC); /* 0xf5 SBC d, x */ op(direct_x, SBC);
/* 0xf6 INC d, x */ op(direct_x_rmw, INC); /* 0xf6 INC d, x */ op(direct_x_rmw, INC);

View File

@ -81,6 +81,9 @@ enum MicroOp: uint8_t {
OperationConstructPER, OperationConstructPER,
OperationConstructBRK, OperationConstructBRK,
OperationConstructStackRelative,
OperationConstructStackRelativeIndexedIndirect,
/// Performs whatever operation goes with this program. /// Performs whatever operation goes with this program.
OperationPerform, OperationPerform,