RVSCC/rtl/cache_controller.sv

67 lines
1.7 KiB
Systemverilog
Raw Normal View History

`include "timescale.sv"
2023-01-01 22:28:56 +00:00
module cache_controller #(
2023-01-29 04:55:22 +00:00
parameter int ADDR_SIZE = 32,
parameter int NUM_SETS = 16,
parameter int NUM_WAYS = 4,
parameter int BLOCK_SIZE = 32
2023-01-01 22:28:56 +00:00
) (
2023-01-29 04:55:22 +00:00
input logic [ADDR_SIZE - 1:0] addr,
2023-01-01 22:28:56 +00:00
input logic write_enable,
2023-03-02 19:56:34 +00:00
input logic [$clog2(NUM_WAYS) - 1:0] replace_way,
input logic [$clog2(NUM_WAYS) - 1:0] populate_way,
2023-03-18 23:45:55 +00:00
input logic populated,
2023-03-02 19:56:34 +00:00
output logic cru_enable,
output logic [$clog2(NUM_WAYS) - 1:0] write_way,
output logic [$clog2(NUM_SETS) - 1:0] set,
output logic [ADDR_SIZE - $clog2(NUM_SETS) - $clog2(BLOCK_SIZE / 4) - 1:0] tag
2023-01-01 22:28:56 +00:00
);
2023-01-29 04:55:22 +00:00
localparam int NumBlockBytes = BLOCK_SIZE / 4;
localparam int ByteOffsetSize = $clog2(NumBlockBytes);
localparam int SetSize = $clog2(NUM_SETS);
localparam int TagSize = ADDR_SIZE - SetSize - ByteOffsetSize;
localparam int WaySize = $clog2(NUM_WAYS);
2023-01-01 22:28:56 +00:00
2023-01-29 04:55:22 +00:00
typedef struct packed {
logic [TagSize - 1:0] tag;
2023-03-20 04:13:34 +00:00
logic [SetSize - 1:0] addr_set;
2023-03-18 23:45:55 +00:00
logic [ByteOffsetSize - 1:0] byte_offset;
2023-01-29 04:55:22 +00:00
} cache_addr_t;
2023-01-01 22:28:56 +00:00
2023-01-29 04:55:22 +00:00
typedef enum logic [1:0] {
READ = 'b00,
2023-03-02 19:56:34 +00:00
WRITE_POPULATE = 'b10,
WRITE_REPLACE = 'b11
2023-01-29 04:55:22 +00:00
} cache_state_t;
2023-01-01 22:28:56 +00:00
2023-03-02 19:56:34 +00:00
cache_addr_t packed_addr;
2023-01-29 04:55:22 +00:00
cache_state_t state;
2023-01-01 22:28:56 +00:00
2023-01-29 04:55:22 +00:00
always_comb begin
2023-03-02 19:56:34 +00:00
packed_addr = cache_addr_t'(addr);
2023-03-20 04:13:34 +00:00
set = packed_addr.addr_set;
2023-01-29 04:55:22 +00:00
tag = packed_addr.tag;
2023-03-20 04:13:34 +00:00
state = cache_state_t'({write_enable, populated});
2023-01-29 04:55:22 +00:00
case (state)
READ: begin
cru_enable = 0;
2023-03-20 04:13:34 +00:00
write_way = 1'dx;
2023-01-29 04:55:22 +00:00
end
2023-03-02 19:56:34 +00:00
WRITE_POPULATE: begin
2023-01-29 04:55:22 +00:00
cru_enable = 0;
2023-03-18 23:45:55 +00:00
write_way = populate_way;
2023-01-29 04:55:22 +00:00
end
2023-03-02 19:56:34 +00:00
WRITE_REPLACE: begin
2023-01-29 04:55:22 +00:00
cru_enable = 1;
2023-03-02 19:56:34 +00:00
write_way = replace_way;
2023-01-29 04:55:22 +00:00
end
default: begin
cru_enable = 0;
2023-03-20 04:13:34 +00:00
write_way = 1'dx;
2023-01-29 04:55:22 +00:00
end
endcase
end
2023-03-18 23:45:55 +00:00
2023-01-01 22:28:56 +00:00
endmodule