uvm监控方法& run_phase

时间:2016-07-20 18:08:55

标签: uvm

我想知道我是否对监视器run_phase任务的uvm方法有所了解。 DUT发送多个时钟,其中包含监视器正在观察和检查的数据,保持不同的时钟域分离。所以我的运行阶段任务看起来像

forever begin
fork
begin @(posedge clk1) begin
..code to capture data..
end end
begin @(posedge clk2) begin
..code to capture data in this domain...
end end
join_any
disable fork;

我的'问题'是如果clk1和clk2对齐,那么只有一个posedge语句被执行。另外,如果我希望我的监视器在第三个异步域上执行一些其他操作,例如,在clk1或clk2的倍数处,则当第三个域与clk1或clk2对齐时会出现问题。

监视器如何在其运行阶段永远循环中在多个时钟域中工作?

1 个答案:

答案 0 :(得分:2)

通常在监视两个不同的时钟域时,它们将保持为独立的永久循环线程。可能存在您想要有条件地禁用其他时钟域的情况,但我怀疑这是您想要的。

fork
  forever @(posedge clk1) begin
    ..code to capture data..
  end
  forever @(posedge clk2) begin
    ..code to capture data in this domain...
  end
join // or join_none