0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

UVM中sequence的那些事儿

冬至子 来源:多读点书 作者:夕文x 2023-05-26 15:17 次阅读

引入sequence的原因:

  • 将 生成测试case的语句 从 main_phase 中独立出来,使得使用不同测试用例时,只需要修改sequence部分即可,而不用关注 UVM剩余部分。(提高剩余部分的可复用性)。

引入sequence的仲裁机制的原因:

  • 一个sequencer上通过fork...join可以启动多个sequence,而多个sequence按照什么顺序启动需要一定的仲裁机制来控制,具体而言主要从两个角度控制
    • sequence角度:自身的优先级、原子性、有效性
    • sequencer角度:对多个sequence的仲裁算法

引入sequence相关宏的原因:

  • 更方便地控制transaction的产生过程,主要有:
    • uvm_do系列宏:实例化transaction+将transaction交给sequencer(对应start_item与finish_item任务)
    • uvm_create宏:实例化transaction,可用new代替
    • uvm_send宏:将transaction交给sequencer(对应start_item与finish_item任务)
    • uvm_rand_send系列宏:对transaction进行随机化+将transaction交给sequencer(对应start_item与finish_item任务)

不同类型sequence共用sequencer的方法(一个driver):

  • transaction类型例化的一个sequencer 对应 多个不同约束的transaction包
    • 可以通过一个sequence启动其他sequence(即嵌套的sequence),然后间接生成多个不同约束的transaction包 —— 注意:这里使用了cseq. start ( m_sequencer );这样的语句
    • 也可以通过一个sequence直接生成多个不同约束的transaction包
  • 通过类型转换,实现同一个sequencer处理不同两个截然不同的transaction,步骤如下
    • 将sequencer和driver能够接受的数据类型设置为uvm_sequence_item
    • driver中使用时,使用cast将uvm_sequence_item转换为各自transaction的类型

补充:start任务参数说明 seq0.start(env.i_agt.sqr, null, 100);

  • 第一个参数:sequencer的位置,指明seq0由哪个sequencer启动
  • 第二个参数:parent sequence
  • 第三个参数:seq0的优先级

补充:m_sequencer是一个属于每个sequence的成员变量,它指向执行当前sequence的sequencer句柄,其类型是uvm_sequencer_base。

