mirror of
https://github.com/sxpert/hp-saturn
synced 2025-01-20 10:26:31 +01:00
moved main registers to arrays, makes things much simpler and better, it seems
This commit is contained in:
parent
01429b4493
commit
0a45b014d7
3 changed files with 114 additions and 55 deletions
|
@ -38,3 +38,6 @@ second delay is posedge $glbnet$clk -> <async>
|
||||||
2019-02-17 15:11 1677 70.29MHz 34.92ns 13.01ns 11788 74.69MHz 17.42ns 3.88ns
|
2019-02-17 15:11 1677 70.29MHz 34.92ns 13.01ns 11788 74.69MHz 17.42ns 3.88ns
|
||||||
2019-02-17 19:30 1637 74.68MHz 34.80ns 12.77ns 11687 68.49Mhz 18.03ns 4.01ns
|
2019-02-17 19:30 1637 74.68MHz 34.80ns 12.77ns 11687 68.49Mhz 18.03ns 4.01ns
|
||||||
2019-02-17 20:25 1733 72.37MHz 32.87ns 12.77ns 12213 73.52MHz 16.22ns 3.87ns
|
2019-02-17 20:25 1733 72.37MHz 32.87ns 12.77ns 12213 73.52MHz 16.22ns 3.87ns
|
||||||
|
2019-02-17 21:21 1734 71.16MHz 32.10ns 12.05ns 11359 73.56MHz 17.19ns 3.73ns
|
||||||
|
2019-02-17 22:31 1573 77.32MHz 32.91ns 12.77ns 10265 70.53MHz 17.35ns 4.13ns
|
||||||
|
2019-02-17 22:48 1067 69.94MHz 32.87ns 12.77ns 6427 74.33MHz 17.71ns 3.96ns
|
||||||
|
|
164
saturn_alu.v
164
saturn_alu.v
|
@ -171,16 +171,17 @@ reg [19:0] PC;
|
||||||
reg [19:0] D0;
|
reg [19:0] D0;
|
||||||
reg [19:0] D1;
|
reg [19:0] D1;
|
||||||
|
|
||||||
reg [63:0] A;
|
//reg [63:0] A;
|
||||||
reg [63:0] B;
|
reg [3:0] A[0:15];
|
||||||
reg [63:0] C;
|
reg [3:0] B[0:15];
|
||||||
reg [63:0] D;
|
reg [3:0] C[0:15];
|
||||||
|
reg [3:0] D[0:15];
|
||||||
|
|
||||||
reg [63:0] R0;
|
reg [3:0] R0[0:15];
|
||||||
reg [63:0] R1;
|
reg [3:0] R1[0:15];
|
||||||
reg [63:0] R2;
|
reg [3:0] R2[0:15];
|
||||||
reg [63:0] R3;
|
reg [3:0] R3[0:15];
|
||||||
reg [63:0] R4;
|
reg [3:0] R4[0:15];
|
||||||
|
|
||||||
reg [0:0] CARRY;
|
reg [0:0] CARRY;
|
||||||
reg [0:0] DEC;
|
reg [0:0] DEC;
|
||||||
|
@ -320,6 +321,10 @@ assign is_alu_op_test = ((alu_op == `ALU_OP_TEST_EQ) ||
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
`ifdef SIM
|
||||||
|
reg [4:0] alu_dbg_ctr;
|
||||||
|
`endif
|
||||||
|
|
||||||
always @(posedge i_clk) begin
|
always @(posedge i_clk) begin
|
||||||
|
|
||||||
`ifdef SIM
|
`ifdef SIM
|
||||||
|
@ -345,12 +350,43 @@ always @(posedge i_clk) begin
|
||||||
PC, CARRY, DEC?"DEC":"HEX", rstk_ptr, RSTK[7]);
|
PC, CARRY, DEC?"DEC":"HEX", rstk_ptr, RSTK[7]);
|
||||||
$display("P: %h HST: %b ST: %b RSTK6: %5h",
|
$display("P: %h HST: %b ST: %b RSTK6: %5h",
|
||||||
P, HST, ST, RSTK[6]);
|
P, HST, ST, RSTK[6]);
|
||||||
$display("A: %h R0: %h RSTK5: %5h", A, R0, RSTK[5]);
|
|
||||||
$display("B: %h R1: %h RSTK4: %5h", B, R1, RSTK[4]);
|
$write("A: ");
|
||||||
$display("C: %h R2: %h RSTK3: %5h", C, R2, RSTK[3]);
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
$display("D: %h R3: %h RSTK2: %5h", D, R3, RSTK[2]);
|
$write("%h", A[alu_dbg_ctr]);
|
||||||
$display("D0: %h D1: %h R4: %h RSTK1: %5h",
|
$write(" R0: ");
|
||||||
D0, D1, R4, RSTK[1]);
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", R0[alu_dbg_ctr]);
|
||||||
|
$write(" RSTK5: %5h\n", RSTK[5]);
|
||||||
|
|
||||||
|
$write("B: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", B[alu_dbg_ctr]);
|
||||||
|
$write(" R1: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", R1[alu_dbg_ctr]);
|
||||||
|
$write(" RSTK4: %5h\n", RSTK[4]);
|
||||||
|
|
||||||
|
$write("C: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", C[alu_dbg_ctr]);
|
||||||
|
$write(" R2: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", R2[alu_dbg_ctr]);
|
||||||
|
$write(" RSTK3: %5h\n", RSTK[3]);
|
||||||
|
|
||||||
|
$write("D: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", D[alu_dbg_ctr]);
|
||||||
|
$write(" R3: ");
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", R3[alu_dbg_ctr]);
|
||||||
|
$write(" RSTK2: %5h\n", RSTK[2]);
|
||||||
|
|
||||||
|
$write("D0: %h D1: %h R4: ", D0, D1);
|
||||||
|
for(alu_dbg_ctr=15;alu_dbg_ctr!=31;alu_dbg_ctr=alu_dbg_ctr-1)
|
||||||
|
$write("%h", R4[alu_dbg_ctr]);
|
||||||
|
$write(" RSTK1: %5h\n", RSTK[1]);
|
||||||
$display(" ADDR: %5h RSTK0: %5h",
|
$display(" ADDR: %5h RSTK0: %5h",
|
||||||
o_bus_address, RSTK[0]);
|
o_bus_address, RSTK[0]);
|
||||||
end
|
end
|
||||||
|
@ -457,33 +493,38 @@ always @(posedge i_clk) begin
|
||||||
* source 1
|
* source 1
|
||||||
*/
|
*/
|
||||||
case (alu_op)
|
case (alu_op)
|
||||||
`ALU_OP_ZERO: begin end // no source required
|
`ALU_OP_ZERO: begin end // no source required
|
||||||
`ALU_OP_COPY,
|
`ALU_OP_COPY,
|
||||||
`ALU_OP_EXCH,
|
`ALU_OP_EXCH,
|
||||||
`ALU_OP_RST_BIT,
|
`ALU_OP_RST_BIT,
|
||||||
`ALU_OP_SET_BIT,
|
`ALU_OP_SET_BIT,
|
||||||
`ALU_OP_2CMPL,
|
`ALU_OP_2CMPL,
|
||||||
`ALU_OP_ADD,
|
`ALU_OP_ADD,
|
||||||
`ALU_OP_TEST_EQ,
|
`ALU_OP_TEST_EQ,
|
||||||
`ALU_OP_TEST_NEQ,
|
`ALU_OP_TEST_NEQ,
|
||||||
`ALU_OP_JMP_REL3,
|
`ALU_OP_JMP_REL3,
|
||||||
`ALU_OP_JMP_REL4,
|
`ALU_OP_JMP_REL4,
|
||||||
`ALU_OP_JMP_ABS5,
|
`ALU_OP_JMP_ABS5,
|
||||||
`ALU_OP_CLR_MASK:
|
`ALU_OP_CLR_MASK:
|
||||||
case (reg_src1)
|
case (reg_src1)
|
||||||
`ALU_REG_A: p_src1 <= A [f_cur*4+:4];
|
`ALU_REG_A: p_src1 <= A[f_cur];
|
||||||
`ALU_REG_B: p_src1 <= B [f_cur*4+:4];
|
`ALU_REG_B: p_src1 <= B[f_cur];
|
||||||
`ALU_REG_C: p_src1 <= C [f_cur*4+:4];
|
`ALU_REG_C: p_src1 <= C[f_cur];
|
||||||
`ALU_REG_D: p_src1 <= D [f_cur*4+:4];
|
`ALU_REG_D: p_src1 <= D[f_cur];
|
||||||
`ALU_REG_D0: p_src1 <= D0[f_cur*4+:4];
|
`ALU_REG_R0: p_src1 <= R0[f_cur];
|
||||||
`ALU_REG_D1: p_src1 <= D1[f_cur*4+:4];
|
`ALU_REG_R1: p_src1 <= R1[f_cur];
|
||||||
`ALU_REG_P: p_src1 <= P;
|
`ALU_REG_R2: p_src1 <= R2[f_cur];
|
||||||
`ALU_REG_HST: p_src1 <= HST;
|
`ALU_REG_R3: p_src1 <= R3[f_cur];
|
||||||
`ALU_REG_IMM: p_src1 <= i_imm_value;
|
`ALU_REG_R4: p_src1 <= R4[f_cur];
|
||||||
`ALU_REG_ZERO: p_src1 <= 0;
|
`ALU_REG_D0: p_src1 <= D0[f_cur*4+:4];
|
||||||
default: $display("#### SRC_1 UNHANDLED REGISTER %0d", reg_src1);
|
`ALU_REG_D1: p_src1 <= D1[f_cur*4+:4];
|
||||||
endcase
|
`ALU_REG_P: p_src1 <= P;
|
||||||
default: $display("#### SRC_1 UNHANDLED OPERATION %0d", alu_op);
|
`ALU_REG_HST: p_src1 <= HST;
|
||||||
|
`ALU_REG_IMM: p_src1 <= i_imm_value;
|
||||||
|
`ALU_REG_ZERO: p_src1 <= 0;
|
||||||
|
default: $display("#### SRC_1 UNHANDLED REGISTER %0d", reg_src1);
|
||||||
|
endcase
|
||||||
|
default: $display("#### SRC_1 UNHANDLED OPERATION %0d", alu_op);
|
||||||
endcase
|
endcase
|
||||||
|
|
||||||
|
|
||||||
|
@ -505,10 +546,15 @@ always @(posedge i_clk) begin
|
||||||
`ALU_OP_TEST_NEQ,
|
`ALU_OP_TEST_NEQ,
|
||||||
`ALU_OP_CLR_MASK: begin
|
`ALU_OP_CLR_MASK: begin
|
||||||
case (reg_src2)
|
case (reg_src2)
|
||||||
`ALU_REG_A: p_src2 <= A [f_cur*4+:4];
|
`ALU_REG_A: p_src2 <= A[f_cur];
|
||||||
`ALU_REG_B: p_src2 <= B [f_cur*4+:4];
|
`ALU_REG_B: p_src2 <= B[f_cur];
|
||||||
`ALU_REG_C: p_src2 <= C [f_cur*4+:4];
|
`ALU_REG_C: p_src2 <= C[f_cur];
|
||||||
`ALU_REG_D: p_src2 <= D [f_cur*4+:4];
|
`ALU_REG_D: p_src2 <= D[f_cur];
|
||||||
|
`ALU_REG_R0: p_src2 <= R0[f_cur];
|
||||||
|
`ALU_REG_R1: p_src2 <= R1[f_cur];
|
||||||
|
`ALU_REG_R2: p_src2 <= R2[f_cur];
|
||||||
|
`ALU_REG_R3: p_src2 <= R3[f_cur];
|
||||||
|
`ALU_REG_R4: p_src2 <= R4[f_cur];
|
||||||
`ALU_REG_D0: p_src2 <= D0[f_cur*4+:4];
|
`ALU_REG_D0: p_src2 <= D0[f_cur*4+:4];
|
||||||
`ALU_REG_D1: p_src2 <= D1[f_cur*4+:4];
|
`ALU_REG_D1: p_src2 <= D1[f_cur*4+:4];
|
||||||
`ALU_REG_P: p_src2 <= P;
|
`ALU_REG_P: p_src2 <= P;
|
||||||
|
@ -653,10 +699,15 @@ always @(posedge i_clk) begin
|
||||||
`ALU_OP_ADD,
|
`ALU_OP_ADD,
|
||||||
`ALU_OP_CLR_MASK:
|
`ALU_OP_CLR_MASK:
|
||||||
case (reg_dest)
|
case (reg_dest)
|
||||||
`ALU_REG_A: A[f_cur*4+:4] <= c_res1;
|
`ALU_REG_A: A[f_cur] <= c_res1;
|
||||||
`ALU_REG_B: B[f_cur*4+:4] <= c_res1;
|
`ALU_REG_B: B[f_cur] <= c_res1;
|
||||||
`ALU_REG_C: C[f_cur*4+:4] <= c_res1;
|
`ALU_REG_C: C[f_cur] <= c_res1;
|
||||||
`ALU_REG_D: D[f_cur*4+:4] <= c_res1;
|
`ALU_REG_D: D[f_cur] <= c_res1;
|
||||||
|
`ALU_REG_R0: R0[f_cur] <= c_res1;
|
||||||
|
`ALU_REG_R1: R1[f_cur] <= c_res1;
|
||||||
|
`ALU_REG_R2: R2[f_cur] <= c_res1;
|
||||||
|
`ALU_REG_R3: R3[f_cur] <= c_res1;
|
||||||
|
`ALU_REG_R4: R4[f_cur] <= c_res1;
|
||||||
`ALU_REG_D0: D0[f_cur*4+:4] <= c_res1;
|
`ALU_REG_D0: D0[f_cur*4+:4] <= c_res1;
|
||||||
`ALU_REG_D1: D1[f_cur*4+:4] <= c_res1;
|
`ALU_REG_D1: D1[f_cur*4+:4] <= c_res1;
|
||||||
`ALU_REG_ST: ST[f_cur*4+:4] <= c_res1;
|
`ALU_REG_ST: ST[f_cur*4+:4] <= c_res1;
|
||||||
|
@ -687,10 +738,15 @@ always @(posedge i_clk) begin
|
||||||
case (alu_op)
|
case (alu_op)
|
||||||
`ALU_OP_EXCH: // 2nd assign, with src2
|
`ALU_OP_EXCH: // 2nd assign, with src2
|
||||||
case (reg_src2)
|
case (reg_src2)
|
||||||
`ALU_REG_A: A[f_cur*4+:4] <= c_res2;
|
`ALU_REG_A: A[f_cur] <= c_res2;
|
||||||
`ALU_REG_B: B[f_cur*4+:4] <= c_res2;
|
`ALU_REG_B: B[f_cur] <= c_res2;
|
||||||
`ALU_REG_C: C[f_cur*4+:4] <= c_res2;
|
`ALU_REG_C: C[f_cur] <= c_res2;
|
||||||
`ALU_REG_D: D[f_cur*4+:4] <= c_res2;
|
`ALU_REG_D: D[f_cur] <= c_res2;
|
||||||
|
`ALU_REG_R0: R0[f_cur] <= c_res2;
|
||||||
|
`ALU_REG_R1: R1[f_cur] <= c_res2;
|
||||||
|
`ALU_REG_R2: R2[f_cur] <= c_res2;
|
||||||
|
`ALU_REG_R3: R3[f_cur] <= c_res2;
|
||||||
|
`ALU_REG_R4: R4[f_cur] <= c_res2;
|
||||||
// `ALU_REG_D0: D0[f_start*4+:4] <= c_res2;
|
// `ALU_REG_D0: D0[f_start*4+:4] <= c_res2;
|
||||||
// `ALU_REG_D1: D1[f_start*4+:4] <= c_res2;
|
// `ALU_REG_D1: D1[f_start*4+:4] <= c_res2;
|
||||||
// `ALU_REG_ST: ST[f_start*4+:4] <= c_res2;
|
// `ALU_REG_ST: ST[f_start*4+:4] <= c_res2;
|
||||||
|
|
|
@ -235,7 +235,7 @@ always @(posedge i_clk) begin
|
||||||
o_bus_data <= `BUSCMD_DP_WRITE;
|
o_bus_data <= `BUSCMD_DP_WRITE;
|
||||||
last_cmd <= `BUSCMD_DP_WRITE;
|
last_cmd <= `BUSCMD_DP_WRITE;
|
||||||
cmd_dp_write_s <= 1;
|
cmd_dp_write_s <= 1;
|
||||||
o_bus_strobe <= 1;
|
o_bus_strobe <= 1;
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue