VMM 中 factory 所用的 copy 和 allocate 方法的区别

在VMM1.1 以及之前,其factory机制的实现是通过以下两种方法实现的

1) copy : 如下

class xxx
   base_transaction      factory;
   ....
   factory=new();
   ....
   base_transaction      tr;   
   $cast(tr, factory.copy())
endclass

in test: 
initial begin
    env.xxx.factory = real_print
end

描述起来就是: 工厂里面已经有现成的模子(实例),我们所做的就是用新的模子 替换原有的模子。(替换的模子的基本功能确定,即基类确定)


2) allocate

class xxx
     base_transaction     tr;
      virtual function new(base_transaction factory);
                 tr= factory.allocate();
      endfunction      
endclass
when instance xxx:
        xxx     inst;
        inst =new(real_print); // real_print is instance of extended xxx class.

描述起来就是: 工厂里面没有模子,模子需要 外部获得。(但是基本功能确定,即基类确定)


我们在Designware  AHB slave VIP 就使用了第二种方法,第二种方法不需要暴露类中的transaction 实例,但是必须暴露参数。


由此,我们在定义 base_transaction的扩展类时,必须实现copy 和 allocate函数。要 提醒大家的是,即使扩展类没有加入新的类成员,只是加了些constraint,但是依然要 加入

`vmm_data_member_begin( xxxxx)
`vmm_data_member_end(xxxx) 


   这样才在扩展类加入了copy 和 allocate 函数的实现


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值