前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >安全地启动sequence

安全地启动sequence

作者头像
空白的贝塔
发布2021-12-20 14:32:29
5190
发布2021-12-20 14:32:29
举报
文章被收录于专栏:摸鱼范式摸鱼范式

uvm从1.1d到1.2再到IEEE1800.2,有了很多变化。尤其是从1.1d到1.2,在objection的使用上有了一些关键性变化。

在uvm进入到1.2后,starting_phase不在推荐使用。更为重要的是,不仅仅是不再推荐,而且如果以default sequence的方式启动以后,default sequence被启动以后,starting_phase依然会是null,如果沿用以前的代码,整个平台就起不来了

代码语言:javascript
复制
task body()
    if(starting_phase != null)
        starting_phase.raise_objection(this)
    //do something
    if(starting_phase != null)
        starting_phase.drop_objection(this)
endtask

尽管starting_phase不推荐使用,但是这个类并没有被uvm删除,如果想要继续使用,那么需要在使用之前进行如下赋值。

代码语言:javascript
复制
starting_phase=get_starting_phase()

get_starting_phase的原型如下

如果不想这么麻烦,也可以使用1.2的新方法,uvm_sequence_base::set_automatic_phase_objection

下面是一个例子

代码语言:javascript
复制
function my_sequence::new(string name="unnamed");
  super.new(name);
  set_automatic_phase_objection(1);
endfunction : new

在时间上,他的整个运行过程如下

代码语言:javascript
复制
start() is executed
  --! Objection is raised !--
  pre_start() is executed
  pre_body() is optionally executed
  body() is executed
  post_body() is optionally executed
  post_start() is executed
  --! Objection is dropped !--
start() unblocks

当然,也不一定要在new函数中set,也可以在new以后,再额外set

代码语言:javascript
复制
my_legacy_seq_type seq = new("seq");
seq.set_automatic_phase_objection(1);
seq.start(my_sequencer);

但是个人不推荐使用,因为如果环境在1.1d和1.2之间切换,会产生意想不到的问题,在1.1d中并没有这种方法。

所以按照个人理解,最稳妥的方法就是直接使用start启动sequence,并且在start前后控制objection,像下面这样

代码语言:javascript
复制
task main_phase(uvm_phase phase)
    my_seq_type seq = new("seq");
    phase.raise_objection(this)
    seq.start(my_sequencer);
    phase.drop_objection(this)
endtask

这样在uvm1.1d和1.2中都能够安全的启动并且控制objection

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-12-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 摸鱼范式 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档