首页
学习
活动
专区
圈层
工具
发布
36 篇文章
1
形式验证与formality基本流程
2
安全地启动sequence
3
【UVM COOKBOOK】Testbench Architecture【二】
4
【UVM COOKBOOK】Testbench Architecture【一】
5
svlib文档翻译(第一至四章)
6
svlib文档翻译(第五章)
7
浅谈便携式激励(PSS)和UVM
8
便携式激励vs形式化vsUVM验证方法在IP块的整个生命周期中的比较分析
9
通过字符串访问generate模块内部的变量
10
Verilog:笔试面试常考易错点整理
11
【源码】手把手教你用Python实现Vivado和ModelSim仿真自动化
12
如何快速生成Verilog代码文件列表?(内附开源C代码)
13
IC工程师的通用技能:文本处理
14
NCVerilog+SimVision+Vivado仿真环境搭建
15
串扰
16
论STA | 数字电路中的串扰
17
STA | 串扰,理论分析
18
低功耗 | UPF + CLP
19
combinational clock gating Vs sequential clock gating
20
Clock Domain Crossing, 跨时钟域检查
21
低功耗 | Glitch Power 分析
22
P&R | 如何在实现全流程中考虑IR-Drop
23
点论 | 组合逻辑环 Combinational loop 知多少
24
UVM的一个简单验证demo
25
systemverilog之Automatic
26
【手把手系列】:芯片设计中的Makefile简明教程
27
“ 一网打尽 ” 二进制、格雷码、独热码编码方式
28
分而治之(Hierarchical Sequences),处理复杂事物的绝对准则
29
断言(assertion),把黑盒变成白盒
30
针对assertion based验证的一些“建议”和“不建议”
31
python脚本练习(5):读写文件步骤
32
python脚本练习(4):正则表达式实例
33
python脚本练习(3):正则表达式实例
34
python脚本练习(2):使用正则表达式的三部曲
35
python脚本练习(1):表格打印
36
VCS门级仿真系列文章之sdf文件和$sdf_annotate

UVM的一个简单验证demo

文末附本文所有代码。

上次使用SystemVerilog进行验证,现在使用UVM对同一DUT进行验证。

SystemVerilog的一个简单验证demo

UVM框架如下:

为了保持组件/对象命名的一致性,所有组件/对象的名称都以mem_*开头。

基本组件:

Sequence item

  • 把激励所需的变量在sequence_item中进行声明。
  • sequence_item可以用作DUT信号上监视器监视的活动的占位符。

sequence_item是通过扩展uvm_seq_item来编写的:

代码语言:javascript
复制
class mem_seq_item extends uvm_sequence_item;    //Utility macro  `uvm_object_utils(mem_seq_item)    //Constructor  function new(string name = "mem_seq_item");    super.new(name);  endfunction endclass

在mem_seq_item中声明变量,并声明随机化:

代码语言:javascript
复制
class mem_seq_item extends uvm_sequence_item;   //data and control fields  rand bit [3:0] addr;  rand bit       wr_en;  rand bit       rd_en;  rand bit [7:0] wdata;       bit [7:0] rdata;
endclass

为了使用uvm_object方法(复制、比较、打包、解包、记录、打印等),所有变量都注册到uvm_field_*宏。

代码语言:javascript
复制
class mem_seq_item extends uvm_sequence_item;  //Utility and Field macros,  `uvm_object_utils_begin(mem_seq_item)    `uvm_field_int(addr,UVM_ALL_ON)    `uvm_field_int(wr_en,UVM_ALL_ON)    `uvm_field_int(rd_en,UVM_ALL_ON)    `uvm_field_int(wdata,UVM_ALL_ON)  `uvm_object_utils_end endclass
下一篇
举报
领券