Compare commits
3 Commits
d89118d4d4
...
5650fd278b
Author | SHA1 | Date | |
---|---|---|---|
5650fd278b | |||
d1bf9801a7 | |||
b624ca4924 |
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
)
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user