OpenCores
URL https://opencores.org/ocsvn/t6507lp/t6507lp/trunk

Subversion Repositories t6507lp

[/] [t6507lp/] [trunk/] [fv/] [fsm_chk.e] - Diff between revs 241 and 247

Go to most recent revision | Show entire file | Details | Blame | View Log

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

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.