mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Fixed forwarding around the 2 bit predictor.
This commit is contained in:
		
							parent
							
								
									d0223da2f7
								
							
						
					
					
						commit
						a8cd4f2b2e
					
				| @ -80,9 +80,8 @@ module BTBPredictor | |||||||
|   assign Valid = ValidBits[LookUpPCIndexQ]; |   assign Valid = ValidBits[LookUpPCIndexQ]; | ||||||
| 
 | 
 | ||||||
|   // the BTB contains the target address.
 |   // the BTB contains the target address.
 | ||||||
|   // *** future version may contain the instruction class, a tag or partial tag,
 |  | ||||||
|   // and other indirection branch data.
 |  | ||||||
|   // Another optimization may be using a PC relative address.
 |   // Another optimization may be using a PC relative address.
 | ||||||
|  |   // *** need to add forwarding.
 | ||||||
| 
 | 
 | ||||||
|   SRAM2P1R1W #(Depth, `XLEN+4) memory(.clk(clk), |   SRAM2P1R1W #(Depth, `XLEN+4) memory(.clk(clk), | ||||||
| 				      .reset(reset), | 				      .reset(reset), | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ module twoBitPredictor | |||||||
|   #(parameter int Depth = 10 |   #(parameter int Depth = 10 | ||||||
|     ) |     ) | ||||||
|   (input logic clk, |   (input logic clk, | ||||||
|    input logic reset, |    input logic 		   reset, | ||||||
|    input logic [`XLEN-1:0] LookUpPC, |    input logic [`XLEN-1:0] LookUpPC, | ||||||
|    output logic [1:0] 	   Prediction, |    output logic [1:0] 	   Prediction, | ||||||
|    // update
 |    // update
 | ||||||
| @ -42,6 +42,8 @@ module twoBitPredictor | |||||||
| 
 | 
 | ||||||
|   logic [Depth-1:0] 	   LookUpPCIndex, UpdatePCIndex; |   logic [Depth-1:0] 	   LookUpPCIndex, UpdatePCIndex; | ||||||
|   logic [1:0] 		   PredictionMemory; |   logic [1:0] 		   PredictionMemory; | ||||||
|  |   logic 		   DoForwarding, DoForwardingF; | ||||||
|  |   logic [1:0] 		   UpdatePredictionF; | ||||||
|    |    | ||||||
| 
 | 
 | ||||||
|   // hashing function for indexing the PC
 |   // hashing function for indexing the PC
 | ||||||
| @ -63,6 +65,20 @@ module twoBitPredictor | |||||||
| 				.BitWEN1(2'b11)); | 				.BitWEN1(2'b11)); | ||||||
| 
 | 
 | ||||||
|   // need to forward when updating to the same address as reading.
 |   // need to forward when updating to the same address as reading.
 | ||||||
|   assign Prediction = (UpdatePC == LookUpPC) ? UpdatePrediction : PredictionMemory; |   // first we compare to see if the update and lookup addreses are the same
 | ||||||
|  |   assign DoForwarding = UpdatePCIndex == LookUpPCIndex; | ||||||
|  | 
 | ||||||
|  |   // register the update value and the forwarding signal into the Fetch stage
 | ||||||
|  |   flopr #(1) DoForwardingReg(.clk(clk), | ||||||
|  | 			     .reset(reset), | ||||||
|  | 			     .d(DoForwarding), | ||||||
|  | 			     .q(DoForwardingF)); | ||||||
|  |    | ||||||
|  |   flopr #(2) UpdatePredictionReg(.clk(clk), | ||||||
|  | 				 .reset(reset), | ||||||
|  | 				 .d(UpdatePrediction), | ||||||
|  | 				 .q(UpdatePredictionF)); | ||||||
|  | 
 | ||||||
|  |   assign Prediction = DoForwardingF ? UpdatePredictionF : PredictionMemory; | ||||||
|    |    | ||||||
| endmodule | endmodule | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user