• 《UVM实战》笔记——第八章 factory机制


    更新ing

    重载的方式及种类

    重载的方式主要有三种,分别是调用位于uvm_component中的覆盖函数、调用位于uvm_factory中的覆盖函数、以及采用命令行进行覆盖。

    位于uvm_component中的覆盖函数:

    1. set_type_override_by_type()
      会在需要将验证平台里所有A类型替换成B类型时用到。
    extern static function void set_type_override_by_type(uvm_object_wrapper original_type,uvm_object_wrapper override_type,bit replace=1);
    
    • 1

    注:

    • uvm_object_wrapper型的类型参数,可以通过xxx::get_type()的形式获得。
    • 在实际应用中一般只用前两个参数, 第一个参数是被重载的类型, 第二个参数是重载的类型。

    eg. 要将bird类型替换成parrot类型

    set_type_override_by_type(bird::get_type(), parrot::get_type());
    
    • 1
    1. set_inst_override_by_type()
      有时候不想将验证平台中的A类型全部替换成B类型, 而只是替换其中的某一部分实例,就可以用到。
    extern function void set_inst_override_by_type(string relative_inst_path, uvm_object_wrapper original_type, uvm_object_wrapper override_type);
    
    • 1
    1. set_type_override()
    extern static function void set_type_override(string original_type_name, string override_type_name, bit replace=1);
    
    • 1

    eg. 用parrot 替代bird类型:

    set_type_override("bird","parrot")
    
    • 1
    1. set_inst_override()
    extern function void set_inst_override(string relative_inst_path, string original_type_name, string override_type_name);
    
    • 1

    eg. 使用new_monitor重载my_monitor:

    set_inst_override("env.o_agt.mon", "my_driver", "new_monitor");
    
    • 1

    小结:

    • 类型覆盖不需要写路径,实例覆盖需要写路径,而且是相对路径

    位于uvm_factory中的覆盖函数

    上述的所有函数都是uvm_component的函数, 但是如果在一个无法使用component的地方, 如在top_tb的initial语句里, 就无法使用。 UVM提供了位于uvm_factory中的另外四个函数来替换上述的四个函数。

    四个覆盖函数

    1. set_type_override_by_type
    extern function void set_type_override_by_type (uvm_object_wrapper original_type, uvm_object_wrapper override_type, bit replace=1);
    
    • 1

    第一个与uvm_component中的同名函数类似, 传递的参数相同。

    1. set_inst_override_by_type
    extern function void set_inst_override_by_type (uvm_object_wrapper original_type, uvm_object_wrapper override_type, string full_inst_path);
    
    • 1

    第二个对应 uvm_component中的同名函数, 只是其输入参数变了, 这里需要输入一个字符串类型的full_inst_path。 这个full_inst_path就是要替 换的实例中使用get_full_name( ) 得到的路径值。

    1. set_type_override_by_name
      第三个与uvm_component中的set_type_override类似, 传递的参数相同。

    2. 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
    
    • 1
    • 2
    • 3

    在component里也完全可以直接调用factory机制的重载函数

    factory.set_type_override_by_type(bird::get_type(), parrot::get_type());
    
    • 1

    用命令行覆盖

    <sim command> +uvm_set_inst_override=<req_type>,<override_type>,<full_inst_path>
    <sim command> +uvm_set_type_override=<req_type>,<override_type>[,<replace>]
    
    • 1
    • 2

    eg.

    类型重载:

    <sim command> +uvm_set_type_override="my_monitor,new_monitor"
    
    • 1

    实例重载:

    <sim command> +uvm_set_inst_override="my_monitor,new_monitor,uvm_test_top.env.o_agt.mon"
    
    • 1
  • 相关阅读:
    接口测试如何测?最全的接口测试总结,资深测试老鸟整理...
    Java开发面试常见问题总结
    Cholesterol艾美捷胆固醇基参方案
    Linux笔记——Ubuntu子系统从系统盘迁移到非系统盘
    Windows 11 启用 Hyper-V 之后网络上传速度异常慢解决方案
    MATLAB中circshift函数转化为C语言
    部署jar包到windows服务器,并自动执行启动脚本
    每日shell脚本之mysql健康查询
    Apache SSI 远程命令执行漏洞复现
    Autosar诊断实战系列22-UDS单帧/长帧发送代码级分析
  • 原文地址:https://blog.csdn.net/dinghj3/article/details/127410154