Utility and Field Macros for Components and Objects | |
Utility Macros | The utility macros provide implementations of the uvm_object::create method, which is needed for cloning, and the uvm_object::get_type_name method, which is needed for a number of debugging features. |
`uvm_field_utils_begin | |
`uvm_field_utils_end | These macros form a block in which `uvm_field_* macros can be placed. |
`uvm_object_utils | |
`uvm_object_param_utils | |
`uvm_object_utils_begin | |
`uvm_object_param_utils_begin | |
`uvm_object_utils_end | uvm_object-based class declarations may contain one of the above forms of utility macros. |
`uvm_component_utils | |
`uvm_component_param_utils | |
`uvm_component_utils_begin | |
`uvm_component_param_utils_begin | |
`uvm_component_end | uvm_component-based class declarations may contain one of the above forms of utility macros. |
`uvm_object_registry | Register a uvm_object-based class with the factory |
`uvm_component_registry | Registers a uvm_component-based class with the factory |
Field Macros | The `uvm_field_* macros are invoked inside of the `uvm_*_utils_begin and `uvm_*_utils_end macro blocks to form “automatic” implementations of the core data methods: copy, compare, pack, unpack, record, print, and sprint. |
`uvm_field_* macros | Macros that implement data operations for scalar properties. |
`uvm_field_int | Implements the data operations for any packed integral property. |
`uvm_field_object | Implements the data operations for an uvm_object-based property. |
`uvm_field_string | Implements the data operations for a string property. |
`uvm_field_enum | Implements the data operations for an enumerated property. |
`uvm_field_real | Implements the data operations for any real property. |
`uvm_field_event | Implements the data operations for an event property. |
`uvm_field_sarray_* macros | Macros that implement data operations for one-dimensional static array properties. |
`uvm_field_sarray_int | Implements the data operations for a one-dimensional static array of integrals. |
`uvm_field_sarray_object | Implements the data operations for a one-dimensional static array of uvm_object-based objects. |
`uvm_field_sarray_string | Implements the data operations for a one-dimensional static array of strings. |
`uvm_field_sarray_enum | Implements the data operations for a one-dimensional static array of enums. |
`uvm_field_array_* macros | Macros that implement data operations for one-dimensional dynamic array properties. |
`uvm_field_array_int | Implements the data operations for a one-dimensional dynamic array of integrals. |
`uvm_field_array_object | Implements the data operations for a one-dimensional dynamic array of uvm_object-based objects. |
`uvm_field_array_string | Implements the data operations for a one-dimensional dynamic array of strings. |
`uvm_field_array_enum | Implements the data operations for a one-dimensional dynamic array of enums. |
`uvm_field_queue_* macros | Macros that implement data operations for dynamic queues. |
`uvm_field_queue_int | Implements the data operations for a queue of integrals. |
`uvm_field_queue_object | Implements the data operations for a queue of uvm_object-based objects. |
`uvm_field_queue_string | Implements the data operations for a queue of strings. |
`uvm_field_queue_enum | Implements the data operations for a one-dimensional queue of enums. |
`uvm_field_aa_*_string macros | Macros that implement data operations for associative arrays indexed by string. |
`uvm_field_aa_int_string | Implements the data operations for an associative array of integrals indexed by string. |
`uvm_field_aa_object_string | Implements the data operations for an associative array of uvm_object-based objects indexed by string. |
`uvm_field_aa_string_string | Implements the data operations for an associative array of strings indexed by string. |
`uvm_field_aa_*_int macros | Macros that implement data operations for associative arrays indexed by an integral type. |
`uvm_field_aa_object_int | Implements the data operations for an associative array of uvm_object-based objects indexed by the int data type. |
`uvm_field_aa_int_int | Implements the data operations for an associative array of integral types indexed by the int data type. |
`uvm_field_aa_int_int_unsigned | Implements the data operations for an associative array of integral types indexed by the int unsigned data type. |
`uvm_field_aa_int_integer | Implements the data operations for an associative array of integral types indexed by the integer data type. |
`uvm_field_aa_int_integer_unsigned | Implements the data operations for an associative array of integral types indexed by the integer unsigned data type. |
`uvm_field_aa_int_byte | Implements the data operations for an associative array of integral types indexed by the byte data type. |
`uvm_field_aa_int_byte_unsigned | Implements the data operations for an associative array of integral types indexed by the byte unsigned data type. |
`uvm_field_aa_int_shortint | Implements the data operations for an associative array of integral types indexed by the shortint data type. |
`uvm_field_aa_int_shortint_unsigned | Implements the data operations for an associative array of integral types indexed by the shortint unsigned data type. |
`uvm_field_aa_int_longint | Implements the data operations for an associative array of integral types indexed by the longint data type. |
`uvm_field_aa_int_longint_unsigned | Implements the data operations for an associative array of integral types indexed by the longint unsigned data type. |
`uvm_field_aa_int_key | Implements the data operations for an associative array of integral types indexed by any integral key data type. |
`uvm_field_aa_int_enumkey | Implements the data operations for an associative array of integral types indexed by any enumeration key data type. |
Recording Macros | The recording macros assist users who implement the uvm_object::do_record method. |
`uvm_record_attribute | Vendor-independent macro for recording attributes (fields) to a vendor-specific transaction database. |
`uvm_record_field | Macro for recording name-value pairs into a transaction recording database. |
Packing Macros | The packing macros assist users who implement the uvm_object::do_pack method. |
Packing - With Size Info | |
`uvm_pack_intN | Pack an integral variable. |
`uvm_pack_enumN | Pack an integral variable. |
`uvm_pack_sarrayN | Pack a static array of integrals. |
`uvm_pack_arrayN | Pack a dynamic array of integrals. |
`uvm_pack_queueN | Pack a queue of integrals. |
Packing - No Size Info | |
`uvm_pack_int | Pack an integral variable without having to also specify the bit size. |
`uvm_pack_enum | Pack an enumeration value. |
`uvm_pack_string | Pack a string variable. |
`uvm_pack_real | Pack a variable of type real. |
`uvm_pack_sarray | Pack a static array without having to also specify the bit size of its elements. |
`uvm_pack_array | Pack a dynamic array without having to also specify the bit size of its elements. |
`uvm_pack_queue | Pack a queue without having to also specify the bit size of its elements. |
Unpacking Macros | The unpacking macros assist users who implement the uvm_object::do_unpack method. |
Unpacking - With Size Info | |
`uvm_unpack_intN | Unpack into an integral variable. |
`uvm_unpack_enumN | Unpack enum of type TYPE into VAR. |
`uvm_unpack_sarrayN | Unpack a static (fixed) array of integrals. |
`uvm_unpack_arrayN | Unpack into a dynamic array of integrals. |
`uvm_unpack_queueN | Unpack into a queue of integrals. |
Unpacking - No Size Info | |
`uvm_unpack_int | Unpack an integral variable without having to also specify the bit size. |
`uvm_unpack_enum | Unpack an enumeration value, which requires its type be specified. |
`uvm_unpack_string | Pack a string variable. |
`uvm_unpack_real | Unpack a variable of type real. |
`uvm_unpack_sarray | Unpack a static array without having to also specify the bit size of its elements. |
`uvm_unpack_array | Unpack a dynamic array without having to also specify the bit size of its elements. |
`uvm_unpack_queue | Unpack a queue without having to also specify the bit size of its elements. |
The utility macros provide implementations of the uvm_object::create method, which is needed for cloning, and the uvm_object::get_type_name method, which is needed for a number of debugging features. They also register the type with the uvm_factory, and they implement a get_type method, which is used when configuring the factory. And they implement the virtual uvm_object::get_object_type method for accessing the factory proxy of an allocated object.
Below is an example usage of the utility and field macros. By using the macros, you do not have to implement any of the data methods to get all of the capabilities of an uvm_object.
class mydata extends uvm_object; string str; mydata subdata; int field; myenum e1; int queue[$]; `uvm_object_utils_begin(mydata) //requires ctor with default args `uvm_field_string(str, UVM_DEFAULT) `uvm_field_object(subdata, UVM_DEFAULT) `uvm_field_int(field, UVM_DEC) //use decimal radix `uvm_field_enum(myenum, e1, UVM_DEFAULT) `uvm_field_queue_int(queue, UVM_DEFAULT) `uvm_object_utils_end endclass
These macros form a block in which `uvm_field_* macros can be placed. Used as
`uvm_field_utils_begin(TYPE) `uvm_field_* macros here `uvm_field_utils_end
These macros do NOT perform factory registration, implement get_type_name, nor implement the create method. Use this form when you need custom implementations of these two methods, or when you are setting up field macros for an abstract class (i.e. virtual class).
uvm_object-based class declarations may contain one of the above forms of utility macros.
For simple objects with no field macros, use
`uvm_object_utils(TYPE)
For simple objects with field macros, use
`uvm_object_utils_begin(TYPE) `uvm_field_* macro invocations here `uvm_object_utils_end
For parameterized objects with no field macros, use
`uvm_object_param_utils(TYPE)
For parameterized objects, with field macros, use
`uvm_object_param_utils_begin(TYPE) `uvm_field_* macro invocations here `uvm_object_utils_end
Simple (non-parameterized) objects use the uvm_object_utils* versions, which do the following:
Parameterized classes must use the uvm_object_param_utils* versions. They differ from `uvm_object_utils only in that they do not supply a type name when registering the object with the factory. As such, name-based lookup with the factory for parameterized classes is not possible.
The macros with _begin suffixes are the same as the non-suffixed versions except that they also start a block in which `uvm_field_* macros can be placed. The block must be terminated by `uvm_object_utils_end.
Objects deriving from uvm_sequence must use the `uvm_sequence_* macros instead of these macros. See <`uvm_sequence_utils> for details.
uvm_component-based class declarations may contain one of the above forms of utility macros.
For simple components with no field macros, use
`uvm_component_utils(TYPE)
For simple components with field macros, use
`uvm_component_utils_begin(TYPE) `uvm_field_* macro invocations here `uvm_component_utils_end
For parameterized components with no field macros, use
`uvm_component_param_utils(TYPE)
For parameterized components with field macros, use
`uvm_component_param_utils_begin(TYPE) `uvm_field_* macro invocations here `uvm_component_utils_end
Simple (non-parameterized) components must use the uvm_components_utils* versions, which do the following:
Parameterized classes must use the uvm_object_param_utils* versions. They differ from `uvm_object_utils only in that they do not supply a type name when registering the object with the factory. As such, name-based lookup with the factory for parameterized classes is not possible.
The macros with _begin suffixes are the same as the non-suffixed versions except that they also start a block in which `uvm_field_* macros can be placed. The block must be terminated by `uvm_component_utils_end.
Register a uvm_object-based class with the factory
`uvm_object_registry(T,S)
Registers a uvm_object-based class T and lookup string S with the factory. S typically is the name of the class in quotes. The `uvm_object_utils family of macros uses this macro.
Registers a uvm_component-based class with the factory
`uvm_component_registry(T,S)
Registers a uvm_component-based class T and lookup string S with the factory. S typically is the name of the class in quotes. The `uvm_object_utils family of macros uses this macro.
The `uvm_field_* macros are invoked inside of the `uvm_*_utils_begin and `uvm_*_utils_end macro blocks to form “automatic” implementations of the core data methods: copy, compare, pack, unpack, record, print, and sprint. For example:
class my_trans extends uvm_transaction; string my_string; `uvm_object_utils_begin(my_trans) `uvm_field_string(my_string, UVM_ALL_ON) `uvm_object_utils_end endclass
Each `uvm_field_* macro is named to correspond to a particular data type: integrals, strings, objects, queues, etc., and each has at least two arguments: ARG and FLAG.
ARG is the instance name of the variable, whose type must be compatible with the macro being invoked. In the example, class variable my_string is of type string, so we use the `uvm_field_string macro.
If FLAG is set to UVM_ALL_ON, as in the example, the ARG variable will be included in all data methods. The FLAG, if set to something other than UVM_ALL_ON or UVM_DEFAULT, specifies which data method implementations will NOT include the given variable. Thus, if FLAG is specified as NO_COMPARE, the ARG variable will not affect comparison operations, but it will be included in everything else.
All possible values for FLAG are listed and described below. Multiple flag values can be bitwise ORed together (in most cases they may be added together as well, but care must be taken when using the + operator to ensure that the same bit is not added more than once).
UVM_ALL_ON | Set all operations on (default). |
UVM_DEFAULT | Use the default flag settings. |
UVM_NOCOPY | Do not copy this field. |
UVM_NOCOMPARE | Do not compare this field. |
UVM_NOPRINT | Do not print this field. |
UVM_NODEFPRINT | Do not print the field if it is the same as its |
UVM_NOPACK | Do not pack or unpack this field. |
UVM_PHYSICAL | Treat as a physical field. Use physical setting in policy class for this field. |
UVM_ABSTRACT | Treat as an abstract field. Use the abstract setting in the policy class for this field. |
UVM_READONLY | Do not allow setting of this field from the set_*_local methods. |
A radix for printing and recording can be specified by OR’ing one of the following constants in the FLAG argument
UVM_BIN | Print / record the field in binary (base-2). |
UVM_DEC | Print / record the field in decimal (base-10). |
UVM_UNSIGNED | Print / record the field in unsigned decimal (base-10). |
UVM_OCT | Print / record the field in octal (base-8). |
UVM_HEX | Print / record the field in hexidecimal (base-16). |
UVM_STRING | Print / record the field in string format. |
UVM_TIME | Print / record the field in time format. |
Radix settings for integral types. Hex is the default radix if none is specified.
Macros that implement data operations for scalar properties.
Implements the data operations for any packed integral property.
`uvm_field_int(ARG,FLAG)
ARG is an integral property of the class, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an uvm_object-based property.
`uvm_field_object(ARG,FLAG)
ARG is an object property of the class, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a string property.
`uvm_field_string(ARG,FLAG)
ARG is a string property of the class, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an enumerated property.
`uvm_field_enum(T,ARG,FLAG)
T is an enumerated type, ARG is an instance of that type, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for any real property.
`uvm_field_real(ARG,FLAG)
ARG is an real property of the class, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an event property.
`uvm_field_event(ARG,FLAG)
ARG is an event property of the class, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Macros that implement data operations for one-dimensional static array properties.
Implements the data operations for a one-dimensional static array of integrals.
`uvm_field_sarray_int(ARG,FLAG)
ARG is a one-dimensional static array of integrals, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional static array of uvm_object-based objects.
`uvm_field_sarray_object(ARG,FLAG)
ARG is a one-dimensional static array of uvm_object-based objects, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional static array of strings.
`uvm_field_sarray_string(ARG,FLAG)
ARG is a one-dimensional static array of strings, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional static array of enums.
`uvm_field_sarray_enum(T,ARG,FLAG)
T is a one-dimensional dynamic array of enums type, ARG is an instance of that type, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Macros that implement data operations for one-dimensional dynamic array properties.
lines flagged with empty multi-line comments, /**/, are not needed or need to be different for fixed arrays, which can not be resized. Fixed arrays do not need to pack/unpack their size either, because their size is known; wouldn’t hurt though if it allowed code consolidation. Unpacking would necessarily be different. */
Implements the data operations for a one-dimensional dynamic array of integrals.
`uvm_field_array_int(ARG,FLAG)
ARG is a one-dimensional dynamic array of integrals, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional dynamic array of uvm_object-based objects.
`uvm_field_array_object(ARG,FLAG)
ARG is a one-dimensional dynamic array of uvm_object-based objects, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional dynamic array of strings.
`uvm_field_array_string(ARG,FLAG)
ARG is a one-dimensional dynamic array of strings, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional dynamic array of enums.
`uvm_field_array_enum(T,ARG,FLAG)
T is a one-dimensional dynamic array of enums type, ARG is an instance of that type, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Macros that implement data operations for dynamic queues.
Implements the data operations for a queue of integrals.
`uvm_field_queue_int(ARG,FLAG)
ARG is a one-dimensional queue of integrals, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a queue of uvm_object-based objects.
`uvm_field_queue_object(ARG,FLAG)
ARG is a one-dimensional queue of uvm_object-based objects, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a queue of strings.
`uvm_field_queue_string(ARG,FLAG)
ARG is a one-dimensional queue of strings, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for a one-dimensional queue of enums.
`uvm_field_queue_enum(T,ARG,FLAG)
T is a queue of enums type, ARG is an instance of that type, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Macros that implement data operations for associative arrays indexed by string.
Implements the data operations for an associative array of integrals indexed by string.
`uvm_field_aa_int_string(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with string key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of uvm_object-based objects indexed by string.
`uvm_field_aa_object_string(ARG,FLAG)
ARG is the name of a property that is an associative array of objects with string key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of strings indexed by string.
`uvm_field_aa_string_string(ARG,FLAG)
ARG is the name of a property that is an associative array of strings with string key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Macros that implement data operations for associative arrays indexed by an integral type.
Implements the data operations for an associative array of uvm_object-based objects indexed by the int data type.
`uvm_field_aa_object_int(ARG,FLAG)
ARG is the name of a property that is an associative array of objects with int key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the int data type.
`uvm_field_aa_int_int(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with int key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the int unsigned data type.
`uvm_field_aa_int_int_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with int unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the integer data type.
`uvm_field_aa_int_integer(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with integer key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the integer unsigned data type.
`uvm_field_aa_int_integer_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with integer unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the byte data type.
`uvm_field_aa_int_byte(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with byte key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the byte unsigned data type.
`uvm_field_aa_int_byte_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with byte unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the shortint data type.
`uvm_field_aa_int_shortint(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with shortint key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the shortint unsigned data type.
`uvm_field_aa_int_shortint_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with shortint unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the longint data type.
`uvm_field_aa_int_longint(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with longint key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by the longint unsigned data type.
`uvm_field_aa_int_longint_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with longint unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by any integral key data type.
`uvm_field_aa_int_key(long unsigned,ARG,FLAG)
KEY is the data type of the integral key, ARG is the name of a property that is an associative array of integrals, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
Implements the data operations for an associative array of integral types indexed by any enumeration key data type.
`uvm_field_aa_int_longint_unsigned(ARG,FLAG)
ARG is the name of a property that is an associative array of integrals with longint unsigned key, and FLAG is a bitwise OR of one or more flag settings as described in Field Macros above.
The recording macros assist users who implement the uvm_object::do_record method. They help ensure that the fields are recorded using a vendor- independent API. Unlike the uvm_recorder policy, fields recorded using the `uvm_record_field macro do not lose type information--they are passed directly to the vendor-specific API. This results in more efficient recording and no artificial limit on bit-widths. See your simulator vendor’s documentation for more information on its transaction recording capabilities.
Vendor-independent macro for recording attributes (fields) to a vendor-specific transaction database.
Macro for recording name-value pairs into a transaction recording database. Requires a valid transaction handle, as provided by the uvm_transaction::begin_tr and uvm_component::begin_tr methods.
The packing macros assist users who implement the uvm_object::do_pack method. They help ensure that the pack operation is the exact inverse of the unpack operation. See also Unpacking Macros.
virtual function void do_pack(uvm_packer packer); `uvm_pack_int(cmd) `uvm_pack_int(addr) `uvm_pack_array(data) endfunction
The ‘N’ versions of these macros take a explicit size argument.
Pack an integral variable.
`uvm_pack_intN(VAR,SIZE)
Pack an integral variable.
`uvm_pack_enumN(VAR,SIZE)
Pack a static array of integrals.
`uvm_pack_sarray(VAR,SIZE)
Pack a dynamic array of integrals.
`uvm_pack_arrayN(VAR,SIZE)
Pack a queue of integrals.
`uvm_pack_queueN(VAR,SIZE)
Pack an integral variable without having to also specify the bit size.
`uvm_pack_int(VAR)
Pack an enumeration value. Packing does not require its type be specified.
`uvm_pack_enum(VAR)
Pack a string variable.
`uvm_pack_string(VAR)
Pack a variable of type real.
`uvm_pack_real(VAR)
Pack a static array without having to also specify the bit size of its elements.
`uvm_pack_sarray(VAR)
Pack a dynamic array without having to also specify the bit size of its elements. Array size must be non-zero.
`uvm_pack_array(VAR)
Pack a queue without having to also specify the bit size of its elements. Queue must not be empty.
`uvm_pack_queue(VAR)
The unpacking macros assist users who implement the uvm_object::do_unpack method. They help ensure that the unpack operation is the exact inverse of the pack operation. See also Packing Macros.
virtual function void do_unpack(uvm_packer packer); `uvm_unpack_enum(cmd,cmd_t) `uvm_unpack_int(addr) `uvm_unpack_array(data) endfunction
The ‘N’ versions of these macros take a explicit size argument.
Unpack into an integral variable.
`uvm_unpack_intN(VAR,SIZE)
Unpack enum of type TYPE into VAR.
`uvm_unpack_enumN(VAR,SIZE,TYPE)
Unpack a static (fixed) array of integrals.
`uvm_unpack_sarrayN(VAR,SIZE)
Unpack into a dynamic array of integrals.
`uvm_unpack_arrayN(VAR,SIZE)
Unpack into a queue of integrals.
`uvm_unpack_queue(VAR,SIZE)
Unpack an integral variable without having to also specify the bit size.
`uvm_unpack_int(VAR)
Unpack an enumeration value, which requires its type be specified.
`uvm_unpack_enum(VAR,TYPE)
Pack a string variable.
`uvm_unpack_string(VAR)
Unpack a variable of type real.
`uvm_unpack_real(VAR)
Unpack a static array without having to also specify the bit size of its elements.
`uvm_unpack_sarray(VAR)
Unpack a dynamic array without having to also specify the bit size of its elements. Array size must be non-zero.
`uvm_unpack_array(VAR)
Unpack a queue without having to also specify the bit size of its elements. Queue must not be empty.
`uvm_unpack_queue(VAR)
The create method allocates a new object of the same type as this object and returns it via a base uvm_object handle.
virtual function uvm_object create ( string name = "" )
This function returns the type name of the object, which is typically the type identifier enclosed in quotes.
virtual function string get_type_name ()
The uvm_object class is the base class for all UVM data and hierarchical classes.
virtual class uvm_object extends uvm_void
The do_record method is the user-definable hook called by the record method.
virtual function void do_record ( uvm_recorder recorder )
The do_pack method is the user-definable hook called by the pack methods.
virtual function void do_pack ( uvm_packer packer )
The do_unpack method is the user-definable hook called by the unpack method.
virtual function void do_unpack ( uvm_packer packer )
As the name implies, uvm_factory is used to manufacture (create) UVM objects and components.
class uvm_factory
Returns the type-proxy (wrapper) for this object.
virtual function uvm_object_wrapper get_object_type ()
The uvm_recorder class provides a policy object for recording uvm_objects.
class uvm_recorder extends uvm_object
This function indicates that the transaction has been started and is not the child of another transaction.
function integer begin_tr ( time begin_time = )
This function marks the start of a transaction, tr, by this component.
function integer begin_tr ( uvm_transaction tr, string stream_name = "main", string label = "", string desc = "", time begin_time = 0, integer parent_handle = 0 )