摘要:VMM是一种基于 SystemVerilog语言的验证方法学,它通过引入断言、抽象化、自动化与重用这四种机制提高了项目验证的生产率。本文通过一个实例介绍怎样利用VMM建立基于事务的可重用的层次化验证平台。

  0引言:

  随着集成电路深亚微米时代的到来,集成电路的规模不断扩大,促进了系统级芯片 SoC(Systems-ON-a- Chip)的发展和应用。通常一个 SoC芯片的规模在几百万门至几千万门左右,面对如此高的复杂度,验证成为 SoC设计中最困难、最具挑战性的课题之一。VMM(Verification Methodology Manual)验证方法学采用 SystemVerilog语言,引入了断言、抽象化、自动化及重用机制,指导验证工程师搭建基于事务的可重用的层次化验证平台,可以很容易地实现定向测试、随机测试、数据自检查等功能,减少了测试案例的复杂度,提高了验证生产率,减少了总的验证代码量,缩短了产品的面市时间。

  1基于事务的验证

  基于事务的验证是当前采用的主要验证技术。简单来说事务就是在接口上的操作。事务可以是抽象的和高层次的,例如可靠地发送一个TCP包,也可以是物理层面上的,例如在APB内连接上的写周期。基于事务的验证让用户不必关注底层的细节,在抽象级别更高的事务级上进行验证,从而提高了验证效率。

  验证环境中的组件称为事务处理器。它是一个静态的对象,它自主地生成、处理或者监视事务。传统的总线功能模型即是一种低层次的事务处理器,它将事务级激励转换成被测设计对象接口上的引脚信 号跃变或者相反。而更高层次的事务处理器只有事务级接口。事务处理器根据设计对象中所使用的协议来处理事务,被测设计对象所产生的响应从引脚信号的跃变转 换回事务级的响应形式。这样就可以做到在事务级上核对响应是否正确,检查出响应不相符的时候,就进一步在信号/引脚级上加以查看,从而将错误定位出来。

  2 VMM验证方法学

  VMM是一种基于 SystemVerilog的验证方法学。它最大程序地利用了 SystemVerilog的面向对象编程的优点,通过一系列机制提高了验证的生产率。

  2.1层次化验证模型

  VMM采用了易于验证重用的分层式测试平台结构。每一层即建立在其他层之上的又具有一定的独立性,使得验证平台在不同的项目之间使用时,即使改变某一层的功能也不会影响其他层的重用,这样就大大提高了验证的重用性。

  可以看出 VMM推荐的层次化验证平台从底至上被分成信号层、命令层、功能层、场景层以及测试层。其中的验证组件包括发生器、代理、驱动器、监视器、检查器、记分板以及断言。

  信号层包括待测设计DUT与接口。命令层在信号层之上,向下通过信号层接口与待测设计相连,向上通过事务级通道与功能层通信,一般包括驱动器(Driver)、监视器(Monitor) 和断言(Assertion)。驱动器将来自上层的事务转化为信号级激励输入给DUT,监视器用来监视接口信号的变化并转化为事务传递给上层的检查器。功 能层位于命令层之上,是高层次操作的抽象,相互之间通过事务级通道通信。这一层主要包括代理(Agent)、检查器(Checker)和记分板 (Scoreboard)。代理的作用是接收上层传来的高层事务,如DMA的读写等,并且将这些高层事务转换成单独的命令向驱动器提供。驱动器在接收到代 理发出的命令后,就会生成相应的激励数据。记分板用来动态预测设计的响应,施加给DUT的激励同时施加给记分板,记分板中的转换函数把输入的激励全部转换 成最后响应的形式,并保存在数据结构中,以传递给检查器,记分板还对所有的事务进行纪录与统计,记录执行的事务个数,成功失败的事务个数,是否某一事务被 遗漏等。检查器通过将监视器传来的数据与记分板中存储的预测响应进行比较来判断待测功能是否正确。场景(Scenario)层在功能层之上,主要是用来生 成具有一定关系的随机事务的序列。最上层是测试层,他被用来配置不同的测试案例,定义不同的约束条件。在整个验证工程中,功能覆盖率由仿真工具自动生成, 测试者根据功能覆盖率来调整测试平台,修改测试案例直到覆盖率达到1O0% ,便可以认为验证过程结束。

  为了充分利用SystemVerilog语言面向对象编程的优点,上述验证组件都用类(class)来实现,以提高可重用性,整个验证平台具有统一的框架,结构也变得清晰,更容易维护。

  2.2 提高验证生产率的机制 VMM方法学通过 4个不同的机制提高了项目验证的生产率。这四个机制为别为 :断言、抽象化、自动化和重用。

  断言是检查待测设计中信号行为是否正确的观察器,它是用描述性语言来实现的。通过在设计模块内部与其对外接口的关键位置上设置功能检查,不需要编写独立的测试代码,便能从测试平台的外观察到这些关键监视点所发生的情况,可以有效地提高观察和定位设计错误的能力。

  传统的总线功能模型使的我们很难添加或结合新的协议层,而事务处理器的层次化形成了递归层次的抽象化,通过事务处理器的层次化来突破总线功能模型的限制。

  在验证中, 需要产生激励来驱动设计。在时间有限的仿真过程中, 定向测试只能验证芯片的典型行为 , 而不能验证所有可能的行为, 这是定向测试的主要缺陷。而随机化激励可以仅用几行代码就能产生大量的激励数据 , 通过为设计提供随机激励信号来扩大验证的测试空间。当随机激励源不能生成所需的激励信号时,或者所需的激励不能用无侧重的随机信号源来产生时,验证者可以对随机化过程施加约束,让它生成的随机化的激励更多地落在我们感兴趣的区域或者边界内, 可更快地达到功能覆盖率的要求。

  VMM对验证环境的层次进行了明确的定义,反映了设计所处理数据不同的抽象层次,每一层建立在其他层之上又具有一定的独立性,即使改变某一层的 功能也不会影响其他层的重用,这样就大大提高了验证的重用性,可有效减少要编写的测试案例的复杂度,验证环境无须修改即可被尽可能多的测试案例重用,避免 了重复编写功能相同的模块。

  3 应用实例

  下面通过一个例子来介绍如何用 VMM建立基于事务的层次化验证平台,待测模块 DUT为一个 FIFO。验证平台的顶层结构如图 2所示:

  由于设计较为简单,因此这里未实现场景层的功能模块。上图中各个验证组件都是用类实现的。下面自上而下介绍各个验证组件的功能与实现。

  (1) 事务定义 fifo_tr

  事务 fifo_tr继承自 VMM的基类 vmm_data,因此也继承了 vmm_data定义的一些方法,如 copy(), compare()等。fifo_tr包括两个成员变量 kind和 data,前者定义事务的类型是读还是写,后者定义读写的数据。

  (2) 事务通道 fifo_chan

  fifo_chan由 VMM定义的宏 `vmm_channel()产生,用来在事务级验证组件之间传输特定的事务。与 SystemVerilog定义的 mailbox结构相比,通道是强类型的,即每种通道只能传输特定的事务,避免了错误情况的发生。

  (3) 接口 fifo_if

  fifo_if是驱动器与 FIFO之间的通信接口,它封装了 FIFO的 Pin,属于信号层,驱动器通过接口来将激励输入给 DUT。

  (4) 发生器 fifo_gen

  fifo_gen继承自 VMM的基类 vmm_xactor,它的核心是一个无限循环,用来产生随机的事务,如读事务或写事务,并将该事务通过通道传输给驱动器 fifo_drv.

  (5) 驱动器 fifo_drv

  fifo_drv继承自 VMM的基类 vmm_xactor,它的功能是接收来自上层发生器 fifo_gen的事务 fifo_xactn,通过分析将其转化为信号级的信号,作为激励输入给待测设计 FIFO,它的构造器包含两个重要的参数,一个是输入通道,用来与发生器通信,另一个是输出接口,用来与 FIFO通信。

  (6) 监视器 fifo_mon

  fifo_mon继承自 VMM的基类 vmm_xactor,它的功能是监视 FIFO的信号变化,将设计的实际响应传递给检查器 fifo_chk.与驱动器类似,它的构造器也包含两个重要的参数,一个是输入接口,用来与 FIFO相连,监视接口信号的变化,另一个是事务级通道,用来与检查器通信。

  (7) 检查器 fifo_chk

  fifo_chk继承自 VMM的基类 vmm_xactor,用来检查事务是否正确得到执行。具体是将监视器传来的信息与记分板传来的预测结果进行比较以判断待测功能的正确性。

  (8) 计分板 fifo_scb

  计分板继承自 VMM的基类 vmm_xactor,用来对输入激励产生预测响应,并对已发生的事务进行纪录与统计,比如总共进行了多少个读事务或写事务,哪些已经完成,哪些被挂起,哪条事务正确的得到执行,哪条事务执行过程中出错了等等。

  (9) 断言 assertions 断言用来检验 FIFO的违例情况,如在满的情况下写 FIFO,空的情况下读 FIFO等,这些可以通过断言检查出来。以上介绍的验证组件组成的验证平台的框架可用图 3表示如下 :

  顶层模块 tb_top由 DUT、测试程序 (program)、接口与时钟发生器组 成。测试程序中例化了验证环境 fifo_env,验证环境将所有必需的事务处理器进行例化,测试案例只用程序(program)块中的一个 initial块来实现,这样做可以避免设计、断言和验证环境出现竞争冒险,并且只使用一个 initial块使得测试案例的执行是单线程的,这样可以更容易的理解所要完成的测试案例的每个步骤。

  4 总结

  在越来越高的抽象层次上进行验证是历史不断发展的趋势。本文以 FIFO验证平台为例运用面向对象的思想介绍了怎样利用VMM验证方法学建立基于事务的层次化验证平台,简单介绍了每个层次验证组件的功能与实现,给出了 总的验证平台的框架。该验证平台具有很高的重用性,增强了程序可读性,降低了验证平台的维护成本、体现了VMM验证方法学的优越性。

  本文作者创新点: 提出利用 VMM建立基于事务的分层式验证平台的思想。

利用VMM建立基于事务的层次化验证平台相关推荐

  1. SystemVerilog搭建APB_I2C IP 层次化验证平台

    一.前言 近期疫情严重,身为社畜的我只能在家中继续钻研技术了.之前写过一篇关于搭建FIFO验证平台的博文,利用SV的OOP特性对FIFO进行初步验证,但有很多不足之处,比如结构不够规范.验证组件类不独 ...

  2. 硬件仿真加速器与原型验证平台

    基于软件仿真工具对于动辄几百万门的ASIC验证而言,几乎显得力不从心.不管是从成本还是从性能的角度来看,使用硬件仿真器或者基于FPGA的原型验证平台,几乎是验证工程师的不二法门.因为基于硬件的环境能够 ...

  3. Keras之CNN:基于Keras利用cv2建立训练存储卷积神经网络模型(2+1)并调用摄像头进行实时人脸识别

    Keras之CNN:基于Keras利用cv2建立训练存储卷积神经网络模型(2+1)并调用摄像头进行实时人脸识别 目录 输出结果 设计思路 核心代码 输出结果 设计思路 核心代码 # -*- codin ...

  4. uvm 形式验证_一种基于UVM的总线验证方法与流程

    本发明涉及芯片设计的功能验证领域,尤其是一种基于UVM的总线验证方法. 背景技术: 随着集成电路工艺的不断进步,集成电路的规模和复杂度也在不断地提高,验证的难度也越来越大.在集成电路设计中,验证工作已 ...

  5. 基于Token进行身份验证

    1.基于服务器的验证 我们都是知道HTTP协议是无状态的,这种无状态意味着程序需要验证每一次请求,从而辨别客户端的身份.  在这之前,程序都是通过在服务端存储的登录信息来辨别请求的.这种方式一般都是通 ...

  6. 利用 k8s 建立软件商店_为企业建立应用商店

    利用 k8s 建立软件商店 It's June 2019. I'm sitting in a conference room in Research Triangle Park in North Ca ...

  7. 【转】基于Token的身份验证原理

    目录 1 发展史 2 Cookie 3 Session 3.1 cookie和session的区别 4 Token 4.1 传统方式--基于服务器的验证 4.2 基于服务器验证方式暴露的一些问题 4. ...

  8. 基于Token的身份验证的原理

    目录 1 发展史 2 Cookie 3 Session 3.1 cookie和session的区别 4 Token 4.1 传统方式--基于服务器的验证 4.2 基于服务器验证方式暴露的一些问题 4. ...

  9. 在ASP.NET中如何用C#.NET实现基于表单的验证

    这篇文章引用到了Microsoft .NET类库中的以下名空间: System.Data.SqlClient System.Web.Security ------------------------- ...

最新文章

  1. 学python最好的方式-自学Python有什么好方法吗?老男孩专业Python培训
  2. 【数据结构-图】1.图的构造和遍历(基本理论+代码)
  3. Kung Fu Panda: Legends of Awesomeness 2
  4. 启动wcc显示本地服务器失败,cwrsync server 服务启动失败的解决方法小结
  5. Java 8 API Stream让List操作更便捷
  6. UIScroll和UIPickView
  7. 生日祝福html_更新,礼包选择,头像框及太子生日金币活动
  8. 已知p是一个指向类a的数据成员m的指针_C++ this指针的理解和作用
  9. 马哥python全栈培训怎么样,你只需要在马哥教育待四个月
  10. Matlab中绘制折线图(附matlab代码)
  11. 市场调查报告写作的基本要求
  12. 二层交换机与三层交换机区别
  13. 反应式框架Reactor中的Mono和Flux
  14. U盘快捷方式文件病毒解决方法
  15. bch纠错码 码长8_密码学BCH纠错编码算法
  16. shell图形化监控网络流量 网络流量的监控工具有很多,如:Mrtg、Cacti、Zabbix等等,他们都有着各自的特点,不同的侧重,只为适合不同的应用场景的各种特殊需求。除了网络流量监控工具以外,还
  17. VLC全部参数,libvlc_new函数参数,VLC SDK开发
  18. 企业微信/skype sdk demo
  19. ajax请求失败readyState为0
  20. 全球与中国氧化PAN纤维市场销售现状与投资前景预测报告2022~2027年

热门文章

  1. django母版用法
  2. 基于云服务创建实时运营数据分析服务(二)
  3. POJ3322(bfs+状态限制)
  4. Java 設計模式 - 適配器模式
  5. 高通平台提高核电电压
  6. smb.conf - Samba组件的配置文件
  7. 产业新基建,撬动数字经济发展新机遇
  8. matlab求解一元四次函数,excel数据函数参数是四个吗|求一个简单的一元四次函数的最大值...
  9. 《 指数基金投资指南 》by 银行螺丝钉 - 笔记 - 4 - 第二部分
  10. K8S 创建 Deployment