Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
VAMS-LRM-2-3-1.pdf
Скачиваний:
43
Добавлен:
05.06.2015
Размер:
3.73 Mб
Скачать

Accellera

 

Version 2.3.1, June 1, 2009

VERILOG-AMS

edge_descriptor2 ::=

01 | 10

| z_or_x zero_or_one | zero_or_one z_or_x

zero_or_one ::= 0 | 1 z_or_x ::= x | X | z | Z

timing_check_condition ::= scalar_timing_check_condition

| ( scalar_timing_check_condition )

scalar_timing_check_condition ::= expression

| ~ expression

| expression == scalar_constant | expression === scalar_constant | expression != scalar_constant | expression !== scalar_constant

scalar_constant ::=

1'b0 | 1'b1 | 1'B0 | 1'B1 | 'b0 | 'b1 | 'B0 | 'B1 | 1 | 0

A.8 Expressions

A.8.1 Concatenations

analog_concatenation ::= { analog_expression { , analog_expression } } analog_multiple_concatenation ::= { constant_expression analog_concatenation }

analog_filter_function_arg ::= parameter_identifier

| parameter_identifier [ msb_constant_expression : lsb_constant_expression ] | constant_optional_arrayinit

concatenation ::= { expression { , expression } }

constant_concatenation ::= { constant_expression { , constant_expression } } constant_multiple_concatenation ::= { constant_expression constant_concatenation } module_path_concatenation ::= { module_path_expression { , module_path_expression } } module_path_multiple_concatenation ::= { constant_expression module_path_concatenation } multiple_concatenation ::= { constant_expression concatenation }

constant_arrayinit ::= '{ constant_expression { , constant_expression } } constant_optional_arrayinit ::= '{ [ constant_expression ] { , [ constant_expression ] } }

A.8.2 Function calls

analog_function_call ::=

analog_function_identifier { attribute_instance } ( analog_expression { , analog_expression } )

analog_system_function_call ::=

analog_system_function_identifier [ ( [ analog_expression ] { , [ analog_expression ] } ) ]

analog_built_in_function_call ::=

analog_built_in_function_name ( analog_expression [ , analog_expression ] )

Copyright © 2009 Accellera Organization, Inc.

346

 

Accellera

Analog and Mixed-signal Extensions to Verilog HDL

Version 2.3.1, June 1, 2009

analog_built_in_function_name ::=

ln | log | exp | sqrt | min | max | abs | pow | floor | ceil | sin | cos | tan | asin | acos | atan | atan2

| hypot | sinh | cosh | tanh | asinh | acosh | atanh

analysis_function_call ::= analysis ( " analysis_identifier " { , " analysis_identifier " } )

analog_filter_function_call ::=

ddt ( analog_expression [ , abstol_expression ] )

| ddx ( analog_expression , branch_probe_function_call )

| idt ( analog_expression [ , analog_expression [ , analog_expression [ , abstol_expression ] ] ] ) | idtmod ( analog_expression [ , analog_expression [ , analog_expression [ , analog_expression

[ , abstol_expression ] ] ] ] )

| absdelay ( analog_expression , analog_expression [ , constant_expression ] ) | transition ( analog_expression [ , analog_expression [ , analog_expression

[ , analog_expression [ , constant_expression ] ] ] ] )

| slew ( analog_expression [ , analog_expression [ , analog_expression ] ] ) | last_crossing ( analog_expression [ , analog_expression ] )

| limexp ( analog_expression )

| laplace_filter_name ( analog_expression , [ analog_filter_function_arg ] , [ analog_filter_function_arg ] [ , constant_expression ] )

| zi_filter_name ( analog_expression , [ analog_filter_function_arg ] , [ analog_filter_function_arg ] , constant_expression

[ , analog_expression [ , constant_expression ] ] )

analog_small_signal_function_call ::=

ac_stim ( [ " analysis_identifier " [ , analog_expression [ , analog_expression ] ] ] ) | white_noise ( analog_expression [ , string ] )

| flicker_noise ( analog_expression , analog_expression [ , string ] ) | noise_table ( noise_table_input_arg [ , string ] )

noise_table_input_arg ::= parameter_identifier

| parameter_identifier [ msb_constant_expression : lsb_constant_expression ] | string

| constant_arrayinit

laplace_filter_name ::= laplace_zd | laplace_zp | laplace_np | laplace_nd zi_filter_name ::= zi_zp | zi_zd | zi_np | zi_nd

branch_probe_function_call ::= nature_attribute_identifier ( branch_reference )

| nature_attribute_identifier ( analog_net_reference [ , analog_net_reference ] ) port_probe_function_call ::= nature_attribute_identifier ( < analog_port_reference > )

