UVM monitor错误,导致仿真时间hang住

采用如下源码,从仿真log中发现一个问题:当cpu没有发出读写命令,即re&we都为0,monitor也会采样传给reference model。

task cpu_monitor::main_phase(uvm_phase phase);
  cpu_transaction tr;
  
  while(1) begin
    tr = new("tr");
	collect_one_pkt(tr);//采集 DUT interface的值,并传给reference model.
  end
endtask

为了屏蔽这种冗余采样,做了如下修改:

task cpu_monitor::main_phase(uvm_phase phase);
  cpu_transaction tr;
  
  while(1) begin
    tr = new("tr");
	if(cif.cpu_re|cif.cpu_we)//添加改行code,当cpu发起读写cmd,再进行采样
	   collect_one_pkt(tr);
	`uvm_info("[cpu_monitor]","end phase", UVM_LOW);
  end
endtask

但是仿真过程中发现,仿真时间hang住,uvm_info 打印的时间一直是0时刻,解决办法:

task cpu_monitor::main_phase(uvm_phase phase);
  cpu_transaction tr;
  
  while(1) begin
    tr = new("tr");
	if(cif.cpu_re|cif.cpu_we)//添加改行code,当cpu发起读写cmd,再进行采样
	   collect_one_pkt(tr);
	else
	  @(posedge top.clk); //加上else 和该语句,仿真正常,且采样符合预期
	`uvm_info("[cpu_monitor]","end phase", UVM_LOW);
  end
endtask

我理解的原因是:修改之前的while循环里所有操作都不消耗仿真时间,所以处于一直在0时刻判断的情况

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值