72 lines
1.9 KiB
Systemverilog
72 lines
1.9 KiB
Systemverilog
`include "timescale.sv"
|
|
|
|
module two_way_lru_cache #(
|
|
parameter int ADDR_SIZE = 32,
|
|
parameter int NUM_SETS = 16,
|
|
parameter int BLOCK_SIZE = 32
|
|
) (
|
|
data_memory_if.cache data_mem_if
|
|
);
|
|
localparam int NumWays = 2;
|
|
localparam int NumBlockBytes = BLOCK_SIZE / 4;
|
|
localparam int ByteOffsetSize = $clog2(NumBlockBytes);
|
|
localparam int WaySize = $clog2(NumWays);
|
|
localparam int SetSize = $clog2(NUM_SETS);
|
|
localparam int TagSize = ADDR_SIZE - SetSize - ByteOffsetSize;
|
|
|
|
logic [$clog2(NumWays) - 1:0] populate_way;
|
|
logic read_valid;
|
|
|
|
logic [WaySize - 1:0] way;
|
|
logic [SetSize - 1:0] set;
|
|
logic [TagSize - 1:0] tag;
|
|
|
|
cache_memory #(
|
|
.ADDR_SIZE (ADDR_SIZE),
|
|
.NUM_SETS (NUM_SETS),
|
|
.NUM_WAYS (NumWays),
|
|
.BLOCK_SIZE(BLOCK_SIZE)
|
|
) cache_memory (
|
|
.clk(data_mem_if.clk),
|
|
.rst(data_mem_if.rst),
|
|
.write_way(write_way),
|
|
.set(set),
|
|
.tag(tag),
|
|
.write_enable(data_mem_if.write_enable),
|
|
.write_data(data_mem_if.write_data),
|
|
.read_data(data_mem_if.read_data),
|
|
.populate_way(populate_way),
|
|
.populated(populated),
|
|
.hit(data_mem_if.hit)
|
|
);
|
|
|
|
two_way_lru_cru #(
|
|
.ADDR_SIZE (ADDR_SIZE),
|
|
.NUM_SETS (NUM_SETS),
|
|
.BLOCK_SIZE(BLOCK_SIZE)
|
|
) cache_replace_unit (
|
|
.clk(data_mem_if.clk),
|
|
.rst(data_mem_if.rst),
|
|
.addr(data_mem_if.addr),
|
|
.replace(cru_enable),
|
|
.preferred(replace_preferred_way)
|
|
);
|
|
|
|
cache_controller #(
|
|
.ADDR_SIZE (ADDR_SIZE),
|
|
.NUM_SETS (NUM_SETS),
|
|
.NUM_WAYS (NumWays),
|
|
.BLOCK_SIZE(BLOCK_SIZE)
|
|
) cache_controller (
|
|
.addr(data_mem_if.addr),
|
|
.write_enable(data_mem_if.write_enable),
|
|
.replace_way(replace_preferred_way),
|
|
.populate_way(populate_way),
|
|
.populated(populated),
|
|
.cru_enable(cru_enable),
|
|
.write_way(write_way),
|
|
.set(set),
|
|
.tag(tag)
|
|
);
|
|
endmodule
|