mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Fixed another bug in the btb.
This commit is contained in:
		
							parent
							
								
									5187c78184
								
							
						
					
					
						commit
						68e39eeb66
					
				@ -144,7 +144,7 @@ module bpred (
 | 
			
		||||
  // BTB contains target address for all CFI
 | 
			
		||||
 | 
			
		||||
  btb #(`BTB_SIZE) 
 | 
			
		||||
    TargetPredictor(.clk, .reset, .StallF, .StallD, .StallE, .StallM, .FlushD, .FlushE, .FlushM,
 | 
			
		||||
    TargetPredictor(.clk, .reset, .StallF, .StallD, .StallE, .StallM, .StallW, .FlushD, .FlushE, .FlushM, .FlushW,
 | 
			
		||||
          .PCNextF, .PCF, .PCD, .PCE, .PCM,
 | 
			
		||||
          .PredPCF,
 | 
			
		||||
          .BTBPredInstrClassF,
 | 
			
		||||
 | 
			
		||||
@ -33,7 +33,7 @@
 | 
			
		||||
module btb #(parameter Depth = 10 ) (
 | 
			
		||||
  input logic 			   clk,
 | 
			
		||||
  input logic 			   reset,
 | 
			
		||||
  input logic 			   StallF, StallD, StallE, StallM, FlushD, FlushE, FlushM,
 | 
			
		||||
  input logic 			   StallF, StallD, StallE, StallM, StallW, FlushD, FlushE, FlushM, FlushW,
 | 
			
		||||
  input logic [`XLEN-1:0]  PCNextF, PCF, PCD, PCE, PCM, // PC at various stages
 | 
			
		||||
  output logic [`XLEN-1:0] PredPCF, // BTB's guess at PC
 | 
			
		||||
  output logic [3:0] 	   BTBPredInstrClassF, // BTB's guess at instruction class
 | 
			
		||||
@ -93,7 +93,7 @@ module btb #(parameter Depth = 10 ) (
 | 
			
		||||
  // An optimization may be using a PC relative address.
 | 
			
		||||
  ram2p1r1wbe #(2**Depth, `XLEN+4) memory(
 | 
			
		||||
    .clk, .ce1(~StallF | reset), .ra1(PCNextFIndex), .rd1(TableBTBPredictionF),
 | 
			
		||||
     .ce2(~StallM & ~FlushM), .wa2(PCMIndex), .wd2({InstrClassM, IEUAdrM}), .we2(UpdateEn), .bwe2('1));
 | 
			
		||||
     .ce2(~StallW & ~FlushW), .wa2(PCMIndex), .wd2({InstrClassM, IEUAdrM}), .we2(UpdateEn), .bwe2('1));
 | 
			
		||||
 | 
			
		||||
  flopenrc #(`XLEN) BTBD(clk, reset, FlushD, ~StallD, PredPCF, PredPCD);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -83,7 +83,7 @@ module gshareForward #(parameter k = 10) (
 | 
			
		||||
    .rd1(TableDirPredictionF),
 | 
			
		||||
    .wa2(IndexM),
 | 
			
		||||
    .wd2(NewDirPredictionM),
 | 
			
		||||
    .we2(BranchInstrM & ~StallW & ~FlushW),
 | 
			
		||||
    .we2(BranchInstrM),
 | 
			
		||||
    .bwe2(1'b1));
 | 
			
		||||
 | 
			
		||||
  flopenrc #(2) PredictionRegD(clk, reset,  FlushD, ~StallD, DirPredictionF, DirPredictionD);
 | 
			
		||||
@ -102,7 +102,7 @@ module gshareForward #(parameter k = 10) (
 | 
			
		||||
  assign GHRNext = BranchInstrM ? {PCSrcM, GHR[k-1:1]} : GHR;
 | 
			
		||||
  assign GHRM = GHR;
 | 
			
		||||
 | 
			
		||||
  flopenr #(k) GHRReg(clk, reset, ~StallM & ~FlushM & BranchInstrM, GHRNext, GHR);
 | 
			
		||||
  flopenr #(k) GHRReg(clk, reset, ~StallW & ~FlushW & BranchInstrM, GHRNext, GHR);
 | 
			
		||||
  flopenrc #(1) PCSrcMReg(clk, reset, FlushM, ~StallM, PCSrcE, PCSrcM);
 | 
			
		||||
    
 | 
			
		||||
endmodule
 | 
			
		||||
 | 
			
		||||
@ -50,8 +50,8 @@ string tvpaths[] = '{
 | 
			
		||||
 | 
			
		||||
  string embench[] = '{
 | 
			
		||||
    `EMBENCH,
 | 
			
		||||
    "bd_speedopt_speed/src/cubic/cubic", // cubic is likely going to removed when embench 2.0 launches
 | 
			
		||||
    "bd_speedopt_speed/src/nsichneu/nsichneu",
 | 
			
		||||
    "bd_speedopt_speed/src/cubic/cubic", // cubic is likely going to removed when embench 2.0 launches
 | 
			
		||||
    "bd_speedopt_speed/src/aha-mont64/aha-mont64",
 | 
			
		||||
    "bd_speedopt_speed/src/crc32/crc32",
 | 
			
		||||
    "bd_speedopt_speed/src/edn/edn",
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user