diff --git a/rtl/alu.v b/rtl/alu.v index b159d3e..5c47920 100644 --- a/rtl/alu.v +++ b/rtl/alu.v @@ -1,18 +1,18 @@ -module alu (input [31:0] input_a, input_b, - input [3:0] op_code, +module alu (input [31:0] in_a, in_b, + input [3:0] op_code, output reg [31:0] out); always@ (*) begin case (op_code) - 4'b0000 : out <= input_a + input_b; - 4'b0001 : out <= input_a - input_b; - 4'b0010 : out <= input_a << input_b; - 4'b0011 : out <= (input_a < input_b) ? 1 : 0; - 4'b0100 : out <= input_a ^ input_b; - 4'b0101 : out <= input_a >> input_b; - 4'b0111 : out <= input_a >>> input_b; - 4'b1000 : out <= input_a | input_b; - 4'b1001 : out <= input_a & input_b; + 4'b0000 : out <= in_a + in_b; + 4'b0001 : out <= in_a - in_b; + 4'b0010 : out <= in_a << in_b; + 4'b0011 : out <= (in_a < in_b) ? 1 : 0; + 4'b0100 : out <= in_a ^ in_b; + 4'b0101 : out <= in_a >> in_b; + 4'b0111 : out <= in_a >>> in_b; + 4'b1000 : out <= in_a | in_b; + 4'b1001 : out <= in_a & in_b; default : out <= 32'b0; endcase end diff --git a/rtl/instruction.v b/rtl/instruction.v index 8ac4e87..3968c54 100644 --- a/rtl/instruction.v +++ b/rtl/instruction.v @@ -1,5 +1,5 @@ -module instruction (input [31:0] address, - output [31:0] instruction); +module instruction (input [31:0] address, + output [31:0] instruction); reg [31:0] memory [63:0]; @@ -30,20 +30,3 @@ module instruction (input [31:0] address, assign instruction = memory[address]; endmodule - -// -- result(1) := "00000000001100110000010000010000"; - -// -- "000000000000_00000_000_00110_0010000" -// result(0) := "00000000000100000000001100010000"; -// -- "000000000001_00000_000_00111_0010000" -// result(1) := "00000000000000000000001110010000"; - -// -- "000000000000_00110_000_01000_0010000" -// result(2) := "00000000000000110000010000010000"; -// -- "0000000_00111_00110_000_00110_0110000" -// result(3) := "00000000011100110000001100110000"; -// -- "000000000000_01000_000_00111_0010000" -// result(4) := "00000000000001000000001110010000"; - -// -- 111111111111_11111_110_00111_1101100 -// result(5) := "11111111111111111101001111101100"; \ No newline at end of file diff --git a/rtl/memory.v b/rtl/memory.v index 0c6f8e7..d2bd7a2 100644 --- a/rtl/memory.v +++ b/rtl/memory.v @@ -1,8 +1,8 @@ -module memory (input clock, reset, - input we, - input [31:0] address, - input [31:0] data_in, - output [31:0] data_out); +module memory (input clock, reset, + input we, + input [31:0] address, + input [31:0] data_in, + output [31:0] data_out); reg [63:0] memory [31:0]; diff --git a/rtl/mux2_1.v b/rtl/mux2_1.v index 267a48e..ed650c8 100644 --- a/rtl/mux2_1.v +++ b/rtl/mux2_1.v @@ -1,8 +1,8 @@ module mux2_1 #(parameter BUS_SIZE = 32) - (input [BUS_SIZE - 1:0] A, B, - input S, - output [BUS_SIZE - 1:0] O); + (input [BUS_SIZE - 1:0] in_1, in_2, + input sel, + output [BUS_SIZE - 1:0] out); - assign O = S ? B : A; + assign out = sel ? in_2 : in_1; endmodule \ No newline at end of file diff --git a/rtl/mux4_1.v b/rtl/mux4_1.v index 8c6b3c0..8e31303 100644 --- a/rtl/mux4_1.v +++ b/rtl/mux4_1.v @@ -1,9 +1,9 @@ module mux4_1 #(parameter BUS_SIZE = 32) - (input [BUS_SIZE - 1:0] A, B, C, D, - input [1:0] S, - output [BUS_SIZE - 1:0] O); + (input [BUS_SIZE - 1:0] in_1, in_2, in_3, in_4, + input [1:0] sel, + output [BUS_SIZE - 1:0] out); - assign O = S[1] ? (S[0] ? D : C) - : (S[0] ? B : A); + assign out = sel[1] ? (sel[0] ? in_4 : in_3) + : (sel[0] ? in_2 : in_1); endmodule diff --git a/rtl/program_counter.v b/rtl/program_counter.v index 8345db8..f647764 100644 --- a/rtl/program_counter.v +++ b/rtl/program_counter.v @@ -1,6 +1,6 @@ -module program_counter (input clock, reset, - input [31:0] pc_new_addr, - output reg [31:0] pc_addr); +module program_counter (input clock, reset, + input [31:0] pc_new_addr, + output reg [31:0] pc_addr); always @ (posedge clock, posedge reset) begin if (reset == 1'b1) diff --git a/rtl/registers_bank.v b/rtl/registers_bank.v index b338862..31c5225 100644 --- a/rtl/registers_bank.v +++ b/rtl/registers_bank.v @@ -1,6 +1,6 @@ -module registers_bank (input clock, reset, we, - input [4:0] sel_in, sel_out_a, sel_out_b, - input [31:0] data_in, +module registers_bank (input clock, reset, we, + input [4:0] sel_in, sel_out_a, sel_out_b, + input [31:0] data_in, output [31:0] data_out_a, data_out_b); reg [31:0] registers[31:0]; diff --git a/rtl/risc_v_cpu.v b/rtl/risc_v_cpu.v index 7985ce1..2770d01 100644 --- a/rtl/risc_v_cpu.v +++ b/rtl/risc_v_cpu.v @@ -1,4 +1,5 @@ -module risc_v_cpu (input clock, reset, output [31:0] out); +module risc_v_cpu (input clock, reset, + output [31:0] out); wire [31:0] instruction; @@ -48,34 +49,34 @@ module risc_v_cpu (input clock, reset, output [31:0] out); .data_out_b(reg_data_out_b) ); - mux2_1 mux2_1_1 ( - .A(reg_data_out_b), - .B(imm), - .S(alu_src), - .O(alu_in_b) + mux2_1 mux2_alu_in_b ( + .in_1(reg_data_out_b), + .in_2(imm), + .sel(alu_src), + .out(alu_in_b) ); alu alu ( - .input_a(reg_data_out_a), - .input_b(alu_in_b), + .in_a(reg_data_out_a), + .in_b(alu_in_b), .op_code(alu_func), .out(alu_out) ); - mux2_1 #(2) mux2_1_2 ( - .A(pc_is_branch), - .B({alu_out[1], (alu_not ? ~alu_out[0] : alu_out[0])}), - .S(pc_is_jmp), - .O(pc_sel_in) + mux2_1 #(2) mux2_pc_sel_branch ( + .in_1(pc_is_branch), + .in_2({alu_out[1], (alu_not ? ~alu_out[0] : alu_out[0])}), + .sel(pc_is_jmp), + .out(pc_sel_in) ); - mux4_1 mux4_1_1 ( - .A(pc_addr + 4), - .B(pc_addr + imm), - .C(alu_out), - .D(0), - .S(pc_sel_in), - .O(pc_new_addr) + mux4_1 mux4_pc_sel_in ( + .in_1(pc_addr + 4), + .in_2(pc_addr + imm), + .in_3(alu_out), + .in_4(0), + .sel(pc_sel_in), + .out(pc_new_addr) ); program_counter program_counter ( @@ -99,13 +100,13 @@ module risc_v_cpu (input clock, reset, output [31:0] out); .data_out(mem_out) ); - mux4_1 mux4_1_2 ( - .A(alu_out), - .B(mem_out), - .C(pc_addr + 4), - .D(pc_addr + alu_out), - .S(reg_sel_data_in), - .O(reg_data_in) + mux4_1 mux4_reg_sel_data_in ( + .in_1(alu_out), + .in_2(mem_out), + .in_3(pc_addr + 4), + .in_4(pc_addr + alu_out), + .sel(reg_sel_data_in), + .out(reg_data_in) ); endmodule diff --git a/tb/tb_alu.v b/tb/tb_alu.v index c9f80d9..39dcf26 100644 --- a/tb/tb_alu.v +++ b/tb/tb_alu.v @@ -1,41 +1,36 @@ `timescale 1ns / 1ps module tb_alu (); -// Design Inputs and outputs -reg [31:0] in_a; -reg [31:0] in_b; -reg [2:0] op_code; -wire [31:0] out; + reg [31:0] in_a; + reg [31:0] in_b; + reg [2:0] op_code; + wire [31:0] out; -// DUT instantiation -alu alu ( - .input_a(in_a), - .input_b(in_b), - .op_code(op_code), - .out(out) -); + alu alu ( + .in_a(in_a), + .in_b(in_b), + .op_code(op_code), + .out(out) + ); -// Test stimulus -initial begin - // Use the monitor task to display the FPGA IO - $monitor("time=%3d, in_a=%d, in_b=%d, ctrl=%b, q=%d \n", - $time, in_a, in_b, op_code, out); + initial begin + $monitor("time=%3d, in_a=%d, in_b=%d, ctrl=%b, q=%d \n", + $time, in_a, in_b, op_code, out); - // Generate each input with a 20 ns delay between them - in_a = 1'b0; - in_b = 1'b0; - op_code = 3'b000; - #20 - if (out !== 0) $display("[FAILED] output should be 0"); - in_a = 1'b1; - #20 - if (out !== 1) $display("[FAILED] output should be 1"); - in_b = 1'b1; - #20 - if (out !== 2) $display("[FAILED] output should be 2"); - op_code = 3'b001; - #20 - if (out !== 2) $display("[FAILED] output should be 2"); -end + in_a = 1'b0; + in_b = 1'b0; + op_code = 3'b000; + #20 + if (out !== 0) $display("[FAILED] output should be 0"); + in_a = 1'b1; + #20 + if (out !== 1) $display("[FAILED] output should be 1"); + in_b = 1'b1; + #20 + if (out !== 2) $display("[FAILED] output should be 2"); + op_code = 3'b001; + #20 + if (out !== 2) $display("[FAILED] output should be 2"); + end endmodule : tb_alu diff --git a/tb/tb_mux2_1.v b/tb/tb_mux2_1.v index b36081f..cd7bc39 100644 --- a/tb/tb_mux2_1.v +++ b/tb/tb_mux2_1.v @@ -1,61 +1,39 @@ `timescale 1ns / 1ps module tb_mux2_1 (); -// Clock and reset signals -reg clk; -reg reset; + reg ctrl; + reg [31:0] in_a; + reg [31:0] in_b; + wire [31:0] out; -// Design Inputs and outputs -reg [31:0] in_a; -reg [31:0] in_b; -reg ctrl; -wire [31:0] out; + mux2_1 mux ( + .S(ctrl), + .A(in_a), + .B(in_b), + .O(out) + ); -// DUT instantiation -mux2_1 mux ( - .S(ctrl), - .A(in_a), - .B(in_b), - .O(out) -); + initial begin + $monitor("time=%3d, in_a=%d, in_b=%d, ctrl=%b, q=%d \n", + $time, in_a, in_b, ctrl, out); -// generate the clock -initial begin - clk = 1'b0; - // forever #1 clk = ~clk; -end - -// Generate the reset -initial begin - reset = 1'b1; - #10 - reset = 1'b0; -end - -// Test stimulus -initial begin - // Use the monitor task to display the FPGA IO - $monitor("time=%3d, in_a=%d, in_b=%d, ctrl=%b, q=%d \n", - $time, in_a, in_b, ctrl, out); - - // Generate each input with a 20 ns delay between them - in_a = 1'b0; - in_b = 1'b0; - ctrl = 1'b0; - #20 - if (out !== 0) $display("[FAILED] output should be 0"); - in_a = 1'b1; - #20 - if (out !== 1) $display("[FAILED] output should be 1"); - ctrl = 1'b1; - in_a = 1'b0; - in_b = 1'b1; - #20 - if (out !== 1) $display("[FAILED] output should be 1"); - ctrl = 1'b0; - in_a = 1'b1; - #20 - if (out !== 1) $display("[FAILED] output should be 1"); -end + in_a = 1'b0; + in_b = 1'b0; + ctrl = 1'b0; + #20 + if (out !== 0) $display("[FAILED] output should be 0"); + in_a = 1'b1; + #20 + if (out !== 1) $display("[FAILED] output should be 1"); + ctrl = 1'b1; + in_a = 1'b0; + in_b = 1'b1; + #20 + if (out !== 1) $display("[FAILED] output should be 1"); + ctrl = 1'b0; + in_a = 1'b1; + #20 + if (out !== 1) $display("[FAILED] output should be 1"); + end endmodule : tb_mux2_1 diff --git a/tb/tb_risc_v_cpu.v b/tb/tb_risc_v_cpu.v index 41852e0..8cdabf5 100644 --- a/tb/tb_risc_v_cpu.v +++ b/tb/tb_risc_v_cpu.v @@ -1,36 +1,28 @@ `timescale 1ns / 1ps module tb_risc_v_cpu (); -integer i; + reg clk; + reg reset; + integer i; + wire [31:0] out; -// Clock and reset signals -reg clk; -reg reset; + risc_v_cpu risc_v_cpu ( + .clock(clk), + .reset(reset), + .out(out) + ); -// Design Inputs and outputs -wire [31:0] out; - -// DUT instantiation -risc_v_cpu risc_v_cpu ( - .clock(clk), - .reset(reset), - .out(out) -); - -// Generate the reset -initial begin - reset = 1'b1; - #10 - reset = 1'b0; -end - - -// generate the clock -initial begin - clk = 1'b0; - for (i = 0; i < 100; i = i + 1) begin - #1 clk = ~clk; + initial begin + reset = 1'b1; + #10 + reset = 1'b0; + end + + initial begin + clk = 1'b0; + for (i = 0; i < 100; i = i + 1) begin + #1 clk = ~clk; + end end -end endmodule : tb_risc_v_cpu