首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >uvm监控方法论& run_phase

uvm监控方法论& run_phase
EN

Stack Overflow用户
提问于 2016-07-21 02:08:55
回答 1查看 443关注 0票数 1

我想知道我是不是对监视器run_phase任务的uvm方法有什么误解。DUT发送多个时钟,其中包含监视器正在监视和检查的数据,从而保持不同时钟域的分离。因此,我的运行阶段任务如下所示

代码语言:javascript
复制
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对齐时就会出现问题。

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-07-21 02:37:29

通常,当监控两个不同的时钟域时,它们被保存为单独的永久循环线程。在某些情况下,您可能希望有条件地禁用另一个时钟域,但我怀疑这是您的意图。

代码语言:javascript
复制
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
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38487823

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档