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

本文介绍了VMM1.1及以前版本中工厂机制的两种实现方法:copy和allocate。通过具体示例阐述了如何利用这两种方式来管理和创建transaction实例,并强调了在扩展类中实现copy和allocate函数的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在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 函数的实现


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值