Hold off first instruction fetch until pwrup_ack is first seen high
This commit is contained in:
		
							parent
							
								
									dff278ea05
								
							
						
					
					
						commit
						97bf2d06f6
					
				|  | @ -1 +1,2 @@ | ||||||
| .DS_Store | .DS_Store | ||||||
|  | *.todo | ||||||
|  |  | ||||||
|  | @ -162,6 +162,7 @@ hazard3_frontend #( | ||||||
| 	.cir_flush_behind     (df_cir_flush_behind), | 	.cir_flush_behind     (df_cir_flush_behind), | ||||||
| 
 | 
 | ||||||
| 	.pwrdown_ok           (f_frontend_pwrdown_ok), | 	.pwrdown_ok           (f_frontend_pwrdown_ok), | ||||||
|  | 	.delay_first_fetch    (!pwrup_ack), | ||||||
| 
 | 
 | ||||||
| 	.predecode_rs1_coarse (f_rs1_coarse), | 	.predecode_rs1_coarse (f_rs1_coarse), | ||||||
| 	.predecode_rs2_coarse (f_rs2_coarse), | 	.predecode_rs2_coarse (f_rs2_coarse), | ||||||
|  |  | ||||||
|  | @ -68,6 +68,9 @@ module hazard3_frontend #( | ||||||
| 	// waits for the frontend to naturally come to a halt before releasing | 	// waits for the frontend to naturally come to a halt before releasing | ||||||
| 	// its power request. This avoids manually halting the frontend.) | 	// its power request. This avoids manually halting the frontend.) | ||||||
| 	output wire              pwrdown_ok, | 	output wire              pwrdown_ok, | ||||||
|  | 	// Signal to delay the first instruction fetch following reset, because | ||||||
|  | 	// powerup has not yet been negotiated. | ||||||
|  | 	input  wire              delay_first_fetch, | ||||||
| 
 | 
 | ||||||
| 	// Provide the rs1/rs2 register numbers which will be in CIR next cycle. | 	// Provide the rs1/rs2 register numbers which will be in CIR next cycle. | ||||||
| 	// Coarse: valid if this instruction has a nonzero register operand. | 	// Coarse: valid if this instruction has a nonzero register operand. | ||||||
|  | @ -284,7 +287,7 @@ always @ (posedge clk or negedge rst_n) begin | ||||||
| 	if (!rst_n) begin | 	if (!rst_n) begin | ||||||
| 		reset_holdoff <= 1'b1; | 		reset_holdoff <= 1'b1; | ||||||
| 	end else begin | 	end else begin | ||||||
| 		reset_holdoff <= 1'b0; | 		reset_holdoff <= (|EXTENSION_XH3POWER && delay_first_fetch) ? reset_holdoff : 1'b0; | ||||||
| 		// This should be impossible, but assert to be sure, because it *will* | 		// This should be impossible, but assert to be sure, because it *will* | ||||||
| 		// change the fetch address (and we shouldn't check it in hardware if | 		// change the fetch address (and we shouldn't check it in hardware if | ||||||
| 		// we can prove it doesn't happen) | 		// we can prove it doesn't happen) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue