RVSCC/rtl/two_way_lru_cru.sv

38 lines
992 B
Systemverilog
Raw Normal View History

`include "timescale.sv"
2023-01-01 22:28:56 +00:00
module two_way_lru_cru #(
2023-02-28 17:22:02 +00:00
parameter int ADDR_SIZE = 32,
parameter int NUM_SETS = 16,
parameter int BLOCK_SIZE = 32
2023-01-01 22:28:56 +00:00
) (
2023-02-28 17:22:02 +00:00
input logic clk,
input logic rst,
input logic [ADDR_SIZE - 1:0] addr,
2023-01-01 22:28:56 +00:00
input logic replace,
output logic preferred
);
2023-02-28 17:22:02 +00:00
localparam int NumBlocksBytes = BLOCK_SIZE / 4;
localparam int ByteOffsetSize = $clog2(NumBlocksBytes);
localparam int SetSize = $clog2(NumSets);
localparam int TagSize = ADDR_SIZE - SetSize - ByteOffSetSize;
typedef struct packed {
logic [ByteOffsetSize - 1:0] byte_offset;
logic [SetSize - 1:0] set;
logic [TagSize - 1:0] tag;
} cache_addr_t;
cache_addr_t packed_addr;
assign packed_addr = cache_addr_t'(addr);
logic [NUM_SETS - 1:0] lru;
assign preferred = lru[packed_addr.set];
always_ff @(posedge clk) begin
if (rst) lru[packed_addr.set] <= 0;
else if (replace) begin
lru[packed_addr.set] <= !lru[packed_addr.set];
2023-01-01 22:28:56 +00:00
end
2023-02-28 17:22:02 +00:00
end
2023-01-01 22:28:56 +00:00
endmodule