Compare commits

...

3 Commits

Author SHA1 Message Date
5650fd278b Fix verilator test
Some checks are pending
continuous-integration/drone/push Build is pending
2023-03-20 01:13:34 -03:00
d1bf9801a7 Merge branch 'main' of https://git.1159.cl/Mario1159/RVSCC 2023-03-19 23:42:51 -03:00
b624ca4924 Update cache test 2023-03-19 23:03:52 -03:00
5 changed files with 32 additions and 15 deletions

View File

@ -24,7 +24,7 @@ module cache_controller #(
typedef struct packed { typedef struct packed {
logic [TagSize - 1:0] tag; logic [TagSize - 1:0] tag;
logic [SetSize - 1:0] set; logic [SetSize - 1:0] addr_set;
logic [ByteOffsetSize - 1:0] byte_offset; logic [ByteOffsetSize - 1:0] byte_offset;
} cache_addr_t; } cache_addr_t;
@ -39,14 +39,14 @@ module cache_controller #(
always_comb begin always_comb begin
packed_addr = cache_addr_t'(addr); packed_addr = cache_addr_t'(addr);
set = packed_addr.set; set = packed_addr.addr_set;
tag = packed_addr.tag; tag = packed_addr.tag;
state = cache_state_t'{write_enable, populated}; state = cache_state_t'({write_enable, populated});
case (state) case (state)
READ: begin READ: begin
cru_enable = 0; cru_enable = 0;
write_way = 'dx; write_way = 1'dx;
end end
WRITE_POPULATE: begin WRITE_POPULATE: begin
cru_enable = 0; cru_enable = 0;
@ -58,7 +58,7 @@ module cache_controller #(
end end
default: begin default: begin
cru_enable = 0; cru_enable = 0;
write_way = 'dx; write_way = 1'dx;
end end
endcase endcase
end end

View File

@ -18,9 +18,11 @@ module two_way_lru_cache #(
logic read_valid; logic read_valid;
logic [WaySize - 1:0] way; logic [WaySize - 1:0] way;
logic [SetSize - 1:0] set; logic [SetSize - 1:0] xset;
logic [TagSize - 1:0] tag; logic [TagSize - 1:0] tag;
logic write_way;
logic populated;
cache_memory #( cache_memory #(
.ADDR_SIZE (ADDR_SIZE), .ADDR_SIZE (ADDR_SIZE),
.NUM_SETS (NUM_SETS), .NUM_SETS (NUM_SETS),
@ -30,7 +32,7 @@ module two_way_lru_cache #(
.clk(data_mem_if.clk), .clk(data_mem_if.clk),
.rst(data_mem_if.rst), .rst(data_mem_if.rst),
.write_way(write_way), .write_way(write_way),
.set(set), .set(xset),
.tag(tag), .tag(tag),
.write_enable(data_mem_if.write_enable), .write_enable(data_mem_if.write_enable),
.write_data(data_mem_if.write_data), .write_data(data_mem_if.write_data),
@ -40,6 +42,8 @@ module two_way_lru_cache #(
.hit(data_mem_if.hit) .hit(data_mem_if.hit)
); );
logic cru_enable;
logic replace_preferred_way;
two_way_lru_cru #( two_way_lru_cru #(
.ADDR_SIZE (ADDR_SIZE), .ADDR_SIZE (ADDR_SIZE),
.NUM_SETS (NUM_SETS), .NUM_SETS (NUM_SETS),
@ -65,7 +69,7 @@ module two_way_lru_cache #(
.populated(populated), .populated(populated),
.cru_enable(cru_enable), .cru_enable(cru_enable),
.write_way(write_way), .write_way(write_way),
.set(set), .set(xset),
.tag(tag) .tag(tag)
); );
endmodule endmodule

View File

@ -18,7 +18,7 @@ module two_way_lru_cru #(
typedef struct packed { typedef struct packed {
logic [ByteOffsetSize - 1:0] byte_offset; logic [ByteOffsetSize - 1:0] byte_offset;
logic [SetSize - 1:0] set; logic [SetSize - 1:0] xset;
logic [TagSize - 1:0] tag; logic [TagSize - 1:0] tag;
} cache_addr_t; } cache_addr_t;
@ -27,11 +27,11 @@ module two_way_lru_cru #(
logic [NUM_SETS - 1:0] lru; logic [NUM_SETS - 1:0] lru;
assign preferred = lru[packed_addr.set]; assign preferred = lru[packed_addr.xset];
always_ff @(posedge clk) begin always_ff @(posedge clk) begin
if (rst) lru <= 'd0; if (rst) lru <= 'd0;
else if (replace) begin else if (replace) begin
lru[packed_addr.set] <= !lru[packed_addr.set]; lru[packed_addr.xset] <= !lru[packed_addr.xset];
end end
end end
endmodule endmodule

View File

@ -50,8 +50,7 @@ rvscc_add_test(
) )
rvscc_add_test( rvscc_add_test(
NAME instruction_memory NAME instruction_memory TOP test_instr_memory
TOP test_instr_memory
SOURCES ${PROJECT_SOURCE_DIR}/rtl/rv32i_defs.sv SOURCES ${PROJECT_SOURCE_DIR}/rtl/rv32i_defs.sv
${PROJECT_SOURCE_DIR}/rtl/instr_memory_if.sv ${PROJECT_SOURCE_DIR}/rtl/instr_memory_if.sv
${PROJECT_SOURCE_DIR}/rtl/instr_memory.sv ${PROJECT_SOURCE_DIR}/rtl/instr_memory.sv
@ -104,3 +103,16 @@ rvscc_add_test(
${PROJECT_SOURCE_DIR}/rtl/priority_encoder.sv ${PROJECT_SOURCE_DIR}/rtl/priority_encoder.sv
${PROJECT_SOURCE_DIR}/test/test_cache_memory.sv ${PROJECT_SOURCE_DIR}/test/test_cache_memory.sv
) )
rvscc_add_test(
NAME two-way-lru-cache
TOP test_two_way_lru_cache
SOURCES ${PROJECT_SOURCE_DIR}/rtl/rv32i_defs.sv
${PROJECT_SOURCE_DIR}/rtl/two_way_lru_cache.sv
${PROJECT_SOURCE_DIR}/rtl/two_way_lru_cru.sv
${PROJECT_SOURCE_DIR}/rtl/data_memory_if.sv
${PROJECT_SOURCE_DIR}/rtl/cache_memory.sv
${PROJECT_SOURCE_DIR}/rtl/cache_controller.sv
${PROJECT_SOURCE_DIR}/rtl/priority_encoder.sv
${PROJECT_SOURCE_DIR}/test/test_two_way_lru_cache.sv
)

View File

@ -27,11 +27,12 @@ module test_cache_memory ();
.write_data(write_data), .write_data(write_data),
.read_data(read_data), .read_data(read_data),
.hit(hit), .hit(hit),
.populate_way(populate_way) .populate_way(populate_way),
.populated()
); );
localparam int ClockCycle = 2; localparam int ClockCycle = 2;
always #(ClockCycle/2) clk = !clk; always #(ClockCycle / 2) clk = !clk;
logic [31:0] write_value; logic [31:0] write_value;