mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Merge branch 'main' of github.com:davidharrishmc/riscv-wally into main
This commit is contained in:
		
						commit
						b108e0a594
					
				
							
								
								
									
										84
									
								
								pipelined/src/cache/cachereplacementpolicy.sv
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										84
									
								
								pipelined/src/cache/cachereplacementpolicy.sv
									
									
									
									
										vendored
									
									
								
							| @ -56,9 +56,8 @@ module cachereplacementpolicy | |||||||
| 
 | 
 | ||||||
|   logic [NUMWAYS-2:0]                  cEn; |   logic [NUMWAYS-2:0]                  cEn; | ||||||
|    |    | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
|   // proposed generic solution
 |   // proposed generic solution
 | ||||||
|    | /* -----\/----- EXCLUDED -----\/----- | ||||||
|   binencoder #(NUMWAYS) encoder(HitWay, HitWayEnc); |   binencoder #(NUMWAYS) encoder(HitWay, HitWayEnc); | ||||||
| 
 | 
 | ||||||
|   // bit duplication
 |   // bit duplication
 | ||||||
| @ -70,11 +69,7 @@ module cachereplacementpolicy | |||||||
|     assign HitWayExpand[StartIndex : EndIndex] = {{DuplicationFactor}{HitWayEnc[row]}}; |     assign HitWayExpand[StartIndex : EndIndex] = {{DuplicationFactor}{HitWayEnc[row]}}; | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|   genvar               r, a,s; |   genvar               r, a,s; | ||||||
|   //localparam           s = NUMWAYS-2;
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|   assign cEn[NUMWAYS-2] = '1; |   assign cEn[NUMWAYS-2] = '1; | ||||||
|   for(s = NUMWAYS-2; s >= NUMWAYS/2; s--) begin : enables |   for(s = NUMWAYS-2; s >= NUMWAYS/2; s--) begin : enables | ||||||
|     localparam p = NUMWAYS - s; |     localparam p = NUMWAYS - s; | ||||||
| @ -86,75 +81,44 @@ module cachereplacementpolicy | |||||||
|     assign cEn[t1] = cEn[s] & HitWayEnc[r]; |     assign cEn[t1] = cEn[s] & HitWayEnc[r]; | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   mux2 #(1) LRUMuxes[NUMWAYS-2:0](LineReplacementBits, HitWayExpand, cEn, NewReplacement); |   mux2 #(1) LRUMuxes[NUMWAYS-2:0](LineReplacementBits, ~HitWayExpand, cEn, NewReplacement); | ||||||
|  | 
 | ||||||
|  |   always_ff @(posedge clk) begin | ||||||
|  |     if (reset) for (int set = 0; set < NUMLINES; set++) ReplacementBits[set] <= '0; | ||||||
|  |     if(ce) begin | ||||||
|  |       if (LRUWriteEn) begin  | ||||||
|  |         ReplacementBits[RAdr] <= NewReplacement; | ||||||
|  |         LineReplacementBits <= #1 NewReplacement; | ||||||
|  |       end else begin | ||||||
|  |         LineReplacementBits <= #1 ReplacementBits[RAdr]; | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   localparam HalfPoint = (2**$clog2(NUMWAYS)) / 2; | ||||||
|  |   logic [NUMWAYS-2:0] ivec; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |   assign ivec[HalfPoint-1:0] = LineReplacementBits[HalfPoint-1:0]; | ||||||
|  |   for(r = NUMWAYS-2; r >= HalfPoint; r--) begin | ||||||
|  |      | ||||||
|  |   end | ||||||
| 
 | 
 | ||||||
|   assign VictimWay[0] = ~LineReplacementBits[2] & ~LineReplacementBits[0]; |   assign VictimWay[0] = ~LineReplacementBits[2] & ~LineReplacementBits[0]; | ||||||
|   assign VictimWay[1] = ~LineReplacementBits[2] & LineReplacementBits[0]; |   assign VictimWay[1] = ~LineReplacementBits[2] & LineReplacementBits[0]; | ||||||
|   assign VictimWay[2] = LineReplacementBits[2] & ~LineReplacementBits[1]; |   assign VictimWay[2] = LineReplacementBits[2] & ~LineReplacementBits[1]; | ||||||
|   assign VictimWay[3] = LineReplacementBits[2] & LineReplacementBits[1];       |   assign VictimWay[3] = LineReplacementBits[2] & LineReplacementBits[1];       | ||||||
|  | 
 | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  -----/\----- EXCLUDED -----/\----- */ | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
| //  logic [NUMWAYS/2-1:0]                rawEn [LOGNUMWAYS-1:0];
 |  | ||||||