sequencer向sequence传递变量(约束)的方法:

  • 方法一:通过cast转换将sequence内置变量m_sequencer(类型为uvm_sequencer_base)转换成my_sequencer类型, 然后引用uvm_sequencer中的成员变量作为约束
  • 方法二:在sequence中使用`uvm_declare_p_sequencer(my_sequencer),然后通过宏默认生成的变量p_sequencer来引用uvm_sequencer中的成员变量作为约束

补充:uvm_declare_p_sequence的实质是在base_sequence中声明了一个成员变量p_sequencer,并将其指向启动本sequence的sequencer。

发往不同driver的sequence之间的同步的方法:

  • 方法一:通过全局事件进行简单同步:在drv0_seq中触发事件,在drv1_seq中等待这个全局事件。
  • 方法二:使用 virtual sequence+virtual sequencer,可以实现类似crossbar的连接,且因为virtual sequence的body是顺序执行,所以可以轻松实现整体顺序(同步),局部并行的效果。

图片

补充:verilog中事件的基本使用

  • event变量声明为:
    • event var;
  • event触发为:
  • ->var;
  • 捕获触发为:
  • @(var);

sequence library的概念:

  • 派生自uvm_sequence,就是一系列sequence的集合,它会根据特定的算法随机选择注册在其中的一些sequence, 并在body中执行这些sequence。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • UVM
    UVM
    +关注

    关注

    0

    文章

    182

    浏览量

    19195
  • sequence
    +关注

    关注

    0

    文章

    23

    浏览量

    2852
收藏 人收藏

    评论

    相关推荐

    数字IC验证之“搭建一个可以运行的uvm测试平台”(5)连载...

    的transaction,以及创建用于产生事物的事物发生器sequence。  在uvm验证平台中穿梭各个组件之间的基本信息单元是一个被称为transaction的数据对象,也就是我们前面所说的事物
    发表于 01-26 10:05

    UVM sequence分层有哪几种方式呢

    种请求下可以使用第一种分层方式,在high-layer sequence依然使用low-layer sequencer进行驱动,同时对low-layer sequence进行更加精细化的控制
    发表于 04-11 16:37

    请问一下在UVM的UVMsequences是什么意思啊

    UVM方法学,UVMsequences 是寿命有限的对象。UVM sequences从uvm_sequence_item基类扩展得到,uvm_s
    发表于 04-11 16:43

    UVM sequence分层的几种体现

    种请求下可以使用第一种分层方式,在high-layer sequence依然使用low-layer sequencer进行驱动,同时对low-layer sequence进行更加精细化的控制。在上面
    发表于 04-14 11:08

    如何配置sequence的仲裁算法和优先级及中断sequence的执行

    01 Arbitrary在UVM,多个sequence可以同时被绑定到相同的sequencer并启动。这种测试场景在实际是存在的,比如在模拟同一个总线master口上的不同类型的数
    发表于 09-23 14:35

    sequence item实际应用应该包含哪些东西

    展开。Sequence item是游走在Sequence-Sequencer-Driver这一基本结构的数据结构类型,在有些地方也直接叫transaction,可以说是UVM的必用品
    发表于 09-23 14:42

    UVMseq.start()和default_sequence执行顺序

      1. 问题  假如用以下两种方式启动sequence,方法1用sequence的start()方法启动seq1,方法2用UVM的default_sequence机制启动seq2。那
    发表于 04-04 17:15

    电源选型的那些事儿

    电路教程相关知识的资料,关于电源选型的那些事儿
    发表于 10-10 14:34 0次下载

    Linux的那些事儿之我是Block层

    Linux的那些事儿之我是Block层
    发表于 10-29 09:43 9次下载
    Linux的<b class='flag-5'>那些</b><b class='flag-5'>事儿</b>之我是Block层

    浅谈UVMsequence/item见解(上)

    item指的是uvm_sequence_item, Sequence Item具备UVM核心基类所必要的数据操作方法,对于激励的生成和场景控制,是由sequence来编织的,item应
    的头像 发表于 02-19 15:52 5062次阅读
    浅谈<b class='flag-5'>UVM</b>之<b class='flag-5'>sequence</b>/item见解(上)

    UVM sequence机制response的简单使用

    sequence作为UVM几个核心机制之一,它有效地将transaction的产生从driver剥离出来,并且通过和sequencer相互配合,成功地将driver的负担降低至仅聚焦于根据协议将
    的头像 发表于 09-22 09:26 2459次阅读

    UVMadd_typewide_sequence和add_sequence的区别

    第2和第3种方式类似,第3种是一下子添加多个sequence,它内部原理就是调用第2种的函数,因此在本质上,只有第1和第2种这两类区别。
    的头像 发表于 05-24 15:21 684次阅读

    UVMuvm_do宏简析

    uvm_do宏及其变体提供了创建、随机化和发送transaction items或者sequence的方法。
    的头像 发表于 06-09 09:36 5074次阅读
    <b class='flag-5'>UVM</b><b class='flag-5'>中</b>的<b class='flag-5'>uvm</b>_do宏简析

    在Sequencer上启动一个Sequence

    Sequencer默认不执行任何Sequence。验证工程师可以通过调用start()启动一个Sequence,也可以通过uvm_config_db指定一个自动启动的Sequence
    的头像 发表于 06-10 09:10 834次阅读
    在Sequencer上启动一个<b class='flag-5'>Sequence</b>

    UVM设计sequence启动方式有哪几种呢?

    本篇介绍UVMsequence,这是UVM中最基础的部分。对于前面介绍的uvm_callback,
    的头像 发表于 08-17 10:07 4535次阅读
    <b class='flag-5'>UVM</b>设计<b class='flag-5'>中</b>的<b class='flag-5'>sequence</b>启动方式有哪几种呢?