当前位置:首页 > 工业控制 > 电子设计自动化
[导读]摘要:VMM是一种基于 SystemVerilog语言的验证方法学,它通过引入断言、抽象化、自动化与重用这四种机制提高了项目验证的生产率。本文通过一个实例介绍怎样利用 VMM建立基于事务的可重用的层次化验证平台。 0引言:

摘要: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建立基于事务的分层式验证平台的思想。



来源:轻舞寻梦1次

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

新一代人工智能的发展,是国家层面的战略大协作。由科技部主导,共15个国家部门构成的新一代人工智能发展规划推进办公室,着力推进项目、基地、人才统筹布局,打造国家级专家库,成立新一代人工智能战略咨询委员会。很多时候企业拥有重...

关键字: 人工智能 自动化 平台

没想到一家半导体公司创始人的经历可以如此传奇,从大屠杀中活了下来,他就是威世(Vishay)创始人费利克斯·赞德曼(Felix Zandman)。本以为世界级半导体公司的创始人都是从小理科天赋过人、名校背景,成长故事如同...

关键字: 半导体 平台 公司

对于法系车,在广大消费者心目中,它最大特点或许是在欧洲设计理念的平台上,设计前卫、操控性好、底盘扎实,突出人性化。一旦你接受并习惯这种法式的设计感后,就会爱得无法自拔,正如法国的艺术品一样。所谓纯正的法系车,只能意会不能...

关键字: 设计感 理念 平台

摘 要 :从智慧旅游平台的构建可行性出发,基于物联网技术对智慧旅游平台进行了总体设计,并分析了平台各子系统功能,总结了平台的总体功能与实际应用价值,以期能够将物联网技术的应用效益最大程度发挥出来,使其更好地服务于智慧旅游...

关键字: 物联网技术 旅游业 智慧旅游 应用效益 信息化 平台

摘 要:车联网将促进汽车、交通和信息技术产业向更加现代化、网络化和智能化的方向发展。根据目前车联网应用现状,从车联网系统框架出发,分析车联网平台应该具有的功能,并提出了以呼叫中心为基础的车联网平台功能的实现方法。

关键字: 关键词 车联网 系统框架 平台 呼叫中心

在任何一个关系数据库中,第一范式(1NF)是对关系模式的基本要求,不满足第一范式(1NF)的数据库就不是关系数据库。

关键字: MySQL 范式 事务

一个TCC事务框架需要解决的当然是分布式事务的管理。

关键字: 分布式 事务

我们知道,MyISAM 和 MEMORY 存储引擎支持表级锁定(table-level locking),InnoDB 存储引擎支持行级锁定(row-level locking),BDB 存储引擎支持页级锁定(page-...

关键字: MySQL 事务 锁定语句

对于分布式事务,相信所有人都应该很了解,为什么会有分布式事务?

关键字: 分布式 事务

8月20日消息,在今天举办的2020百度云智峰会上,百度集团副总裁侯震宇介绍百度在AI新基建时代的定位和目标是做“对外赋能的AI平台型公司”。 侯震宇表示,当下,智能家居、智能金融、自动驾驶、智慧医

关键字: 侯震宇 百度 AI 平台 云计算
关闭
关闭