URL
https://opencores.org/ocsvn/t6507lp/t6507lp/trunk
Subversion Repositories t6507lp
[/] [t6507lp/] [trunk/] [fv/] [fsm_chk.e] - Rev 244
Go to most recent revision | Compare with Previous | Blame | View Log
<' import fsm_components; type state_t : [RESET, CYCLE_1, CYCLE_2, CYCLE_3, CYCLE_4, CYCLE_5, CYCLE_6, CYCLE_7]; unit fsm_chk_u { !A : byte; keep soft A == 0; !X : byte; keep soft X == 0; !Y : byte; keep soft Y == 0; !PC : uint(bits : 13); keep soft PC == 0; // !SP : uint(bits : 9); // keep soft SP == 9'b100000000; !SP : byte; keep soft SP == 0; !pointer : byte; keep soft pointer == 0; !pointer_h : byte; keep soft pointer_h == 0; !more_cycles : bool; keep soft more_cycles == FALSE; --!R : byte; -- keep soft R == 0; --!PS : byte; -- keep soft PS[0:0] == 0; -- keep soft PS[1:1] == 0; -- keep soft PS[2:2] == 0; -- keep soft PS[3:3] == 0; -- keep soft PS[4:4] == 0; -- keep soft PS[5:5] == 1; -- keep soft PS[6:6] == 0; -- keep soft PS[7:7] == 0; -- N : bit; -- V : bit; -- B : bit; -- D : bit; -- I : bit; -- Z : bit; -- C : bit; -- keep soft N == 0; -- keep soft V == 0; -- keep soft B == 0; -- keep soft D == 0; -- keep soft I == 0; -- keep soft Z == 0; -- keep soft C == 0; !new_inst : bool; keep new_inst == FALSE; !new_input : fsm_input_s; !old_input : fsm_input_s; --!new_inst : bool; --keep soft new_inst == FALSE; --!i : ps_index; !new_state : state_t; !old_state : state_t; --count_cycles : int; --first_cycle : bool; --last_a : byte; --last_status : byte; --last_result : byte; !PCL:byte; !PCH:byte; !SP_aux:byte; !rst : bit; !rst_counter : byte; --keep first_cycle == TRUE; --keep count_cycles == 0; keep rst_counter == 0; !instruction : valid_opcodes; !last_instruction : valid_opcodes; !instructions : valid_opcodes; print_state () is { outf("-------------------------------------------------------\n"); print instructions; -- print instruction; print 't6507lp_fsm.ir'; print 't6507lp_fsm.sp'; print SP + 256; print 't6507lp_fsm.pc'; print PC; --print addr; case ('t6507lp_fsm.state') { 0 : { outf(" t6507lp_fsm.state = FETCH_OP\n"); }; 2 : { outf(" t6507lp_fsm.state = FETCH_LOW\n");}; 3 : { outf(" t6507lp_fsm.state = FETCH_HIGH\n"); }; 4 : { outf(" t6507lp_fsm.state = READ_MEM\n"); }; 5 : { outf(" t6507lp_fsm.state = DUMMY_WRT_CALC\n"); }; 6 : { outf(" t6507lp_fsm.state = WRITE_MEM\n"); }; 7 : { outf(" t6507lp_fsm.state = FETCH_OP_CALC_PARAM\n"); }; 8 : { outf(" t6507lp_fsm.state = READ_MEM_CALC_INDEX\n"); }; 9 : { outf(" t6507lp_fsm.state = FETCH_HIGH_CALC_INDEX\n"); }; 10 : { outf(" t6507lp_fsm.state = READ_MEM_FIX_ADDR\n"); }; 11 : { outf(" t6507lp_fsm.state = FETCH_OP_EVAL_BRANCH\n"); }; 12 : { outf(" t6507lp_fsm.state = FETCH_OP_FIX_PC\n"); }; 13 : { outf(" t6507lp_fsm.state = READ_FROM_POINTER\n"); }; 14 : { outf(" t6507lp_fsm.state = READ_FROM_POINTER_X\n"); }; 15 : { outf(" t6507lp_fsm.state = READ_FROM_POINTER_X1\n"); }; 16 : { outf(" t6507lp_fsm.state = PUSH_PCH\n"); }; 17 : { outf(" t6507lp_fsm.state = PUSH_PCL\n"); }; 18 : { outf(" t6507lp_fsm.state = PUSH_STATUS\n"); }; 19 : { outf(" t6507lp_fsm.state = FETCH_PCL\n"); }; 20 : { outf(" t6507lp_fsm.state = FETCH_PCH\n"); }; 21 : { outf(" t6507lp_fsm.state = INCREMENT_SP\n"); }; 22 : { outf(" t6507lp_fsm.state = PULL_STATUS\n"); }; 23 : { outf(" t6507lp_fsm.state = PULL_PCL\n"); }; 24 : { outf(" t6507lp_fsm.state = PULL_PCH\n"); }; 25 : { outf(" t6507lp_fsm.state = INCREMENT_PC\n"); }; 26 : { outf(" t6507lp_fsm.state = PUSH_REGISTER\n"); }; 27 : { outf(" t6507lp_fsm.state = PULL_REGISTER\n"); }; 28 : { outf(" t6507lp_fsm.state = DUMMY\n"); }; 31 : { outf(" t6507lp_fsm.state = RESET\n"); }; }; }; store(input : fsm_input_s) is { --reset_n : bit; --alu_result : byte; --alu_status : byte; --data_in : byte; --alu_x : byte; --alu_y : byte; //print me; //print input; if (input.reset_n == 0) { rst_counter = 0; new_state = RESET; old_state = RESET; A = 0; X = 0; Y = 0; PC = 0; SP = 255; } else { case (old_state) { RESET : { if (rst_counter == 7) { new_state = CYCLE_1; }; }; CYCLE_1 : { instruction = input.data_in.as_a(valid_opcodes); new_state = CYCLE_2; }; CYCLE_2 : { X = input.alu_x; Y = input.alu_y; case { ( instruction == BRK_IMP || instruction == PHA_IMP || instruction == PHP_IMP || instruction == PLA_IMP || instruction == PLP_IMP || instruction == RTI_IMP || instruction == RTS_IMP ) : { new_state = CYCLE_3; }; instruction == JSR_ABS : { new_state = CYCLE_3; PCL = input.data_in; }; ( instruction == ADC_ABS || instruction == ASL_ABS || instruction == BIT_ABS || instruction == AND_ABS || instruction == CMP_ABS || instruction == CPX_ABS || instruction == CPY_ABS || instruction == DEC_ABS || instruction == EOR_ABS || instruction == INC_ABS || instruction == JMP_ABS || instruction == LDA_ABS || instruction == LDX_ABS || instruction == LDY_ABS || instruction == LSR_ABS || instruction == ORA_ABS || instruction == ROL_ABS || instruction == ROR_ABS || instruction == SBC_ABS || instruction == STA_ABS || instruction == STX_ABS || instruction == STY_ABS || instruction == LDA_ZPG || instruction == LDX_ZPG || instruction == LDY_ZPG || instruction == EOR_ZPG || instruction == AND_ZPG || instruction == ORA_ZPG || instruction == ADC_ZPG || instruction == SBC_ZPG || instruction == CMP_ZPG || instruction == CPX_ZPG || instruction == CPY_ZPG || instruction == BIT_ZPG || instruction == STA_ZPG || instruction == STX_ZPG || instruction == STY_ZPG || instruction == ASL_ZPG || instruction == LSR_ZPG || instruction == ROL_ZPG || instruction == ROR_ZPG || instruction == INC_ZPG || instruction == DEC_ZPG || instruction == LDA_ZPX || instruction == LDX_ZPY || instruction == LDY_ZPX || instruction == EOR_ZPX || instruction == AND_ZPX || instruction == ORA_ZPX || instruction == ADC_ZPX || instruction == SBC_ZPX || instruction == CMP_ZPX || instruction == ASL_ZPX || instruction == LSR_ZPX || instruction == ROL_ZPX || instruction == ROR_ZPX || instruction == INC_ZPX || instruction == DEC_ZPX || instruction == STA_ZPX || instruction == STX_ZPY || instruction == STY_ZPX || instruction == LDA_ABX || instruction == LDA_ABY || instruction == STA_ABX || instruction == STA_ABY || instruction == LDX_ABY || instruction == LDY_ABX || instruction == EOR_ABX || instruction == EOR_ABY || instruction == AND_ABX || instruction == AND_ABY || instruction == ORA_ABX || instruction == ORA_ABY || instruction == ADC_ABX || instruction == ADC_ABY || instruction == SBC_ABX || instruction == SBC_ABY || instruction == CMP_ABX || instruction == CMP_ABY || instruction == ASL_ABX || instruction == LSR_ABX || instruction == ROL_ABX || instruction == ROR_ABX || instruction == INC_ABX || instruction == DEC_ABX ) : { new_state = CYCLE_3; PCL = input.data_in; }; ( instruction == LDA_IDX || instruction == STA_IDX || instruction == ORA_IDX || instruction == EOR_IDX || instruction == AND_IDX || instruction == ADC_IDX || instruction == CMP_IDX || instruction == SBC_IDX || instruction == LDA_IDY || instruction == STA_IDY || instruction == ORA_IDY || instruction == EOR_IDY || instruction == AND_IDY || instruction == ADC_IDY || instruction == CMP_IDY || instruction == SBC_IDY || instruction == JMP_IND ) : { new_state = CYCLE_3; pointer = input.data_in; }; ( instruction == TXS_IMP ) : { new_state = CYCLE_1; SP_aux = input.alu_x; }; default : { new_state = CYCLE_1; }; }; }; CYCLE_3 : { case { instruction == JSR_ABS : { new_state = CYCLE_4; //PCH = input.data_in; }; ( instruction == BRK_IMP || instruction == PLA_IMP || instruction == PLP_IMP || instruction == RTI_IMP || instruction == RTS_IMP || instruction == ASL_ZPG || instruction == LSR_ZPG || instruction == ROL_ZPG || instruction == ROR_ZPG || instruction == INC_ZPG || instruction == DEC_ZPG || instruction == LDA_ZPX || instruction == LDX_ZPY || instruction == LDY_ZPX || instruction == EOR_ZPX || instruction == AND_ZPX || instruction == ORA_ZPX || instruction == ADC_ZPX || instruction == SBC_ZPX || instruction == CMP_ZPX || instruction == ASL_ZPX || instruction == LSR_ZPX || instruction == ROL_ZPX || instruction == ROR_ZPX || instruction == INC_ZPX || instruction == DEC_ZPX || instruction == STA_ZPX || instruction == STX_ZPY || instruction == STY_ZPX || instruction == LDA_IDX || instruction == STA_IDX || instruction == ORA_IDX || instruction == EOR_IDX || instruction == AND_IDX || instruction == ADC_IDX || instruction == CMP_IDX || instruction == SBC_IDX ) : { new_state = CYCLE_4; }; ( instruction == LDA_IDY || instruction == STA_IDY || instruction == ORA_IDY || instruction == EOR_IDY || instruction == AND_IDY || instruction == ADC_IDY || instruction == CMP_IDY || instruction == SBC_IDY ) : { new_state = CYCLE_4; PCL = input.data_in; }; ( instruction == JMP_IND ) : { new_state = CYCLE_4; pointer_h = input.data_in; }; ( instruction == ADC_ABS || instruction == ASL_ABS || instruction == BIT_ABS || instruction == AND_ABS || instruction == CMP_ABS || instruction == CPX_ABS || instruction == CPY_ABS || instruction == DEC_ABS || instruction == EOR_ABS || instruction == INC_ABS || instruction == LDA_ABS || instruction == LDX_ABS || instruction == LDY_ABS || instruction == LSR_ABS || instruction == ORA_ABS || instruction == ROL_ABS || instruction == ROR_ABS || instruction == SBC_ABS || instruction == STA_ABS || instruction == STX_ABS || instruction == STY_ABS || instruction == LDA_ABX || instruction == LDA_ABY || instruction == STA_ABX || instruction == STA_ABY || instruction == LDX_ABY || instruction == LDY_ABX || instruction == EOR_ABX || instruction == EOR_ABY || instruction == AND_ABX || instruction == AND_ABY || instruction == ORA_ABX || instruction == ORA_ABY || instruction == ADC_ABX || instruction == ADC_ABY || instruction == SBC_ABX || instruction == SBC_ABY || instruction == CMP_ABX || instruction == CMP_ABY || instruction == ASL_ABX || instruction == LSR_ABX || instruction == ROL_ABX || instruction == ROR_ABX || instruction == INC_ABX || instruction == DEC_ABX ) : { new_state = CYCLE_4; PCH = input.data_in; }; ( instruction == JMP_ABS ) : { new_state = CYCLE_1; PCH = input.data_in; }; default : { new_state = CYCLE_1; }; }; }; CYCLE_4 : { case { instruction == JSR_ABS : { new_state = CYCLE_5; }; ( instruction == RTS_IMP || instruction == JMP_IND ) : { new_state = CYCLE_5; PCL = input.data_in; }; ( instruction == ASL_ABS || instruction == BRK_IMP || instruction == DEC_ABS || instruction == INC_ABS || instruction == LSR_ABS || instruction == ROL_ABS || instruction == ROR_ABS || instruction == RTI_IMP || instruction == ASL_ZPG || instruction == LSR_ZPG || instruction == ROL_ZPG || instruction == ROR_ZPG || instruction == INC_ZPG || instruction == DEC_ZPG || instruction == ASL_ZPX || instruction == LSR_ZPX || instruction == ROL_ZPX || instruction == ROR_ZPX || instruction == INC_ZPX || instruction == DEC_ZPX || instruction == ASL_ABX || instruction == LSR_ABX || instruction == ROL_ABX || instruction == ROR_ABX || instruction == INC_ABX || instruction == DEC_ABX || instruction == STA_ABX || instruction == STA_ABY || ( more_cycles == TRUE && ( instruction == LDA_ABX || instruction == LDA_ABY || instruction == LDX_ABY || instruction == LDY_ABX || instruction == EOR_ABX || instruction == EOR_ABY || instruction == AND_ABX || instruction == AND_ABY || instruction == ORA_ABX || instruction == ORA_ABY || instruction == ADC_ABX || instruction == ADC_ABY || instruction == SBC_ABX || instruction == SBC_ABY || instruction == CMP_ABX || instruction == CMP_ABY ) ) ) : { new_state = CYCLE_5; }; ( instruction == LDA_IDX || instruction == STA_IDX || instruction == ORA_IDX || instruction == EOR_IDX || instruction == AND_IDX || instruction == ADC_IDX || instruction == CMP_IDX || instruction == SBC_IDX ) : { new_state = CYCLE_5; PCL = input.data_in; }; ( instruction == LDA_IDY || instruction == STA_IDY || instruction == ORA_IDY || instruction == EOR_IDY || instruction == AND_IDY || instruction == ADC_IDY || instruction == CMP_IDY || instruction == SBC_IDY ) : { new_state = CYCLE_5; PCH = input.data_in; }; default : { new_state = CYCLE_1; }; }; }; CYCLE_5 : { case { instruction == JSR_ABS : { new_state = CYCLE_6; }; ( instruction == RTI_IMP ) : { new_state = CYCLE_6; PCL = input.data_in; }; ( instruction == RTS_IMP ) : { new_state = CYCLE_6; PCH = input.data_in; }; ( instruction == ASL_ABS || instruction == BRK_IMP || instruction == DEC_ABS || instruction == INC_ABS || instruction == LSR_ABS || instruction == ROL_ABS || instruction == ROR_ABS || instruction == ASL_ZPX || instruction == LSR_ZPX || instruction == ROL_ZPX || instruction == ROR_ZPX || instruction == INC_ZPX || instruction == DEC_ZPX || instruction == ASL_ABX || instruction == LSR_ABX || instruction == ROL_ABX || instruction == ROR_ABX || instruction == INC_ABX || instruction == DEC_ABX || instruction == STA_IDY || ( more_cycles == TRUE && ( instruction == LDA_IDY || instruction == ORA_IDY || instruction == EOR_IDY || instruction == AND_IDY || instruction == ADC_IDY || instruction == CMP_IDY || instruction == SBC_IDY ) ) ) : { new_state = CYCLE_6; }; ( instruction == LDA_IDX || instruction == STA_IDX || instruction == ORA_IDX || instruction == EOR_IDX || instruction == AND_IDX || instruction == ADC_IDX || instruction == CMP_IDX || instruction == SBC_IDX ) : { new_state = CYCLE_6; PCH = input.data_in; }; ( instruction == JMP_IND ) : { new_state = CYCLE_1; PCH = input.data_in; }; default : { new_state = CYCLE_1; }; }; }; CYCLE_6 : { case { ( instruction == BRK_IMP ) : { new_state = CYCLE_7; PCL = input.data_in; }; ( instruction == RTI_IMP ) : { new_state = CYCLE_1; PCH = input.data_in; }; ( instruction == JSR_ABS ) : { new_state = CYCLE_1; PCH = input.data_in; }; ( instruction == ASL_ABX || instruction == LSR_ABX || instruction == ROL_ABX || instruction == ROR_ABX || instruction == INC_ABX || instruction == DEC_ABX ) : { new_state = CYCLE_7; }; default : { new_state = CYCLE_1; }; }; }; CYCLE_7 : { case (instruction) { BRK_IMP : { new_state = CYCLE_1; PCH = input.data_in; }; default : { new_state = CYCLE_1; }; }; }; }; old_input = new_input; new_input = input; }; }; compare(addr: uint(bits:13), mem_rw:bit, data_out:byte, alu_opcode:valid_opcodes, alu_a:byte, alu_enable:bit) is { case (old_state) { RESET : { print_state(); rst = 1; rst_counter = rst_counter + 1; }; CYCLE_1 : { more_cycles = FALSE; print_state(); print addr; last_instruction = instructions; instructions = instruction; if (mem_rw != 0) { dut_error("Mem_rw is Wrong!"); }; if (rst == 0) { case { ( last_instruction == ADC_ABS || last_instruction == ADC_IMM || last_instruction == AND_ABS || last_instruction == AND_IMM || last_instruction == BIT_ABS || last_instruction == CMP_ABS || last_instruction == CPX_ABS || last_instruction == CPY_ABS || last_instruction == CMP_IMM || last_instruction == CPX_IMM || last_instruction == CPY_IMM || last_instruction == EOR_ABS || last_instruction == EOR_IMM || last_instruction == LDA_ABS || last_instruction == LDA_IMM || last_instruction == LDX_ABS || last_instruction == LDX_IMM || last_instruction == LDY_ABS || last_instruction == LDY_IMM || last_instruction == ORA_ABS || last_instruction == ORA_IMM || last_instruction == PLA_IMP || last_instruction == PLP_IMP || last_instruction == SBC_ABS || last_instruction == SBC_IMM || last_instruction == LDA_ZPG || last_instruction == LDX_ZPG || last_instruction == LDY_ZPG || last_instruction == EOR_ZPG || last_instruction == AND_ZPG || last_instruction == ORA_ZPG || last_instruction == ADC_ZPG || last_instruction == SBC_ZPG || last_instruction == CMP_ZPG || last_instruction == CPX_ZPG || last_instruction == CPY_ZPG || last_instruction == BIT_ZPG || last_instruction == LDA_ZPX || last_instruction == LDX_ZPY || last_instruction == LDY_ZPX || last_instruction == EOR_ZPX || last_instruction == AND_ZPX || last_instruction == ORA_ZPX || last_instruction == ADC_ZPX || last_instruction == SBC_ZPX || last_instruction == CMP_ZPX || last_instruction == LDA_ABX || last_instruction == LDA_ABY || last_instruction == LDX_ABY || last_instruction == LDY_ABX || last_instruction == EOR_ABX || last_instruction == EOR_ABY || last_instruction == AND_ABX || last_instruction == AND_ABY || last_instruction == ORA_ABX || last_instruction == ORA_ABY || last_instruction == ADC_ABX || last_instruction == ADC_ABY || last_instruction == SBC_ABX || last_instruction == SBC_ABY || last_instruction == CMP_ABX || last_instruction == CMP_ABY || last_instruction == LDA_IDX || last_instruction == ORA_IDX || last_instruction == EOR_IDX || last_instruction == AND_IDX || last_instruction == ADC_IDX || last_instruction == CMP_IDX || last_instruction == SBC_IDX || last_instruction == LDA_IDY || last_instruction == ORA_IDY || last_instruction == EOR_IDY || last_instruction == AND_IDY || last_instruction == ADC_IDY || last_instruction == CMP_IDY || last_instruction == SBC_IDY ) : { if (alu_opcode != last_instruction) { dut_error("alu_opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("alu_enable is Wrong!"); }; if (addr != PC) { dut_error("Address is Wrong!"); }; }; --( --) : { -- if (alu_opcode != last_instruction) { -- dut_error("alu_opcode is Wrong!"); -- }; -- if (alu_enable != 1) { -- dut_error("alu_enable is Wrong!"); -- }; -- if (addr[7:0] != PCL) { -- dut_error("Address is Wrong!"); -- }; -- if (addr[12:8] != PCH[4:0]) { -- dut_error("Address is Wrong!"); -- }; --}; default : { if (alu_opcode.as_a(byte) != 0) { dut_error("alu_opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("alu_enable is Wrong!"); }; if (alu_a != 0) { dut_error("alu_a is Wrong!"); }; if (addr != PC) { dut_error("Address is Wrong!"); }; }; }; } else { rst = 0; if (alu_enable != 0) { dut_error("alu_enable is Wrong!"); }; if (alu_opcode.as_a(byte) != 0) { dut_error("alu_opcode is Wrong!"); }; if (alu_a != 0) { dut_error("alu_a is Wrong!"); }; if (addr != PC) { dut_error("Address is Wrong!"); }; }; PC = PC + 1; }; CYCLE_2 : { print_state(); print addr; if (addr != PC) { dut_error("ADDR should be equal PC!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (READ)"); }; case { ( instructions == ADC_ABS || instructions == ADC_IMM || instructions == AND_ABS || instructions == AND_IMM || instructions == ASL_ABS || instructions == BIT_ABS || instructions == BRK_IMP || instructions == CMP_ABS || instructions == CPX_ABS || instructions == CPY_ABS || instructions == CMP_IMM || instructions == CPX_IMM || instructions == CPY_IMM || instructions == DEC_ABS || instructions == EOR_ABS || instructions == EOR_IMM || instructions == INC_ABS || instructions == JMP_ABS || instructions == LDA_ABS || instructions == LDA_IMM || instructions == LDX_ABS || instructions == LDX_IMM || instructions == LDY_ABS || instructions == LDY_IMM || instructions == LSR_ABS || instructions == ORA_ABS || instructions == ORA_IMM || instructions == ROL_ABS || instructions == ROR_ABS || instructions == SBC_ABS || instructions == SBC_IMM || instructions == LDA_ZPG || instructions == LDX_ZPG || instructions == LDY_ZPG || instructions == EOR_ZPG || instructions == AND_ZPG || instructions == ORA_ZPG || instructions == ADC_ZPG || instructions == SBC_ZPG || instructions == CMP_ZPG || instructions == CPX_ZPG || instructions == CPY_ZPG || instructions == BIT_ZPG || instructions == ASL_ZPG || instructions == LSR_ZPG || instructions == ROL_ZPG || instructions == ROR_ZPG || instructions == INC_ZPG || instructions == DEC_ZPG || instructions == LDA_ZPX || instructions == LDX_ZPY || instructions == LDY_ZPX || instructions == EOR_ZPX || instructions == AND_ZPX || instructions == ORA_ZPX || instructions == ADC_ZPX || instructions == SBC_ZPX || instructions == CMP_ZPX || instructions == ASL_ZPX || instructions == LSR_ZPX || instructions == ROL_ZPX || instructions == ROR_ZPX || instructions == INC_ZPX || instructions == DEC_ZPX || instructions == STX_ZPY || instructions == STY_ZPX || instructions == STA_ZPX || instructions == LDA_ABX || instructions == LDA_ABY || instructions == STA_ABX || instructions == STA_ABY || instructions == LDX_ABY || instructions == LDY_ABX || instructions == EOR_ABX || instructions == EOR_ABY || instructions == AND_ABX || instructions == AND_ABY || instructions == ORA_ABX || instructions == ORA_ABY || instructions == ADC_ABX || instructions == ADC_ABY || instructions == SBC_ABX || instructions == SBC_ABY || instructions == CMP_ABX || instructions == CMP_ABY || instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX || instructions == LDA_IDX || instructions == STA_IDX || instructions == ORA_IDX || instructions == EOR_IDX || instructions == AND_IDX || instructions == ADC_IDX || instructions == CMP_IDX || instructions == SBC_IDX || instructions == LDA_IDY || instructions == STA_IDY || instructions == ORA_IDY || instructions == EOR_IDY || instructions == AND_IDY || instructions == ADC_IDY || instructions == CMP_IDY || instructions == SBC_IDY || instructions == JMP_IND || instructions == JSR_ABS ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; PC = PC + 1; }; -- TODO: STX and STY should not -- TODO: they dont need access to alu at any cycle -- TODO: because X and Y are available at alu_x and alu_y ( instructions == STA_ABS || instructions == STA_ZPG || instructions == STX_ABS || instructions == STY_ABS || instructions == STX_ZPG || instructions == STY_ZPG ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; PC = PC + 1; }; ( instructions == NOP_IMP || instructions == PHP_IMP || instructions == PLA_IMP || instructions == PLP_IMP || instructions == RTI_IMP || instructions == RTS_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; }; ( instructions == ASL_ACC || instructions == CLC_IMP || instructions == CLD_IMP || instructions == CLI_IMP || instructions == CLV_IMP || instructions == DEX_IMP || instructions == DEY_IMP || instructions == INX_IMP || instructions == INY_IMP || instructions == LSR_ACC || instructions == PHA_IMP || instructions == ROL_ACC || instructions == ROR_ACC || instructions == SEC_IMP || instructions == SED_IMP || instructions == SEI_IMP || instructions == TAX_IMP || instructions == TAY_IMP || instructions == TXA_IMP || instructions == TYA_IMP ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; }; //JSR_ABS : { // if (alu_opcode.as_a(byte) != 0) { // dut_error("Opcode is Wrong!"); // }; // if (mem_rw != 0) { // dut_error("MEM_RW should be 1 (WRITE)"); // }; // if (alu_enable != 0) { // dut_error("JSR_IMP is Wrong!"); // }; // if (addr != PC) { // dut_error("ADDR should be equal SP!"); // }; // PC = PC + 1; //}; ( instructions == TSX_IMP ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("TSX_IMP is Wrong!"); }; if (alu_a != SP) { dut_error("TSX_IMP is Wrong!"); }; }; ( instructions == TXS_IMP ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("TXS_IMP is Wrong!"); }; SP = SP_aux; }; }; }; CYCLE_3 : { print_state(); print addr; case { ( instructions == BRK_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (data_out[4:0] != PC[12:8] && data_out[7:5] != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; }; instructions == JSR_ABS : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("JSR_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal PC!"); }; }; -- TODO: This is probably an error STA should not use ALU on the third cycle ( instructions == STA_ZPX || instructions == STX_ZPY || instructions == STY_ZPX ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (addr != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == STA_ZPG || instructions == STX_ZPG || instructions == STY_ZPG ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (addr != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == JMP_ABS ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; PC[7:0] = PCL; PC[12:8] = PCH[4:0]; }; ( instructions == LDA_ZPX || instructions == LDX_ZPY || instructions == LDY_ZPX || instructions == EOR_ZPX || instructions == AND_ZPX || instructions == ORA_ZPX || instructions == ADC_ZPX || instructions == SBC_ZPX || instructions == CMP_ZPX || instructions == ASL_ZPX || instructions == LSR_ZPX || instructions == ROL_ZPX || instructions == ROR_ZPX || instructions == INC_ZPX || instructions == DEC_ZPX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == LDA_IDX || instructions == STA_IDX || instructions == ORA_IDX || instructions == EOR_IDX || instructions == AND_IDX || instructions == ADC_IDX || instructions == CMP_IDX || instructions == SBC_IDX || instructions == LDA_IDY || instructions == STA_IDY || instructions == ORA_IDY || instructions == EOR_IDY || instructions == AND_IDY || instructions == ADC_IDY || instructions == CMP_IDY || instructions == SBC_IDY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr != pointer) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == ADC_ABS || instructions == AND_ABS || instructions == ASL_ABS || instructions == BIT_ABS || instructions == CMP_ABS || instructions == CPX_ABS || instructions == CPY_ABS || instructions == DEC_ABS || instructions == EOR_ABS || instructions == INC_ABS || instructions == LDA_ABS || instructions == LDX_ABS || instructions == LDY_ABS || instructions == LSR_ABS || instructions == ORA_ABS || instructions == ROL_ABS || instructions == ROR_ABS || instructions == SBC_ABS || instructions == STA_ABS || instructions == STX_ABS || instructions == STY_ABS || instructions == LDA_ABX || instructions == LDY_ABX || instructions == EOR_ABX || instructions == AND_ABX || instructions == ORA_ABX || instructions == ADC_ABX || instructions == SBC_ABX || instructions == CMP_ABX || instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (addr != PC) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; PC = PC + 1; if (PCL + X > 255) { more_cycles = TRUE; }; }; ( instructions == LDA_ABY || instructions == LDX_ABY || instructions == AND_ABY || instructions == EOR_ABY || instructions == ORA_ABY || instructions == ADC_ABY || instructions == SBC_ABY || instructions == CMP_ABY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (addr != PC) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; PC = PC + 1; if (PCL + Y > 255) { more_cycles = TRUE; }; }; ( instructions == STA_ABX || instructions == STA_ABY || instructions == JMP_IND ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (addr != PC) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; PC = PC + 1; }; ( instructions == LDA_ZPG || instructions == LDX_ZPG || instructions == LDY_ZPG || instructions == EOR_ZPG || instructions == AND_ZPG || instructions == ORA_ZPG || instructions == ADC_ZPG || instructions == SBC_ZPG || instructions == CMP_ZPG || instructions == CPX_ZPG || instructions == CPY_ZPG || instructions == BIT_ZPG || instructions == ASL_ZPG || instructions == LSR_ZPG || instructions == ROL_ZPG || instructions == ROR_ZPG || instructions == INC_ZPG || instructions == DEC_ZPG ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (addr != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == PHA_IMP || instructions == PHP_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_a != 0) { dut_error("PHP_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; if (alu_enable != 0) { dut_error("PHP_IMP is Wrong!"); }; }; ( instructions == PLA_IMP || instructions == PLP_IMP || instructions == RTI_IMP || instructions == RTS_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("PLA_IMP is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (READ)"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP + 1; }; }; }; CYCLE_4 : { print_state(); print addr; case { ( instructions == BRK_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (data_out != PC[7:0]) { dut_error("BRK_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; }; instructions == JSR_ABS : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("JSR_ABS is Wrong!"); }; if (data_out[4:0] != PC[12:8]) { dut_error("JSR_ABS is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; }; ( instructions == STA_ABX ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == STA_ABY ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (PCL + Y > 255) { if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR should be equal SP!"); }; }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == LDA_ZPX || instructions == LDY_ZPX || instructions == EOR_ZPX || instructions == AND_ZPX || instructions == ORA_ZPX || instructions == ADC_ZPX || instructions == SBC_ZPX || instructions == CMP_ZPX || instructions == ASL_ZPX || instructions == LSR_ZPX || instructions == ROL_ZPX || instructions == ROR_ZPX || instructions == INC_ZPX || instructions == DEC_ZPX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; --TODO: Isn`t it suppose to have ADDRH == 0???? if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == LDA_ABX || instructions == LDY_ABX || instructions == EOR_ABX || instructions == AND_ABX || instructions == ORA_ABX || instructions == ADC_ABX || instructions == SBC_ABX || instructions == CMP_ABX || instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + X > 255) { more_cycles = TRUE; if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == LDA_IDX || instructions == STA_IDX || instructions == ORA_IDX || instructions == EOR_IDX || instructions == AND_IDX || instructions == ADC_IDX || instructions == CMP_IDX || instructions == SBC_IDX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (pointer + X > 255) { if (addr[7:0] != pointer + X - 256) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != pointer + X) { dut_error("ADDR is wrong"); }; }; }; ( instructions == LDA_IDY || instructions == STA_IDY || instructions == ORA_IDY || instructions == EOR_IDY || instructions == AND_IDY || instructions == ADC_IDY || instructions == CMP_IDY || instructions == SBC_IDY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr != pointer + 1) { dut_error("ADDR should be equal SP!"); }; if (PCL + Y > 255) { more_cycles = TRUE; }; }; ( instructions == JMP_IND ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != pointer) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != pointer_h[4:0]) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == LDX_ZPY || instructions == LDA_ABY || instructions == LDX_ABY || instructions == EOR_ABY || instructions == AND_ABY || instructions == ORA_ABY || instructions == ADC_ABY || instructions == SBC_ABY || instructions == CMP_ABY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + Y > 255) { more_cycles = TRUE; if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == ADC_ABS || instructions == AND_ABS || instructions == ASL_ABS || instructions == BIT_ABS || instructions == CMP_ABS || instructions == CPX_ABS || instructions == CPY_ABS || instructions == DEC_ABS || instructions == EOR_ABS || instructions == INC_ABS || instructions == LDA_ABS || instructions == LDX_ABS || instructions == LDY_ABS || instructions == LSR_ABS || instructions == ORA_ABS || instructions == ROL_ABS || instructions == ROR_ABS || instructions == SBC_ABS ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == STA_ABS || instructions == STX_ABS || instructions == STY_ABS ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == ASL_ZPG || instructions == LSR_ZPG || instructions == ROL_ZPG || instructions == ROR_ZPG || instructions == INC_ZPG || instructions == DEC_ZPG ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 1) { dut_error("BRK_IMP is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == STA_ZPX || instructions == STY_ZPX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == STX_ZPY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (PCL + Y > 255) { if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == PLA_IMP || instructions == PLP_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (READ)"); }; if (alu_enable != 0) { dut_error("PLP_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == RTI_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("RTI_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP + 1; }; ( instructions == RTS_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("RTS_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP + 1; PC[7:0] = PCL; }; }; }; CYCLE_5 : { print_state(); print addr; case { ( instructions == BRK_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; }; ( instructions == JMP_IND ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (pointer + 1 > 255) { if (addr[7:0] != pointer + 1 - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != pointer + 1) { dut_error("ADDR should be equal SP!"); }; }; -- TODO: This is the correct behaviour expected from spec --if (addr[12:8] != pointer_h[4:0]) { -- print addr[7:0], pointer; -- print addr[12:8], pointer_h[4:0]; -- dut_error("ADDR should be equal SP!"); --}; PC[7:0] = PCL; PC[12:8] = PCH[4:0]; }; instructions == JSR_ABS : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("JSR_ABS is Wrong!"); }; if (data_out != PC[7:0]) { dut_error("JSR_ABS is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP - 1; }; ( instructions == LDA_IDX || instructions == ORA_IDX || instructions == EOR_IDX || instructions == AND_IDX || instructions == ADC_IDX || instructions == CMP_IDX || instructions == SBC_IDX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (pointer + X + 1 > 255) { if (addr[7:0] != pointer + X + 1 - 256) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != pointer + X + 1) { dut_error("ADDR is wrong"); }; }; if (addr[12:8] != 0) { print addr[12:8], PCH[4:0]; dut_error("ADDR is wrong"); }; }; ( instructions == LDA_IDY || //instructions == STA_IDY || instructions == ORA_IDY || instructions == EOR_IDY || instructions == AND_IDY || instructions == ADC_IDY || instructions == CMP_IDY || instructions == SBC_IDY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + Y > 255) { if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR is wrong"); }; }; -- TODO: This is the expected behavior (took from spec) -- addr[12:8] is 0 or 1 acording to PCL + Y > 255 --if (addr[12:8] != PCH[4:0]) { -- print addr[12:8], PCH[4:0]; -- dut_error("ADDR is wrong"); --}; }; ( instructions == STA_IDX ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (pointer + X + 1 > 255) { if (addr[7:0] != pointer + X + 1 - 256) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != pointer + X + 1) { dut_error("ADDR is wrong"); }; }; }; ( instructions == STA_IDY ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (pointer + Y > 255) { if (addr[7:0] != pointer + Y - 256) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != pointer + Y) { dut_error("ADDR is wrong"); }; }; }; ( instructions == STA_ABX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH + 1) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == STA_ABY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (PCL + Y > 255) { if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH + 1) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; }; ( instructions == RTI_IMP ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 1) { dut_error("RTI_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; SP = SP + 1; PC[7:0] = PCL; }; ( instructions == RTS_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("SEI_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; PC[12:8] = PCH[4:0]; }; ( instructions == ASL_ZPG || instructions == LSR_ZPG || instructions == ROL_ZPG || instructions == ROR_ZPG || instructions == INC_ZPG || instructions == DEC_ZPG ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == LDA_ABX || instructions == LDY_ABX || instructions == EOR_ABX || instructions == AND_ABX || instructions == ORA_ABX || instructions == ADC_ABX || instructions == SBC_ABX || instructions == CMP_ABX || ( more_cycles == TRUE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X - 256) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0] + 1) { dut_error("ADDR is wrong!"); }; }; ( more_cycles == FALSE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; ( instructions == LDX_ZPY || instructions == LDA_ABY || instructions == LDX_ABY || instructions == EOR_ABY || instructions == AND_ABY || instructions == ORA_ABY || instructions == ADC_ABY || instructions == SBC_ABY || instructions == CMP_ABY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0] + 1) { dut_error("ADDR is wrong!"); }; }; ( instructions == ASL_ZPX || instructions == LSR_ZPX || instructions == ROL_ZPX || instructions == ROR_ZPX || instructions == INC_ZPX || instructions == DEC_ZPX ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; }; ( instructions == ASL_ABS || instructions == DEC_ABS || instructions == INC_ABS || instructions == LSR_ABS || instructions == ROL_ABS || instructions == ROR_ABS ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 1) { dut_error("BRK_IMP is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; }; }; }; CYCLE_6 : { print_state(); print addr; case { ( instructions == BRK_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr != 13'b1111111111110) { dut_error("BRK_IMP is Wrong!"); }; PC[7:0] = PCL; }; instructions == JSR_ABS : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("JSR_ABS is Wrong!"); }; if (addr != PC) { dut_error("ADDR should be equal SP!"); }; PC [7:0] = PCL; PC[12:8] = PCH[4:0]; }; ( instructions == LDA_IDX || instructions == ORA_IDX || instructions == EOR_IDX || instructions == AND_IDX || instructions == ADC_IDX || instructions == CMP_IDX || instructions == SBC_IDX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL) { dut_error("ADDR is wrong"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR is wrong"); }; }; ( instructions == LDA_IDY || --instructions == STA_IDY || instructions == ORA_IDY || instructions == EOR_IDY || instructions == AND_IDY || instructions == ADC_IDY || instructions == CMP_IDY || instructions == SBC_IDY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR is wrong"); }; if (addr[12:8] != PCH[4:0] + 1) { print PCH, addr[12:8]; print PCL + Y, addr[7:0]; dut_error("ADDR is wrong"); }; }; ( instructions == STA_IDY ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + Y > 255) { if (addr[7:0] != PCL + Y - 256) { dut_error("ADDR is wrong"); }; if (addr[12:8] != PCH[4:0] + 1) { dut_error("ADDR is wrong"); }; } else { if (addr[7:0] != PCL + Y) { dut_error("ADDR is wrong"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR is wrong"); }; }; }; ( instructions == STA_IDX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL) { dut_error("ADDR is wrong"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR is wrong"); }; }; ( instructions == RTI_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("RTI_IMP is Wrong!"); }; if (addr != SP + 256) { dut_error("ADDR should be equal SP!"); }; PC[12:8] = PCH[4:0]; }; ( instructions == RTS_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("RTI_IMP is Wrong!"); }; if (addr != PC) { dut_error("ADDR should be equal SP!"); }; PC = PC + 1; }; ( instructions == ASL_ZPX || instructions == LSR_ZPX || instructions == ROL_ZPX || instructions == ROR_ZPX || instructions == INC_ZPX || instructions == DEC_ZPX ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (PCL + X > 255) { if (addr[7:0] != PCL + X - 256) { dut_error("ADDR should be equal SP!"); }; } else { if (addr[7:0] != PCL + X) { dut_error("ADDR should be equal SP!"); }; }; }; ( more_cycles == TRUE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X - 256) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0] + 1) { dut_error("ADDR is wrong!"); }; }; ( more_cycles == FALSE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) : { if (alu_opcode != instructions) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 1) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR is wrong!"); }; }; ( instructions == ASL_ABS || instructions == DEC_ABS || instructions == INC_ABS || instructions == LSR_ABS || instructions == ROL_ABS || instructions == ROR_ABS ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr[7:0] != PCL) { dut_error("ADDR should be equal SP!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR should be equal SP!"); }; }; }; }; CYCLE_7 : { print_state(); print addr; case { ( more_cycles == TRUE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X - 256) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0] + 1) { dut_error("ADDR is wrong!"); }; }; ( more_cycles == FALSE && ( instructions == ASL_ABX || instructions == LSR_ABX || instructions == ROL_ABX || instructions == ROR_ABX || instructions == INC_ABX || instructions == DEC_ABX ) ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (alu_enable != 0) { dut_error("ASL_ACC is Wrong!"); }; if (mem_rw != 1) { dut_error("MEM_RW should be 0 (WRITE)"); }; if (addr[7:0] != PCL + X) { dut_error("ADDR is wrong!"); }; if (addr[12:8] != PCH[4:0]) { dut_error("ADDR is wrong!"); }; }; ( instructions == BRK_IMP ) : { if (alu_opcode.as_a(byte) != 0) { dut_error("Opcode is Wrong!"); }; if (mem_rw != 0) { dut_error("MEM_RW should be 1 (WRITE)"); }; if (alu_enable != 0) { dut_error("BRK_IMP is Wrong!"); }; if (addr != 13'b1111111111111) { dut_error("BRK_IMP is Wrong!"); }; PC[12:8] = PCH[4:0]; }; }; }; }; old_state = new_state; }; }; '>
Go to most recent revision | Compare with Previous | Blame | View Log