From b5eba44417df2a67a11712d82c411b70ee098a74 Mon Sep 17 00:00:00 2001 From: Ross Thompson Date: Wed, 25 Aug 2021 13:46:36 -0500 Subject: [PATCH] Replaced dcache generate ORing with or_rows. --- wally-pipelined/src/cache/cacheway.sv | 21 ++++++++++----------- wally-pipelined/src/cache/dcache.sv | 18 ++++++------------ 2 files changed, 16 insertions(+), 23 deletions(-) diff --git a/wally-pipelined/src/cache/cacheway.sv b/wally-pipelined/src/cache/cacheway.sv index 288d8fc00..3f2f08bf2 100644 --- a/wally-pipelined/src/cache/cacheway.sv +++ b/wally-pipelined/src/cache/cacheway.sv @@ -30,13 +30,12 @@ module cacheway #(parameter NUMLINES=512, parameter BLOCKLEN = 256, TAGLEN = 26, (input logic clk, input logic reset, - input logic [$clog2(NUMLINES)-1:0] Adr, + input logic [$clog2(NUMLINES)-1:0] RAdr, input logic [`PA_BITS-1:OFFSETLEN+INDEXLEN] MemPAdrM, input logic WriteEnable, input logic [BLOCKLEN/`XLEN-1:0] WriteWordEnable, input logic TagWriteEnable, input logic [BLOCKLEN-1:0] WriteData, - input logic [TAGLEN-1:0] WriteTag, input logic SetValid, input logic ClearValid, input logic SetDirty, @@ -63,7 +62,7 @@ module cacheway #(parameter NUMLINES=512, parameter BLOCKLEN = 256, TAGLEN = 26, sram1rw #(.DEPTH(`XLEN), .WIDTH(NUMLINES)) CacheDataMem(.clk(clk), - .Addr(Adr), + .Addr(RAdr), .ReadData(ReadDataBlockWayM[(words+1)*`XLEN-1:words*`XLEN]), .WriteData(WriteData[(words+1)*`XLEN-1:words*`XLEN]), .WriteEnable(WriteEnable & WriteWordEnable[words])); @@ -73,9 +72,9 @@ module cacheway #(parameter NUMLINES=512, parameter BLOCKLEN = 256, TAGLEN = 26, sram1rw #(.DEPTH(TAGLEN), .WIDTH(NUMLINES)) CacheTagMem(.clk(clk), - .Addr(Adr), + .Addr(RAdr), .ReadData(ReadTag), - .WriteData(WriteTag), + .WriteData(MemPAdrM), .WriteEnable(TagWriteEnable)); assign WayHit = Valid & (ReadTag == MemPAdrM[`PA_BITS-1:OFFSETLEN+INDEXLEN]); @@ -88,17 +87,17 @@ module cacheway #(parameter NUMLINES=512, parameter BLOCKLEN = 256, TAGLEN = 26, always_ff @(posedge clk, posedge reset) begin if (reset) ValidBits <= {NUMLINES{1'b0}}; - else if (SetValid & WriteEnable) ValidBits[Adr] <= 1'b1; - else if (ClearValid & WriteEnable) ValidBits[Adr] <= 1'b0; - Valid <= ValidBits[Adr]; + else if (SetValid & WriteEnable) ValidBits[RAdr] <= 1'b1; + else if (ClearValid & WriteEnable) ValidBits[RAdr] <= 1'b0; + Valid <= ValidBits[RAdr]; end always_ff @(posedge clk, posedge reset) begin if (reset) DirtyBits <= {NUMLINES{1'b0}}; - else if (SetDirty & WriteEnable) DirtyBits[Adr] <= 1'b1; - else if (ClearDirty & WriteEnable) DirtyBits[Adr] <= 1'b0; - Dirty <= DirtyBits[Adr]; + else if (SetDirty & WriteEnable) DirtyBits[RAdr] <= 1'b1; + else if (ClearDirty & WriteEnable) DirtyBits[RAdr] <= 1'b0; + Dirty <= DirtyBits[RAdr]; end diff --git a/wally-pipelined/src/cache/dcache.sv b/wally-pipelined/src/cache/dcache.sv index b2e4cdd75..00034d43a 100644 --- a/wally-pipelined/src/cache/dcache.sv +++ b/wally-pipelined/src/cache/dcache.sv @@ -205,13 +205,12 @@ module dcache cacheway #(.NUMLINES(NUMLINES), .BLOCKLEN(BLOCKLEN), .TAGLEN(TAGLEN), .OFFSETLEN(OFFSETLEN), .INDEXLEN(INDEXLEN)) MemWay[NUMWAYS-1:0](.clk, .reset, - .Adr(SRAMAdr), + .RAdr(SRAMAdr), .MemPAdrM(MemPAdrM[`PA_BITS-1:OFFSETLEN+INDEXLEN]), .WriteEnable(SRAMWayWriteEnable), .WriteWordEnable(SRAMWordEnable), .TagWriteEnable(SRAMBlockWayWriteEnableM), .WriteData(SRAMWriteData), - .WriteTag(MemPAdrM[`PA_BITS-1:OFFSETLEN+INDEXLEN]), .SetValid(SetValidM), .ClearValid(ClearValidM), .SetDirty(SetDirtyM), @@ -264,22 +263,17 @@ module dcache // ReadDataBlockWayMaskedM is a 2d array of cache block len by number of ways. // Need to OR together each way in a bitwise manner. // Final part of the AO Mux. - genvar index; - always_comb begin - ReadDataBlockM = '0; - VictimReadDataBlockM = '0; - VictimTag = '0; - for(int index = 0; index < NUMWAYS; index++) begin - ReadDataBlockM = ReadDataBlockM | ReadDataBlockWayMaskedM[index]; - VictimTag = VictimTag | VictimTagWay[index]; - end - end + or_rows #(NUMWAYS, BLOCKLEN) ReadDataAOMux(.a(ReadDataBlockWayMaskedM), .y(ReadDataBlockM)); + or_rows #(NUMWAYS, TAGLEN) VictimTagAOMux(.a(VictimTagWay), .y(VictimTag)); + assign VictimDirty = | VictimDirtyWay; // Convert the Read data bus ReadDataSelectWay into sets of XLEN so we can // easily build a variable input mux. // *** consider using a limited range shift to do this final muxing. + genvar index; + generate for (index = 0; index < WORDSPERLINE; index++) begin assign ReadDataBlockSetsM[index] = ReadDataBlockM[((index+1)*`XLEN)-1: (index*`XLEN)];