UVM中的regmodel建模(一)
UVM中的regmodel继承自VMM的RAL(Register Abstract Layer),现在可以先将寄存器模型进行XML建模,再通过Synopsys
家的工具ralgen来直接生成regmodel,提供后门访问,十分方便。
寄存器模型建模:
1)定义一个寄存器,如下;也可以在该class中定义covergroup,sample的function等。在以后的component中在采样。
class reg_invert extends uvm_reg;
rand uvm_reg_field reg_data; //uvm_reg_field是寄存器模型中最小的单元,相当于一个bit
//可以定义多个uvm_reg_field;
covergroup cg_vars(); //定义covergroup
option.per_instance = 1; //按intance来采集覆盖率
xxxxxxx;
endgroup
virtual function void build(); //与build phase不同,这仅仅是一个建立函数
reg_data = uvm_reg_field::type_id::creat("reg_data"); //new reg_field
reg_data.configure(); //可以定义该field在这个reg中的具体位置,操作方式,是否有复位值
endfunction //是否可以随机化等。
function void sample_values();
super.sample_values();
if(get_coverage(UVM_CVR_FIELD_VALS)) begin //get_coverage()返回coverage是否使能
if(cg_vals != null) cg_vals.sample();
endfunction
configure(this, 1, 0, "RW", 1, 0, 1, 1, 0); this表示parent class,"1"表示此域的宽度,“0”表示最低位的位置,“RW”表示可读可写,“1”是否volatile
“0”上电后的复位值,“1”此域是否有复位,“1”是否可以随机化,“0”此域是否可单独存取
UVM_CVR_FIELD_VALS定义于uvm_coverage_model_e联合体中,还有定义UVM_NO_COVERAGE, UVM_CVR_REG_BITS,
UVM_CVR_ADDR_MAP, UVM_CVR_ALL。
2)定义一组寄存器,如下:
class block_reg extends uvm_reg_block;
rand reg_gpr0 gpr0; //定义一个寄存器
rand uvm_reg_field ctrl_en; //也可定义一个寄存器部分
virtual function void build(); //同样与build phase不同,仅仅一个建立函数
this.default_map = creat_map(); //先建立一个addr_map
this.gpr0 = reg_gpr0::type_id::create("gpr0",get_full_name() );
this.gpr0.configure(this, null, "");
this.gpr0.build();
this.gpr0.add_hdl_path(); //后门访问的路径
this.default_map.add_reg(); //前门访问的地址
endfunction
begin
reg_gpr0_bkdr bkdr = new(this.gpr0.get_full_name() );
this.gpr0.set_backdoor(bkdr); //设置该寄存器对应的后门操作
end
create_map("", 0, 4, UVM_LITTLE_ENDIAN, 0); 参数名为空, 基地址为0, 系统总线的宽度是4*8,小端格式,不能按byte来寻址。
add_hdl_path(‘{‘{“REG1”, -1, -1}}); 表示作为一个整体来寻址。
add_hdl_path(‘{‘{“A_REG”, 15, 1}, '{"B_REG", 10, 2}}); 表示两部分第15位的为A_REG,第10-11位是B_REG。
add_reg(this.gpr0, 'h0, "RW"); 表示寄存器gpr0,地址是0, 读写方式访问。
class reg_gpr0_bkdr extends uvm_reg_backdoor;
virtual task read(uvm_reg_item rw);
do_pre_read(rw); //callback函数
rw.value[0] = `REG_TOP_PATH.A_REG; //路径+已经定义过的A_REG,在add_hdl_path,PATH的定义可以放在命令行
rw.status = UVM_IS_OK; //返回的状态值定义在uvm_state_e联合体中,还有UVM_HAS_X, UVM_ERROR
do_post_read(rw);
endtask
virtual task write(uvm_reg_item rw);
//与read类似
endtask
endclass
uvm_reg_item派生自uvm_sequence_item,表示一个寄存器的Transaction。
uvm_reg_bus_op表示一个对register/memory的bus Transction,主要用在前门访问中
最后子顶层env build_phase中定义如下:
uvm_reg::include_coverage("*", UVM_CVR_FIELD_VALS);
regmodel = block_reg::type_id::create("block", this);
regmodel.build();
regmodel.set_coverage(UVM_CVR_FIELD_VALS);
regmodel.lock_model();
regmodel.default_map.set_auto_predict(0); //从DUT更新寄存器模型的一种方式
至此后门访问已经可以通过
UVM中的regmodel建模(一)的更多相关文章
- UVM中的regmodel建模(三)
总结一下UVM中的寄存器访问实现: 后门访问通过add_hdl_path命令来添加寄存器路径,并扩展uvm_reg_backdoor基类,定义read与write函数,最后在uvm_reg_block ...
- UVM中的regmodel建模(二)
UVM的寄存器模型,对一个寄存器bit中有两种数值,mirror值,尽可能的反映DUT中寄存器的值.expected值,尽可能的反映用户期望的值. 几种常用的操作: read/write:可以前门访问 ...
- Visio 2007中进行数据库建模时如何显示字段类型以及概念名称
关于在VISIO中进行数据库建模时如何显示字段类型,以及注释的 1 如何显示字段类型: 在visio菜单上--->点击数据库--->选项--->文档 打开后选择表这项,在上 ...
- UVM中的class
UVM中的类包括:基类(base)------------uvm_void/uvm_object/uvm_transaction/uvm_root/uvm_phase/uvm_port_base 报告 ...
- 直播开始:'云榨汁机'诞生记--聊聊JavaScript中的'业务建模'
闭包是JavaScript中的一个重要特性,在之前的博文中,我们说闭包是一个'看似简单,其实很有内涵'的特性.当我们用JavaScript来实现相对复杂的业务建模时,我们可以如何利用'闭包'这个特性呢 ...
- 浅析软件工程中的UML建模技术
一.基本信息 标题:浅析软件工程中的UML建模技术 时间:2018 出版源:电子世界 领域分类:软件工程:UML建模技术:需求分析 二.研究背景 问题定义:软件工程中UML建模技术的研究 难点:明确软 ...
- UVM中的sequence使用(一)
UVM中Driver,transaction,sequence,sequencer之间的关系. UVM将原来在Driver中的数据定义部分,单独拿出来成为Transaction,主要完成数据的rand ...
- UVM中factory机制的使用
UVM中的factory机制一般用在sequence的重载,尤其是virtual sequence.当Test_case变化时,通过virtual sequence的重载,可以很容易构建新的测试. 因 ...
- UVM中的factory机制实现
首先在Systemverilog中便有对于重载的最基本的支持. 1)定义task/function时,使用virtual关键字.那之后在test_case中调用时,便使用句柄指向的对象的类型而不是句柄 ...
随机推荐
- Unity3D笔记 愤怒的小鸟<六> 弹弓发射小鸟
要实现的目标 实现个性化的鼠标 实现弹弓 选择小鸟.拉升弹弓.发射小鸟 弹弓橡皮筋 声音 1.实现个性化鼠标 效果 2.添加弹弓 建立两个材质 创建一个空GameObject 把两个shoot拖进来统 ...
- Unity3D笔记二十 多媒体与网络
1 游戏音频 1.游戏音乐:如游戏背景音乐 2.游戏音效:如开枪或打怪物时“砰砰”的游戏音效 Unity 3D游戏引擎共支持4种音乐格式的文件,具体如下. aiff:适用于较短的音乐文件,可用作游戏音 ...
- 初始react
很久就期待学习react了,惰性,一直都没有去翻阅react的资料,最近抽空,简单的了解了一下react,先记录一下,后续慢慢的学习. 一.ReactJS简介 React 起源于 Facebook 的 ...
- wpgcms---详情页面数据怎么渲染
wpgcms的详情页面的数据会被保存在 contentInfo 这么一个字段里面. 面包屑导航调用: <p>当前位置 {% for c in crumb|slice(1, crumb|le ...
- 9.8Django
2018-9-8 14:34:38
- mysql union查询
1.mysql总是通过创建并填充临时表来执行union查询; 2.除非要服务器消除重复的行,否则一定要用union all.如果没有all关键字,mysql会在临时表加个distinct选项,会导致临 ...
- ubuntu下安装opencv3.1.0
ubuntu14.04安装opencv3.1 1.下载opencv3.1源码http://opencv.org/releases.html 2.安装opencv3 2.1安装opencv3的依赖 1 ...
- Pandas新建一个DataFrame
我们在使用Pandas时候,前提需要一个新的DataFrame,需要首先初始化一个: 那么可以根据字典形式初始化: # 新建一个dataFrame df = pd.DataFrame({']) 必须包 ...
- MySQL权限和用户管理
Mysql权限系统(由mysql权限表进行控制user和db)通过下面两个方面进行认证: 1)对于连接的用户进行身份验证,合法的通过验证,不合法的拒绝连接. 2)对于通过连接认证的用户,可以在合法的范 ...
- windows kibana的连接使用
下载后解压使用,打开config目录下的kibana.yml文件,然后添加:elasticsearch.url: "http://localhost:9200" 表示你要添加的e ...