constant_analog_function_call ::=

analog_function_identifier { attribute_instance } ( constant_expression { , constant_expression } )

constant_function_call ::= function_identifier { attribute_instance } ( constant_expression { , constant_expression } )

constant_system_function_call ::= system_function_identifier ( constant_expression { , constant_expression } )

constant_analog_built_in_function_call ::=

analog_built_in_function_name ( constant_expression [ , constant_expression ] )

function_call ::= hierarchical_function_identifier{ attribute_instance } ( expression { , expression } )

system_function_call ::= system_function_identifier [ ( expression { , expression } ) ]

347

Copyright © 2009 Accellera Organization, Inc. All rights reserved.

Accellera

 

Version 2.3.1, June 1, 2009

VERILOG-AMS

A.8.3 Expressions

abstol_expression ::= constant_expression

| nature_identifier

analog_conditional_expression ::=

analog_expression ? { attribute_instance } analog_expression : analog_expression

analog_range_expression ::= analog_expression

| msb_constant_expression : lsb_constant_expression analog_expression_or_null ::= [ analog_expression ]

analog_expression ::= analog_primary

| unary_operator { attribute_instance } analog_primary

| analog_expression binary_operator { attribute_instance } analog_expression | analog_conditional_expression

| string

base_expression ::= expression

conditional_expression ::= expression1 ? { attribute_instance } expression2 : expression3 constant_base_expression ::= constant_expression

constant_expression_or_null ::= [ constant_expression ]

constant_expression ::= constant_primary

| unary_operator { attribute_instance } constant_primary

| constant_expression binary_operator { attribute_instance } constant_expression

| constant_expression ? { attribute_instance } constant_expression : constant_expression

analysis_or_constant_expression ::= constant_primary

| analysis_function_call

| unary_operator { attribute_instance } analysis_or_constant_primary

| analysis_or_constant_expression binary_operator { attribute_instance } analysis_constant_expression

| analysis_or_constant_expression ? { attribute_instance } analysis_or_constant_expression : analysis_or_constant_expression

constant_mintypmax_expression ::= constant_expression

| constant_expression : constant_expression : constant_expression

constant_range_expression ::= constant_expression

| msb_constant_expression : lsb_constant_expression

| constant_base_expression +: width_constant_expression | constant_base_expression -: width_constant_expression

dimension_constant_expression ::= constant_expression

expression ::= primary

| unary_operator { attribute_instance } primary

| expression binary_operator { attribute_instance } expression | conditional_expression

expression1 ::= expression expression2 ::= expression

Copyright © 2009 Accellera Organization, Inc.

348

 

Accellera

Analog and Mixed-signal Extensions to Verilog HDL

Version 2.3.1, June 1, 2009

expression3 ::= expression

indirect_expression ::= branch_probe_function_call

| port_probe_function_call

| ddt ( branch_probe_function_call [ , abstol_expression ] ) | ddt ( port_probe_function_call [ , abstol_expression ] )

| idt ( branch_probe_function_call [ , analog_expression [ , analog_expression [ , abstol_expression ] ] ] )

| idt ( port_probe_function_call [ , analog_expression [ , analog_expression [ , abstol_expression ] ] ] )

| idtmod ( branch_probe_function_call [ , analog_expression [ , analog_expression [ , analog_expression [ , abstol_expression ] ] ] ] )

| idtmod ( port_probe_function_call [ , analog_expression [ , analog_expression [ , analog_expression [ , abstol_expression ] ] ] ] )

lsb_constant_expression ::= constant_expression

mintypmax_expression ::= expression

| expression : expression : expression

module_path_conditional_expression ::= module_path_expression ? { attribute_instance } module_path_expression : module_path_expression

module_path_expression ::= module_path_primary

| unary_module_path_operator { attribute_instance } module_path_primary

| module_path_expression binary_module_path_operator { attribute_instance } module_path_expression

| module_path_conditional_expression

module_path_mintypmax_expression ::= module_path_expression

| module_path_expression : module_path_expression : module_path_expression msb_constant_expression ::= constant_expression

nature_attribute_expression ::= constant_expression

| nature_identifier

| nature_access_identifier

range_expression ::= expression

| msb_constant_expression : lsb_constant_expression | base_expression +: width_constant_expression

| base_expression -: width_constant_expression width_constant_expression ::= constant_expression

A.8.4 Primaries

analog_primary ::= number

| analog_concatenation

| analog_multiple_concatenation | variable_reference

| net_reference

| genvar_identifier

| parameter_reference

349

Copyright © 2009 Accellera Organization, Inc. All rights reserved.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]