首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UVM相位单子

UVM相位单子
EN

Stack Overflow用户
提问于 2014-02-28 15:44:45
回答 1查看 1.1K关注 0票数 2

在浏览了一下UVM源代码之后,我注意到每个阶段都存在单例。对于运行阶段,可以通过调用uvm_run_phase::get()来访问。

我尝试从uvm_run_phase::get()阶段和run_phase阶段调用end_of_elaboration,正如预期的那样,这两个调用都返回了同一个对象的句柄。我有点困惑,因为这个方法返回的对象与传递给run_phase(...)任务的对象不是它的阶段参数相同的对象。

我在EDA游乐场上创建了一个示例:http://www.edaplayground.com/x/2PL

有谁确切地知道传递给阶段方法的阶段参数是什么,以及为什么它不是单例?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-04-23 08:41:15

在UVM论坛上问了这个问题之后,我发现创建的每个阶段都有多个uvm_phase实例,一个用于调度,另一个用作实际实现。

调用uvm_run_phase::get()将返回运行阶段的实现节点,而传递给run_phase(...)的参数是调度节点。要从任何其他阶段获取调度节点,可以使用phase.find_by_name("run",0)

下面是指向UVM论坛中原始线程的链接:http://forums.accellera.org/topic/1769-uvm-phase-singletons/

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22099574

复制
相关文章

相似问题

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