Line 6... |
Line 6... |
reg_a : byte;
|
reg_a : byte;
|
reg_x : byte;
|
reg_x : byte;
|
reg_y : byte;
|
reg_y : byte;
|
reg_status : byte;
|
reg_status : byte;
|
|
|
|
inst : alu_input_s;
|
|
next_inst : alu_input_s;
|
|
|
count_cycles : int;
|
count_cycles : int;
|
first_cycle : bool;
|
first_cycle : bool;
|
|
|
keep first_cycle == TRUE;
|
keep first_cycle == TRUE;
|
keep count_cycles == 0;
|
keep count_cycles == 0;
|
|
|
store(input : alu_input_s) is {
|
store(input : alu_input_s) is {
|
out ("input stored: ", input);
|
out ("cycle ", count_cycles, ": input stored: ");
|
|
print input;
|
|
|
|
if (first_cycle) {
|
|
inst = input;
|
|
next_inst = input;
|
|
}
|
|
else {
|
|
inst = next_inst;
|
|
next_inst = input;
|
|
};
|
|
|
|
count_cycles = count_cycles + 1;
|
|
|
|
if (count_cycles == 10000) {
|
|
dut_error();
|
|
}
|
};
|
};
|
|
|
compare(alu_result:byte, alu_status:byte, alu_x:byte, alu_y:byte ) is {
|
compare(alu_result:byte, alu_status:byte, alu_x:byte, alu_y:byte ) is {
|
if (first_cycle) {
|
if (first_cycle) {
|
first_cycle = FALSE;
|
first_cycle = FALSE;
|
reg_x = alu_x;
|
reg_x = alu_x;
|
reg_y = alu_y;
|
reg_y = alu_y;
|
reg_status = alu_status;
|
reg_status = alu_status;
|
reg_a = ???? // TODO
|
reg_a = 0; // TODO: check this
|
|
}
|
|
else {
|
|
case inst.input_kind {
|
|
ENABLED_VALID: {
|
|
out("cycle ", count_cycles, ": executing and comparing");
|
|
execute();
|
|
};
|
|
DISABLED_VALID: {
|
|
out("cycle ", count_cycles, ": just comparing");
|
|
};
|
|
default: {
|
|
dut_error("error at e code");
|
|
};
|
|
};
|
|
|
|
// here comes the compare!
|
|
}
|
|
};
|
|
|
|
execute() is {
|
|
case inst.alu_opcode {
|
|
ADC_IMM: { exec_sum(); }; // A,Z,C,N = A+M+C
|
|
ADC_ZPG: { exec_sum(); };
|
|
ADC_ZPX: { exec_sum(); };
|
|
ADC_ABS: { exec_sum(); };
|
|
ADC_ABX: { exec_sum(); };
|
|
ADC_ABY: { exec_sum(); };
|
|
ADC_IDX: { exec_sum(); };
|
|
ADC_IDY: { exec_sum(); };
|
|
|
|
AND_IMM: { exec_and(); };
|
|
AND_ZPG: { exec_and(); };
|
|
AND_ZPX: { exec_and(); };
|
|
AND_ABS: { exec_and(); };
|
|
AND_ABX: { exec_and(); };
|
|
AND_ABY: { exec_and(); };
|
|
AND_IDX: { exec_and(); };
|
|
AND_IDY: { exec_and(); };
|
|
|
|
|
|
default: {
|
|
//dut_error("unknown opcode");
|
|
}
|
|
};
|
|
};
|
|
|
|
exec_and() is {
|
|
|
|
|
|
};
|
|
|
|
exec_sum() is {
|
|
update_c(reg_a, inst.alu_a);
|
|
reg_a = reg_a + inst.alu_a;
|
|
update_z(reg_a);
|
|
update_n(reg_a);
|
|
|
|
print me;
|
|
|
|
dut_error();
|
|
};
|
|
|
|
update_z(arg : byte) is {
|
|
if (arg == 0) {
|
|
reg_status[1:1] = 1;
|
|
}
|
|
else {
|
|
reg_status[1:1] = 0;
|
|
}
|
|
};
|
|
|
|
update_c(arg1 : byte, arg2 : byte) is {
|
|
if (arg1 + arg2 > 256) {
|
|
reg_status[0:0] = 1;
|
|
}
|
|
else {
|
|
reg_status[0:0] = 0;
|
|
}
|
|
};
|
|
|
|
update_n(arg : byte) is {
|
|
if (arg[7:7] == 1) {
|
|
reg_status[7:7] = 1;
|
|
}
|
|
else {
|
|
reg_status[7:7] = 0;
|
}
|
}
|
};
|
};
|
};
|
};
|
'>
|
'>
|
|
|
No newline at end of file
|
No newline at end of file
|