重载的方式主要有三种,分别是调用位于uvm_component中的覆盖函数、调用位于uvm_factory中的覆盖函数、以及采用命令行进行覆盖。
extern static function void set_type_override_by_type(uvm_object_wrapper original_type,uvm_object_wrapper override_type,bit replace=1);
注:
eg. 要将bird类型替换成parrot类型
set_type_override_by_type(bird::get_type(), parrot::get_type());
extern function void set_inst_override_by_type(string relative_inst_path, uvm_object_wrapper original_type, uvm_object_wrapper override_type);
extern static function void set_type_override(string original_type_name, string override_type_name, bit replace=1);
eg. 用parrot 替代bird类型:
set_type_override("bird","parrot")
extern function void set_inst_override(string relative_inst_path, string original_type_name, string override_type_name);
eg. 使用new_monitor重载my_monitor:
set_inst_override("env.o_agt.mon", "my_driver", "new_monitor");
小结:
上述的所有函数都是uvm_component的函数, 但是如果在一个无法使用component的地方, 如在top_tb的initial语句里, 就无法使用。 UVM提供了位于uvm_factory中的另外四个函数来替换上述的四个函数。
extern function void set_type_override_by_type (uvm_object_wrapper original_type, uvm_object_wrapper override_type, bit replace=1);
第一个与uvm_component中的同名函数类似, 传递的参数相同。
extern function void set_inst_override_by_type (uvm_object_wrapper original_type, uvm_object_wrapper override_type, string full_inst_path);
第二个对应 uvm_component中的同名函数, 只是其输入参数变了, 这里需要输入一个字符串类型的full_inst_path。 这个full_inst_path就是要替 换的实例中使用get_full_name( ) 得到的路径值。
set_type_override_by_name
第三个与uvm_component中的set_type_override类似, 传递的参数相同。
set_inst_override_by_name
第四个函数对应uvm_component中的set_inst_override, 也需要一个full_inst_path。
系统中存在一个uvm_factory类型的全局变量factory,可以如下进行调用:
initial语句中:
initial begin
factory.set_type_override_by_type(bird::get_type(),parrot::get_type());
end
在component里也完全可以直接调用factory机制的重载函数:
factory.set_type_override_by_type(bird::get_type(), parrot::get_type());
<sim command> +uvm_set_inst_override=<req_type>,<override_type>,<full_inst_path>
<sim command> +uvm_set_type_override=<req_type>,<override_type>[,<replace>]
eg.
类型重载:
<sim command> +uvm_set_type_override="my_monitor,new_monitor"
实例重载:
<sim command> +uvm_set_inst_override="my_monitor,new_monitor,uvm_test_top.env.o_agt.mon"