forked from Github_Repos/cvw
		
	Possibly working speculative global history.
This commit is contained in:
		
							parent
							
								
									0eda4b1ab3
								
							
						
					
					
						commit
						6cbce9672d
					
				| @ -604,7 +604,7 @@ add wave -noupdate /testbench/dut/core/ifu/bpred/bpred/Predictor/DirPredictor/Br | |||||||
| add wave -noupdate /testbench/dut/core/ifu/bpred/bpred/Predictor/DirPredictor/NewDirPredictionF | add wave -noupdate /testbench/dut/core/ifu/bpred/bpred/Predictor/DirPredictor/NewDirPredictionF | ||||||
| add wave -noupdate /testbench/dut/core/ifu/bpred/bpred/Predictor/DirPredictor/NewDirPredictionW | add wave -noupdate /testbench/dut/core/ifu/bpred/bpred/Predictor/DirPredictor/NewDirPredictionW | ||||||
| TreeUpdate [SetDefaultTree] | TreeUpdate [SetDefaultTree] | ||||||
| WaveRestoreCursors {{Cursor 2} {314596 ns} 1} {{Cursor 3} {314460 ns} 1} {{Cursor 4} {219681 ns} 1} {{Cursor 4} {341201 ns} 1} {{Cursor 5} {9616 ns} 0} | WaveRestoreCursors {{Cursor 2} {314596 ns} 1} {{Cursor 3} {314460 ns} 1} {{Cursor 4} {219681 ns} 1} {{Cursor 4} {341201 ns} 1} {{Cursor 5} {116741 ns} 0} | ||||||
| quietly wave cursor active 5 | quietly wave cursor active 5 | ||||||
| configure wave -namecolwidth 250 | configure wave -namecolwidth 250 | ||||||
| configure wave -valuecolwidth 194 | configure wave -valuecolwidth 194 | ||||||
| @ -620,4 +620,4 @@ configure wave -griddelta 40 | |||||||
| configure wave -timeline 0 | configure wave -timeline 0 | ||||||
| configure wave -timelineunits ns | configure wave -timelineunits ns | ||||||
| update | update | ||||||
| WaveRestoreZoom {9519 ns} {9917 ns} | WaveRestoreZoom {118528 ns} {128752 ns} | ||||||
|  | |||||||
| @ -97,7 +97,7 @@ module bpred ( | |||||||
|       .BranchInstrE(InstrClassE[0]), .BranchInstrM(InstrClassM[0]), .PCSrcE); |       .BranchInstrE(InstrClassE[0]), .BranchInstrM(InstrClassM[0]), .PCSrcE); | ||||||
| 
 | 
 | ||||||
|   end else if (`BPTYPE == "BPSPECULATIVEGLOBAL") begin:Predictor |   end else if (`BPTYPE == "BPSPECULATIVEGLOBAL") begin:Predictor | ||||||
|     speculativeglobalhistory #(5) DirPredictor(.clk, .reset, .StallF, .StallD, .StallE, .StallM, .StallW, .FlushD, .FlushE, .FlushM, .FlushW, |     speculativeglobalhistory #(10) DirPredictor(.clk, .reset, .StallF, .StallD, .StallE, .StallM, .StallW, .FlushD, .FlushE, .FlushM, .FlushW, | ||||||
|       .PCNextF, .PCF, .PCD, .PCE, .PCM, .DirPredictionF, .DirPredictionWrongE, |       .PCNextF, .PCF, .PCD, .PCE, .PCM, .DirPredictionF, .DirPredictionWrongE, | ||||||
|       .BranchInstrF(BPInstrClassF[0]), .BranchInstrD(BPInstrClassD[0]), .BranchInstrE(InstrClassE[0]), .BranchInstrM(InstrClassM[0]), |       .BranchInstrF(BPInstrClassF[0]), .BranchInstrD(BPInstrClassD[0]), .BranchInstrE(InstrClassE[0]), .BranchInstrM(InstrClassM[0]), | ||||||
|       .BranchInstrW(InstrClassW[0]), .PCSrcE); |       .BranchInstrW(InstrClassW[0]), .PCSrcE); | ||||||
|  | |||||||
| @ -79,7 +79,7 @@ module speculativeglobalhistory | |||||||
|   assign MatchD = BranchInstrD & ~FlushE & (GHRNextF == GHRD[k-1:0]); |   assign MatchD = BranchInstrD & ~FlushE & (GHRNextF == GHRD[k-1:0]); | ||||||
|   assign MatchE = BranchInstrE & ~FlushM & (GHRNextF == GHRE[k-1:0]); |   assign MatchE = BranchInstrE & ~FlushM & (GHRNextF == GHRE[k-1:0]); | ||||||
|   assign MatchM = BranchInstrM & ~FlushW & (GHRNextF == GHRM[k-1:0]); |   assign MatchM = BranchInstrM & ~FlushW & (GHRNextF == GHRM[k-1:0]); | ||||||
|   assign MatchW = BranchInstrW & (GHRNextF == GHRM[k-1:0]); |   assign MatchW = BranchInstrW & (GHRNextF == GHRW[k-1:0]); | ||||||
|   assign MatchNextX = MatchF | MatchD | MatchE | MatchM | MatchW; |   assign MatchNextX = MatchF | MatchD | MatchE | MatchM | MatchW; | ||||||
| 
 | 
 | ||||||
|   flopenr #(1) MatchReg(clk, reset, ~StallF, MatchNextX, MatchXF); |   flopenr #(1) MatchReg(clk, reset, ~StallF, MatchNextX, MatchXF); | ||||||
|  | |||||||
| @ -83,6 +83,7 @@ one_6: | |||||||
| 	addi t3, t3, 1		 | 	addi t3, t3, 1		 | ||||||
| 	addi t3, t3, 1		 | 	addi t3, t3, 1		 | ||||||
| 	addi t3, t3, 1		 | 	addi t3, t3, 1		 | ||||||
|  | 	addi t3, t3, 1		 | ||||||
| 	addi t2, t2, -1 | 	addi t2, t2, -1 | ||||||
| 	bnez t2, loop_6 | 	bnez t2, loop_6 | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user