mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	If a local variable is always assigned before it is used, then adding nosync prevents latches from being needlessly generated.
		
			
				
	
	
		
			20 lines
		
	
	
	
		
			335 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
	
		
			335 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| read_verilog -sv <<EOF
 | |
| module top;
 | |
| logic x;
 | |
| logic z;
 | |
| assign z = 1'b1;
 | |
| always_comb begin
 | |
|     logic y;
 | |
|     case (x)
 | |
|     1'b0:
 | |
|         y = 1;
 | |
|     endcase
 | |
|     if (z)
 | |
|         x = y;
 | |
|     else
 | |
|         x = 1'b0;
 | |
| end
 | |
| endmodule
 | |
| EOF
 | |
| logger -expect error "^Latch inferred for signal `\\top\.\$unnamed_block\$1\.y' from always_comb process" 1
 | |
| proc
 |