Update two way LRU cache

This commit is contained in:
Mario Romero 2023-03-18 20:45:55 -03:00
parent 37e0c938a3
commit 201029b1e3
6 changed files with 44 additions and 31 deletions

View File

@ -1,5 +1,5 @@
# RVSCC developer enviroment # RVSCC developer enviroment
FROM alpine FROM alpine:edge
MAINTAINER Mario Romero <mario@1159.cl> MAINTAINER Mario Romero <mario@1159.cl>
# Install packages # Install packages

View File

@ -10,6 +10,7 @@ module cache_controller #(
input logic write_enable, input logic write_enable,
input logic [$clog2(NUM_WAYS) - 1:0] replace_way, input logic [$clog2(NUM_WAYS) - 1:0] replace_way,
input logic [$clog2(NUM_WAYS) - 1:0] populate_way, input logic [$clog2(NUM_WAYS) - 1:0] populate_way,
input logic populated,
output logic cru_enable, output logic cru_enable,
output logic [$clog2(NUM_WAYS) - 1:0] write_way, output logic [$clog2(NUM_WAYS) - 1:0] write_way,
output logic [$clog2(NUM_SETS) - 1:0] set, output logic [$clog2(NUM_SETS) - 1:0] set,
@ -22,9 +23,9 @@ module cache_controller #(
localparam int WaySize = $clog2(NUM_WAYS); localparam int WaySize = $clog2(NUM_WAYS);
typedef struct packed { typedef struct packed {
logic [ByteOffsetSize - 1:0] byte_offset;
logic [SetSize - 1:0] set;
logic [TagSize - 1:0] tag; logic [TagSize - 1:0] tag;
logic [SetSize - 1:0] set;
logic [ByteOffsetSize - 1:0] byte_offset;
} cache_addr_t; } cache_addr_t;
typedef enum logic [1:0] { typedef enum logic [1:0] {
@ -36,15 +37,12 @@ module cache_controller #(
cache_addr_t packed_addr; cache_addr_t packed_addr;
cache_state_t state; cache_state_t state;
logic [WaySize - 1:0] next_populate_way;
logic valid;
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.set;
tag = packed_addr.tag; tag = packed_addr.tag;
state = cache_state_t'{write_enable, valid}; state = cache_state_t'{write_enable, populated};
case (state) case (state)
READ: begin READ: begin
cru_enable = 0; cru_enable = 0;
@ -52,7 +50,7 @@ module cache_controller #(
end end
WRITE_POPULATE: begin WRITE_POPULATE: begin
cru_enable = 0; cru_enable = 0;
write_way = next_populate_way; write_way = populate_way;
end end
WRITE_REPLACE: begin WRITE_REPLACE: begin
cru_enable = 1; cru_enable = 1;
@ -63,6 +61,6 @@ module cache_controller #(
write_way = 'dx; write_way = 'dx;
end end
endcase endcase
next_populate_way = populate_way + 'd1;
end end
endmodule endmodule

View File

@ -15,6 +15,7 @@ module cache_memory #(
input logic [BLOCK_SIZE - 1:0] write_data, input logic [BLOCK_SIZE - 1:0] write_data,
output logic [BLOCK_SIZE - 1:0] read_data, output logic [BLOCK_SIZE - 1:0] read_data,
output logic [$clog2(NUM_WAYS) - 1:0] populate_way, output logic [$clog2(NUM_WAYS) - 1:0] populate_way,
output logic populated,
output logic hit output logic hit
); );
localparam int NumBlockBytes = BLOCK_SIZE / 4; localparam int NumBlockBytes = BLOCK_SIZE / 4;
@ -75,11 +76,28 @@ module cache_memory #(
end end
end end
logic valid_flags_index_valid;
logic[WaySize-1:0] valid_flags_index;
priority_encoder #( priority_encoder #(
.N(WaySize) .N(WaySize)
) populate_way_encoder ( ) populate_way_encoder (
.data_in(valid_flags), .data_in(valid_flags),
.data_out(populate_way), .data_out(valid_flags_index),
.valid() .valid(valid_flags_index_valid)
); );
/*
generate
if (WaySize > 1)
always_comb populated &= populate_way;
else
assign populated = populate_way;
endgenerate*/
always_comb begin
if(valid_flags_index_valid)
{populated, populate_way} = valid_flags_index + 'd1;
else
{populated, populate_way} = 'd0;
end
endmodule endmodule

View File

@ -11,11 +11,12 @@ interface data_memory_if #(
logic write_enable; logic write_enable;
logic [DATA_SIZE-1:0] write_data; logic [DATA_SIZE-1:0] write_data;
logic [DATA_SIZE-1:0] read_data; logic [DATA_SIZE-1:0] read_data;
logic valid; logic hit;
logic ready; logic ready;
modport datapath(input read_data, output addr, write_enable, write_data); modport datapath(input read_data, output addr, write_enable, write_data);
modport ram(input clk, rst, addr, write_enable, write_data, output read_data); modport ram(input clk, rst, addr, write_enable, write_data, output read_data);
modport cache(input clk, rst, addr, write_enable, write_data, output read_data, hit);
modport test(input read_data, write_enable, write_data); modport test(input read_data, write_enable, write_data);
/* /*

View File

@ -5,13 +5,7 @@ module two_way_lru_cache #(
parameter int NUM_SETS = 16, parameter int NUM_SETS = 16,
parameter int BLOCK_SIZE = 32 parameter int BLOCK_SIZE = 32
) ( ) (
input logic clk, data_memory_if.cache data_mem_if
input logic rst,
input logic [ADDR_SIZE - 1:0] addr,
input logic write_enable,
input logic [BLOCK_SIZE - 1:0] write_data,
output logic [BLOCK_SIZE - 1:0] read_data,
output logic hit
); );
localparam int NumWays = 2; localparam int NumWays = 2;
localparam int NumBlockBytes = BLOCK_SIZE / 4; localparam int NumBlockBytes = BLOCK_SIZE / 4;
@ -33,16 +27,17 @@ module two_way_lru_cache #(
.NUM_WAYS (NumWays), .NUM_WAYS (NumWays),
.BLOCK_SIZE(BLOCK_SIZE) .BLOCK_SIZE(BLOCK_SIZE)
) cache_memory ( ) cache_memory (
.clk(clk), .clk(data_mem_if.clk),
.rst(rst), .rst(data_mem_if.rst),
.write_way(write_way), .write_way(write_way),
.set(set), .set(set),
.tag(tag), .tag(tag),
.write_enable(write_enable), .write_enable(data_mem_if.write_enable),
.write_data(write_data), .write_data(data_mem_if.write_data),
.read_data(read_data), .read_data(data_mem_if.read_data),
.populate_way(populate_way), .populate_way(populate_way),
.hit(hit) .populated(populated),
.hit(data_mem_if.hit)
); );
two_way_lru_cru #( two_way_lru_cru #(
@ -50,9 +45,9 @@ module two_way_lru_cache #(
.NUM_SETS (NUM_SETS), .NUM_SETS (NUM_SETS),
.BLOCK_SIZE(BLOCK_SIZE) .BLOCK_SIZE(BLOCK_SIZE)
) cache_replace_unit ( ) cache_replace_unit (
.clk(clk), .clk(data_mem_if.clk),
.rst(rst), .rst(data_mem_if.rst),
.addr(addr), .addr(data_mem_if.addr),
.replace(cru_enable), .replace(cru_enable),
.preferred(replace_preferred_way) .preferred(replace_preferred_way)
); );
@ -63,10 +58,11 @@ module two_way_lru_cache #(
.NUM_WAYS (NumWays), .NUM_WAYS (NumWays),
.BLOCK_SIZE(BLOCK_SIZE) .BLOCK_SIZE(BLOCK_SIZE)
) cache_controller ( ) cache_controller (
.addr(addr), .addr(data_mem_if.addr),
.write_enable(write_enable), .write_enable(data_mem_if.write_enable),
.replace_way(replace_preferred_way), .replace_way(replace_preferred_way),
.populate_way(populate_way), .populate_way(populate_way),
.populated(populated),
.cru_enable(cru_enable), .cru_enable(cru_enable),
.write_way(write_way), .write_way(write_way),
.set(set), .set(set),

View File

@ -29,7 +29,7 @@ module two_way_lru_cru #(
assign preferred = lru[packed_addr.set]; assign preferred = lru[packed_addr.set];
always_ff @(posedge clk) begin always_ff @(posedge clk) begin
if (rst) lru[packed_addr.set] <= 0; if (rst) lru <= 'd0;
else if (replace) begin else if (replace) begin
lru[packed_addr.set] <= !lru[packed_addr.set]; lru[packed_addr.set] <= !lru[packed_addr.set];
end end