5、IC验证面试88问——工厂机制

Q7:简述 UVM 的工厂机制。

Factory 机制也叫工厂机制,其存在的意义就是为了能够方便地替换TB 中的实例或者已注册的类型。一般而言,在搭建完 TB 后,我们如果需要对 TB 进行更改配置或者相关的类信息,我们可以通过使用 factory 机制进行覆盖,达到替换的效果,从而大大提高 TB 的可重用性和灵活性。

7.1 步骤

要使用 factory 机制先要进行:
1、定义(extends)
2、将类注册到 factory 表中(utils)
3、构建函数(function new)
4、 创建对象,使用对应的语句 (type_id::create)
5、 编写相应的类对基类进行覆盖。

7.2 覆盖类型

覆盖分为类型覆盖和实例覆盖。
类型覆盖:UVM层次结构下的所有原有类型都被覆盖类型所替换;

static function void set_type_override(uvm_object_wrapper override_type, bit replace = 1);
//调用
origin_type::type_id::set_type_override(new_type::get_type())

实例覆盖:指某些位置中原有类型会被覆盖类型所替换。

static function void set_inst_override(uvm_object_wrapper override_type,string inst_path,uvm_componnent parent = null);
//调用
origin_type::type_id::set_inst_override(new_type::get_type(),"orig_inst_path");
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值