验证环境用户需要创建许多测试用例来验证一个dut的功能是否正确,验证环境开发者应该通过以下方式提高测试用例的开发效率:
在数据项类中加入旋钮,以简化测试用例开发控制
创建一些可重用的sequences library。
声明自定义的sequences
sequences是由几个数据项组成的,它们共同构成一个数据pattern以触发有趣的dut场景。
验证组件可以包括一个基本sequences library(而不是单一的数据项),测试用例编写者(验证环境使用者)可以调用它。这种方法加强了对常见数据pattern的复用,并减少了测试用例的代码长度。此外,一个sequences可以调用其他sequences,从而创造更复杂的场景。
uvm类库提供了uvm_sequence基类。你应该直接或间接地从这个类派生出所有的sequences类。要创建一个用户定义的sequences:
从uvm_sequence基类派生出一个sequences,并指定request和response数据项类型参数。在下面的例子中,只指定了request类型,即simple_item,所以response数据项类型也是simple_item 。
使用`uvm_object_utils宏来向factory注册sequences类型。
如果sequences需要访问其相关sequencer,使用'uvm_declare_p_sequencer宏来声明sequencer指针。
实现sequences的body任务来触发特定的dut场景。在body任务中,你可以发送数据项或者调用其他sequences。
下面例子中的simple_seq_do类定义了一个简单的sequences。它是由uvm_sequence派生出来的,并 使 用 了 `uvm_object_utils 宏 。 这个例子还定义了一个simple_sequencer类,simple_seq_do序列可以在该simple_sequencer上运行。
发送sequence items或者subsequences的基本流程
要 发 送 一 个sequence item,sequence的body()任务 需 要create() 该 sequence item , 对 该sequence item调 用start_item(),然后随机化该sequence item(可选的),最后对该sequence item调用finish_item()。
要发送一个subsequence,parent sequence的body()任务需要create该subsequence,对其进行随机化(可选的),最后对该subsequence调用start()。如果subsequence有一个相应的response,parent sequence可以调用get_response()。
上图显示了在uvm_do宏中实现的发送sequence items和sequences的完整流程。uvm_do宏会更根据传递的类型create一个对象,并且根据发送sequence items和sequences执行对应的流程。
uvm_do宏不会执行subsequences的pre_body()和post_body()方法。
EUV光刻技术助力半导体行业发展
PROFINET转TCP IP网关profinet转modbus网关
【Milk-V Duo 开发板免费体验】+ 1、开箱
卢伟冰微博暗示红米K30 Pro 或将采用升降式全面屏设计
小米6或在2月底发布:骁龙835顺利量产,小米6小规模试产
基于UVM验证环境开发测试流程
计算机电源的工作原理及发展史简述
赛普拉斯助力打造世界领先的汽车系统
华为为5G时代提供智能网优方案
国产耳机哪个牌子品牌音质好?音质最好的国产蓝牙耳机推荐
CMOS图像传感器重要参数解析
中易云物联网软硬件给用户带来极大便利
dfrobot短U型支架介绍
明日在线研讨会预热 | 基于高层级设计的FPGA开发快速迭代
PLC在电气自动化控制系统中都扮演了什么角色?
人工智能暗藏危险泡沫,是技术的沉淀还是彻底的沉没
iPhone 14系列面板订单82%来自三星
我国城市轨道发展现状及最新轨道交通技术应用解析
今年手机处理器天梯图出炉,看看你的手机排第几
如何正确选购水晶头