There are multiple variants of the UVM utility macros, each one used to register a different kind of UVM object class:
- UVM components must use the
component
variants, all other UVM objects must use theobject
variants - Parameterized classes must use the
param
variants - Virtual classes must use the
abstract
variants (UVM 2017 or higher)
class my_uvm_component#(type type_param) extends uvm_component;
`uvm_object_utils(my_uvm_component#(type_param))
function new(string name, uvm_component parent);
super.new(name, parent);
endfunction
endclass
class my_uvm_component#(type type_param) extends uvm_component;
`uvm_component_param_utils(my_uvm_component#(type_param))
function new(string name, uvm_component parent);
super.new(name, parent);
endfunction
endclass
Rule Configuration
This rule can be disabled for your project, or its severity and parameters can be modified in the project linting settings. Alternatively, it can be manually configured with the following template:
146/severity/${path}={error|warning|info|ignore}