mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-10-26 09:24:37 +00:00 
			
		
		
		
	Add support to the "read_verilog -sv" parser to validate the
"unique", "unique0", and "priority" keywords in contexts where
they're legal according to 1800-2012 12.4.2.
This affects only the grammar accepted; the behaviour of conditionals
is not changed.  (But accepting this syntax will provide scope for
possible optimisations as future work.)
Three test cases ("unique_if", "unique_if_else", and
"unique_if_else_begin") verify that the keywords are accepted where
legal and rejected where illegal, as described in the final paragraph
of 12.4.2.
		
	
			
		
			
				
	
	
		
			11 lines
		
	
	
	
		
			340 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			11 lines
		
	
	
	
		
			340 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| logger -expect error "unique keyword cannot be used for 'else if' branch" 1
 | |
| read_verilog -sv <<EOF
 | |
| module top( input[2:0] a );
 | |
| always_comb begin
 | |
|     // invalid example from 1800-2012 12.4.2
 | |
|     unique if ((a==0) || (a==1)) $display("0 or 1");
 | |
|     else unique if (a == 2) $display("2");
 | |
|     else if (a == 4) $display("4");
 | |
| end
 | |
| endmodule
 | |
| EOF
 |