|   for(r = LOGNUMWAYS-1; r >= 0; r--) begin |  | ||||||
|     localparam integer g = 2**(LOGNUMWAYS-r-1); |  | ||||||
|     for(a = g-1; a > 0; a--) begin |  | ||||||
|       localparam t0 = s - 2**(g-1); |  | ||||||
|       localparam t1 = t0 - 1; |  | ||||||
|       localparam s = s - 1; |  | ||||||
|       assign cEn[t0] = cEn[s] & ~HitWayEnc[r]; |  | ||||||
|       assign cEn[t1] = cEn[s] & HitWayEnc[r]; |  | ||||||
|     end |  | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
|       for(a = g-1; a > 0; a--) begin |  | ||||||
|         localparam t0 = s - 2**(g-1); |  | ||||||
|         localparam t1 = t0 - 1; |  | ||||||
|         s = s - 1; |  | ||||||
|       end |  | ||||||
|   end |  | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  | ||||||
|    |  | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
|   always_comb begin |  | ||||||
|     for(r = LOGNUMWAYS-1; r > 0; r--) begin |  | ||||||
|       localparam g = 2**(LOGNUMWAYS-r-1); |  | ||||||
|       for(a = g-1; a > 0; a--) begin |  | ||||||
|         localparam t0 = s - 2**(g-1); |  | ||||||
|         localparam t1 = t0 - 1; |  | ||||||
|         s = s - 1; |  | ||||||
|       end |  | ||||||
|     end |  | ||||||
|   end |  | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  | ||||||
| 
 |  | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
| 
 |  | ||||||
|   genvar row2; |  | ||||||
|   logic [LOGNUMWAYS-1:0] indices [LOGNUMWAYS-1:0]; |  | ||||||
|   integer                jindex; |  | ||||||
|   always_comb begin |  | ||||||
|     rawEn[LOGNUMWAYS-1] = 1; |  | ||||||
|     for(jindex = 0; jindex < LOGNUMWAYS-1; jindex++) begin |  | ||||||
|       rawEn[jindex] = 0; |  | ||||||
|       rawEn[jindex][~(HitWayEnc>>(jindex+1))] = 1; |  | ||||||
| 
 |  | ||||||
|       //cEn[2**(LOGNUMWAYS-jindex)-1+jindex:0] = rawEn[jindex][2**(LOGNUMWAYS-jindex)-1:0];
 |  | ||||||
|        |  | ||||||
|     end |  | ||||||
|   end |  | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  | ||||||
| 
 |  | ||||||
|    |    | ||||||
|      |      | ||||||
|   // *** high priority to clean up
 |   // *** high priority to clean up
 | ||||||
| /* -----\/----- EXCLUDED -----\/----- |  | ||||||
|   initial begin |   initial begin | ||||||
|       assert (NUMWAYS == 2 || NUMWAYS == 4) else $error("Only 2 or 4 ways supported"); |       assert (NUMWAYS == 2 || NUMWAYS == 4) else $error("Only 2 or 4 ways supported"); | ||||||
|   end |   end | ||||||
|  -----/\----- EXCLUDED -----/\----- */ |  | ||||||
|    |    | ||||||
|   // Replacement Bits: Register file
 |   // Replacement Bits: Register file
 | ||||||
|   // Needs to be resettable for simulation, but could omit reset for synthesis ***
 |   // Needs to be resettable for simulation, but could omit reset for synthesis ***
 | ||||||
|  | |||||||
| @ -221,7 +221,7 @@ module ifu ( | |||||||
|       cache #(.LINELEN(`ICACHE_LINELENINBITS), |       cache #(.LINELEN(`ICACHE_LINELENINBITS), | ||||||
|               .NUMLINES(`ICACHE_WAYSIZEINBYTES*8/`ICACHE_LINELENINBITS), |               .NUMLINES(`ICACHE_WAYSIZEINBYTES*8/`ICACHE_LINELENINBITS), | ||||||
|               .NUMWAYS(`ICACHE_NUMWAYS), .LOGBWPL(LOGBWPL), .WORDLEN(32), .MUXINTERVAL(16), .DCACHE(0)) |               .NUMWAYS(`ICACHE_NUMWAYS), .LOGBWPL(LOGBWPL), .WORDLEN(32), .MUXINTERVAL(16), .DCACHE(0)) | ||||||
|       icache(.clk, .reset, .FlushStage(FlushW), .CPUBusy, |       icache(.clk, .reset, .FlushStage(TrapM), .CPUBusy, | ||||||
|              .FetchBuffer, .CacheBusAck(ICacheBusAck), |              .FetchBuffer, .CacheBusAck(ICacheBusAck), | ||||||
|              .CacheBusAdr(ICacheBusAdr), .CacheStall(ICacheStallF),  |              .CacheBusAdr(ICacheBusAdr), .CacheStall(ICacheStallF),  | ||||||
|              .CacheBusRW, |              .CacheBusRW, | ||||||
| @ -238,7 +238,7 @@ module ifu ( | |||||||
|       ahbcacheinterface #(WORDSPERLINE, LINELEN, LOGBWPL, `ICACHE)  |       ahbcacheinterface #(WORDSPERLINE, LINELEN, LOGBWPL, `ICACHE)  | ||||||
|       ahbcacheinterface(.HCLK(clk), .HRESETn(~reset), |       ahbcacheinterface(.HCLK(clk), .HRESETn(~reset), | ||||||
|             .HRDATA, |             .HRDATA, | ||||||
|             .Flush(FlushW), .CacheBusRW, .HSIZE(IFUHSIZE), .HBURST(IFUHBURST), .HTRANS(IFUHTRANS), .HWSTRB(), |             .Flush(TrapM), .CacheBusRW, .HSIZE(IFUHSIZE), .HBURST(IFUHBURST), .HTRANS(IFUHTRANS), .HWSTRB(), | ||||||
|             .Funct3(3'b010), .HADDR(IFUHADDR), .HREADY(IFUHREADY), .HWRITE(IFUHWRITE), .CacheBusAdr(ICacheBusAdr), |             .Funct3(3'b010), .HADDR(IFUHADDR), .HREADY(IFUHREADY), .HWRITE(IFUHWRITE), .CacheBusAdr(ICacheBusAdr), | ||||||
|             .BeatCount(), .Cacheable(CacheableF), .SelBusBeat(), .WriteDataM('0), |             .BeatCount(), .Cacheable(CacheableF), .SelBusBeat(), .WriteDataM('0), | ||||||
|              .CacheBusAck(ICacheBusAck), .HWDATA(), .CacheableOrFlushCacheM(1'b0), .CacheReadDataWordM('0), |              .CacheBusAck(ICacheBusAck), .HWDATA(), .CacheableOrFlushCacheM(1'b0), .CacheReadDataWordM('0), | ||||||
| @ -257,7 +257,7 @@ module ifu ( | |||||||
| //      assign BusRW = IFURWF & ~{IgnoreRequest, IgnoreRequest} & ~{SelIROM, SelIROM};
 | //      assign BusRW = IFURWF & ~{IgnoreRequest, IgnoreRequest} & ~{SelIROM, SelIROM};
 | ||||||
|       assign IFUHSIZE = 3'b010; |       assign IFUHSIZE = 3'b010; | ||||||
| 
 | 
 | ||||||
|       ahbinterface #(0) ahbinterface(.HCLK(clk), .Flush(FlushW), .HRESETn(~reset), .HREADY(IFUHREADY),  |       ahbinterface #(0) ahbinterface(.HCLK(clk), .Flush(TrapM), .HRESETn(~reset), .HREADY(IFUHREADY),  | ||||||
|         .HRDATA(HRDATA), .HTRANS(IFUHTRANS), .HWRITE(IFUHWRITE), .HWDATA(), |         .HRDATA(HRDATA), .HTRANS(IFUHTRANS), .HWRITE(IFUHWRITE), .HWDATA(), | ||||||
|         .HWSTRB(), .BusRW, .ByteMask(), .WriteData('0), |         .HWSTRB(), .BusRW, .ByteMask(), .WriteData('0), | ||||||
|         .CPUBusy, .BusStall, .BusCommitted(BusCommittedF), .FetchBuffer(FetchBuffer)); |         .CPUBusy, .BusStall, .BusCommitted(BusCommittedF), .FetchBuffer(FetchBuffer)); | ||||||
|  | |||||||
| @ -246,7 +246,7 @@ module wallypipelinedcore ( | |||||||
| 
 | 
 | ||||||
|   lsu lsu( |   lsu lsu( | ||||||
|      .clk, .reset, .StallM, .FlushM, .StallW, |      .clk, .reset, .StallM, .FlushM, .StallW, | ||||||
|   .FlushW, |   .FlushW(TrapM), | ||||||
|   // CPU interface
 |   // CPU interface
 | ||||||
|   .MemRWM, .Funct3M, .Funct7M(InstrM[31:25]), |   .MemRWM, .Funct3M, .Funct7M(InstrM[31:25]), | ||||||
|   .AtomicM, |   .AtomicM, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user