diff options
| author | Eddie Hung <eddie@fpgeh.com> | 2019-07-08 10:46:08 -0700 | 
|---|---|---|
| committer | Eddie Hung <eddie@fpgeh.com> | 2019-07-08 10:46:08 -0700 | 
| commit | c71ad5482ed27eed361b95e4d99eacdec91e0694 (patch) | |
| tree | 4d64bbffc199cd53edde9baf78d54dff5be97b4b /frontends/verilog | |
| parent | c35023d0bf25fc12b09dea6b43ca28639b710078 (diff) | |
| parent | 030483ffb909ab38e10d437d09ec922cb0ad2ce8 (diff) | |
| download | yosys-c71ad5482ed27eed361b95e4d99eacdec91e0694.tar.gz yosys-c71ad5482ed27eed361b95e4d99eacdec91e0694.tar.bz2 yosys-c71ad5482ed27eed361b95e4d99eacdec91e0694.zip | |
Merge remote-tracking branch 'origin/master' into xc7mux
Diffstat (limited to 'frontends/verilog')
| -rw-r--r-- | frontends/verilog/verilog_parser.y | 95 | 
1 files changed, 14 insertions, 81 deletions
| diff --git a/frontends/verilog/verilog_parser.y b/frontends/verilog/verilog_parser.y index d89b2dc88..0fec445fa 100644 --- a/frontends/verilog/verilog_parser.y +++ b/frontends/verilog/verilog_parser.y @@ -1021,13 +1021,8 @@ list_of_specparam_assignments:  specparam_assignment:  	ignspec_id '=' constant_mintypmax_expression ; -/* -pulsestyle_declaration : -	; - -showcancelled_declaration : -	; -*/ +ignspec_opt_cond: +	TOK_IF '(' ignspec_expr ')' | /* empty */;  path_declaration :  	simple_path_declaration ';' @@ -1036,8 +1031,8 @@ path_declaration :  	;  simple_path_declaration : -	parallel_path_description '=' path_delay_value | -	full_path_description '=' path_delay_value +	ignspec_opt_cond parallel_path_description '=' path_delay_value | +	ignspec_opt_cond full_path_description '=' path_delay_value  	;  path_delay_value : @@ -1047,32 +1042,20 @@ path_delay_value :  	;  list_of_path_delay_extra_expressions : -/* -	t_path_delay_expression -	| trise_path_delay_expression ',' tfall_path_delay_expression -	| trise_path_delay_expression ',' tfall_path_delay_expression ',' tz_path_delay_expression -	| t01_path_delay_expression ',' t10_path_delay_expression ',' t0z_path_delay_expression ',' -	  tz1_path_delay_expression ',' t1z_path_delay_expression ',' tz0_path_delay_expression -	| t01_path_delay_expression ',' t10_path_delay_expression ',' t0z_path_delay_expression ',' -	  tz1_path_delay_expression ',' t1z_path_delay_expression ',' tz0_path_delay_expression ',' -	  t0x_path_delay_expression ',' tx1_path_delay_expression ',' t1x_path_delay_expression ',' -	  tx0_path_delay_expression ',' txz_path_delay_expression ',' tzx_path_delay_expression -*/ -	',' path_delay_expression -	|  ',' path_delay_expression ',' path_delay_expression -	|  ',' path_delay_expression ',' path_delay_expression ',' -	  path_delay_expression ',' path_delay_expression ',' path_delay_expression -	|  ',' path_delay_expression ',' path_delay_expression ',' -	  path_delay_expression ',' path_delay_expression ',' path_delay_expression ',' -	  path_delay_expression ',' path_delay_expression ',' path_delay_expression ',' -	  path_delay_expression ',' path_delay_expression ',' path_delay_expression -	; +	',' path_delay_expression | ',' path_delay_expression list_of_path_delay_extra_expressions; + +specify_edge_identifier : +	TOK_POSEDGE | TOK_NEGEDGE ;  parallel_path_description : -	'(' specify_input_terminal_descriptor opt_polarity_operator '=' '>' specify_output_terminal_descriptor ')' ; +	'(' specify_input_terminal_descriptor opt_polarity_operator '=' '>' specify_output_terminal_descriptor ')' | +	'(' specify_edge_identifier specify_input_terminal_descriptor '=' '>' '(' specify_output_terminal_descriptor opt_polarity_operator ':' ignspec_expr ')' ')' | +	'(' specify_edge_identifier specify_input_terminal_descriptor '=' '>' '(' specify_output_terminal_descriptor TOK_POS_INDEXED ignspec_expr ')' ')' ;  full_path_description : -	'(' list_of_path_inputs '*' '>' list_of_path_outputs ')' ; +	'(' list_of_path_inputs '*' '>' list_of_path_outputs ')' | +	'(' specify_edge_identifier list_of_path_inputs '*' '>' '(' list_of_path_outputs opt_polarity_operator ':' ignspec_expr ')' ')' | +	'(' specify_edge_identifier list_of_path_inputs '*' '>' '(' list_of_path_outputs TOK_POS_INDEXED ignspec_expr ')' ')' ;  // This was broken into 2 rules to solve shift/reduce conflicts  list_of_path_inputs : @@ -1112,56 +1095,6 @@ system_timing_args :  	system_timing_arg |  	system_timing_args ',' system_timing_arg ; -/* -t_path_delay_expression : -	path_delay_expression; - -trise_path_delay_expression : -	path_delay_expression; - -tfall_path_delay_expression : -	path_delay_expression; - -tz_path_delay_expression : -	path_delay_expression; - -t01_path_delay_expression : -	path_delay_expression; - -t10_path_delay_expression : -	path_delay_expression; - -t0z_path_delay_expression : -	path_delay_expression; - -tz1_path_delay_expression : -	path_delay_expression; - -t1z_path_delay_expression : -	path_delay_expression; - -tz0_path_delay_expression : -	path_delay_expression; - -t0x_path_delay_expression : -	path_delay_expression; - -tx1_path_delay_expression : -	path_delay_expression; - -t1x_path_delay_expression : -	path_delay_expression; - -tx0_path_delay_expression : -	path_delay_expression; - -txz_path_delay_expression : -	path_delay_expression; - -tzx_path_delay_expression : -	path_delay_expression; -*/ -  path_delay_expression :  	ignspec_constant_expression; | 
