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

相关文章

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

如何安装HWE内核? Ubuntu安装hwe内核解决硬件太新的问题

《如何安装HWE内核?Ubuntu安装hwe内核解决硬件太新的问题》今天的主角就是hwe内核(hardwareenablementkernel),一般安装的Ubuntu都是初始内核,不能很好地支... 对于追求系统稳定性,又想充分利用最新硬件特性的 Ubuntu 用户来说,HWEXBQgUbdlna(Har

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

MAVEN3.9.x中301问题及解决方法

《MAVEN3.9.x中301问题及解决方法》本文主要介绍了使用MAVEN3.9.x中301问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录01、背景02、现象03、分析原因04、解决方案及验证05、结语本文主要是针对“构建加速”需求交

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc

使用@Slf4j注解,log.info()无法使用问题

《使用@Slf4j注解,log.info()无法使用问题》在使用Lombok的@Slf4j注解打印日志时遇到问题,通过降低Lombok版本(从1.18.x降至1.16.10)解决了问题... 目录@Slf4androidj注解,log.info()无法使用问题最后解决总结@Slf4j注解,log.info(

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行