[Verfication]如何在env中实现task/function 形参类型可变

文章描述了一个在Verilog编程中遇到的问题,即需要改变task或function的参数类型。作者创建了一个名为SCB_SRC的虚拟类,包含一个data_cmp任务,该任务接受不同类型的数据进行比较。通过实例化SCB_SRC并传入不同的参数类型,实现了功能的灵活性。示例展示了如何调用这个任务来处理不同宽度的数据并关联到特定的接口vif。

最近在项目中遇到需要改变task/function 形参类型,寻求了一种实现方法,记录一下~~

virtual class SCB_SRC#(type T=int, int BW =32);
  extern static task data_cmp(string gld_file, ref T dut_q[$], bit[BW-1:0] gld_q_q[$][$], virtual tx_if vif)
endclass

task SCB_SRC::data_cmp(string gld_file,ref T dut_q[$],bit[BW-1:0]gld_q_q[$][$],virtual tx_if vif);

  forever begin
    @(posedge vif.tx_en);
    ...
  end

endtask



//调用
SCB_SRC#(tx_trans,4)::data_cmp("tx_data.txt",out_data_q[0],gld_data_q_q,top_vif);
SCB_SRC#(tx_mon_trans,10)::data_cmp("tx_mon_data.txt",out_data_q[2],gld_data_q_q,top_vif);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值