UVM寄存器模型——手写Ralf问题debug

2024-05-15 22:36

本文主要是介绍UVM寄存器模型——手写Ralf问题debug,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

寄存器模型是UVM中至关重要的一部分,如果没有寄存器模型,那么验证平台对于DUT内寄存器的访问方式将十分有限,对DUT运行状态的把控也会变得更为复杂。

图片

在验证过程中,scoreboard或者其他验证组件经常需要了解当前时间某个寄存器的值,以此来调控激励的输入或者进行数据的比对。如果不使用寄存器模型,那只能够通过启动sequence的方式,给DUT的交互端口特定的地址和操作信号,获取寄存器的值。这种方法不仅十分繁琐,而且在某些情况下会提高测试用例的编写难度。 

寄存器模型其实就是DUT内各个寄存器的“拷贝文件”,而且它还能够根据DUT的变化,及时更新内部属性值,达到和DUT内部寄存器同步的目的。这就要求寄存器模型有和真实寄存器类似的结构、相同的属性以及一定的访问方法,这样才方便理解和使用。UVM中的寄存器模型分为了三个级别:uvm_reg_field、uvm_reg以及uvm_reg_block,如下图所示。

图片

uvm_reg_field 是寄存器模型中最基本的单位,对应着真实寄存器中的域。

uvm_reg_field 可以拥有不同的比特长度,定义不同的名称和属性;uvm_reg 与 DUT中的寄存器相对应,每个 uvm_reg 至少包含一个 uvm_reg_field;uvm_reg_block 则 属于比较大的单位,其中可以包含多个 uvm_reg,也可以包含多个 uvm_reg_block,block一般可以涵盖模块级 DUT 中的全部寄存器。

每个寄存器模型除了拥有用来表征寄存器的三级结构外,还需要uvm_reg_map

来实现地址上的映射。DUT 中的每个寄存器都会有对应的地址,用来给外部访问 提供依据。同样,在寄存器模型中,验证人员要在 uvm_reg_map 里添加各个 uvm_reg的访问地址,为寄存器模型前门访问提供相关的信息。

为了方便管理,UVM 在寄存器模型中规定了四种属性来描述寄存器信息。也 就是说,对于 DUT 中的每个寄存器,寄存器模型都会使用四个变量从不同的角度 对寄存器的值进行记录。这四种属性分别为 m_reset、m_mirrored、value 以及m_desired。 

其中m_reset用来储存寄存器的复位值,m_mirrored用来存储寄存器的镜像值,m_desired 用来存储期望值,这三个变量都属于本地变量,不能够直接从外部进行 访问,需要使用寄存器模型提供的方法,常用的访问方法如下表所示。而 value属性属于 public 类型,可以从外部直接访问,主要用于功能覆盖率或者域的随机 等方面。寄存器属性常用方法如下:

图片

最后,由于寄存器模型中存储数据的格式和在验证平台中使用的格式不一致,所以需要一个adapter模块负责格式转换,使寄存器模型能够和 sequencer 实现数据交互。寄存器模型在验证环境中的应用结构如下图所示。

图片

景芯SoC全流程训练营验证的VIP学员问:自己写的Ralf文件编译OK,为啥仿真有错?

图片

uvm-1.1/reg/uvm_reg.svh(1296) @ 0: reporter [RegModel] 

Field DLAB overlaps field RESERVED_8 in register "UART_LCR"

答:景芯训练营要求大家一切从底层撸,搞清楚设计、验证、DFT、后端的底层逻辑,所以Ralf文件我也要求学员自己写。回到VIP学员问题本身,很明显ralf文件写错了,具体错在哪里,欢迎知识星球查看答案!

如下,field DLAB 7是1bit 学员定义为2bit了,导致fIeld RESERVED_8变成了@9,而不是@8。

图片

修改ralf,然后重新生成reg_model,大家参考训练营文档执行即可。

图片

这篇关于UVM寄存器模型——手写Ralf问题debug的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/993114

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Python绘制TSP、VRP问题求解结果图全过程

《Python绘制TSP、VRP问题求解结果图全过程》本文介绍用Python绘制TSP和VRP问题的静态与动态结果图,静态图展示路径,动态图通过matplotlib.animation模块实现动画效果... 目录一、静态图二、动态图总结【代码】python绘制TSP、VRP问题求解结果图(包含静态图与动态图

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe