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

embedded/2024/10/21 9:53:20/

寄存器模型是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,大家参考训练营文档执行即可。

图片


http://www.ppmy.cn/embedded/41922.html

相关文章

【Leetcode每日一题】 动态规划 - 简单多状态 dp 问题 - 删除并获得点数(难度⭐⭐)(76)

1. 题目解析 题目链接:LCR 091. 粉刷房子 这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。 2.算法原理 1. 状态定义 在解决这类问题时,我们首先需要根据题目的具体要求来定义状态。针对房屋粉刷问题&#…

【个人成长】Fitten Code 测试案例分析

JS,Fitten Code 当插件,然后在代码分析的时候,有些小感悟,大模型写代码的思路,正常我理解的代码思路。 输入代码 (item.score* 100).toFixed(0)Prompt 得出的结果 5分,如果超过100按100算输出结果 con…

代码审计-php篇之某CRM系统多处sql注入

🌟 ❤️ 作者:yueji0j1anke 首发于公号:剑客古月的安全屋 字数:3516 阅读时间: 35min 声明:请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果…

Lora训练Windows[笔记]

一. 使用kohya_ss的GUI版本(https://github.com/bmaltais/kohya_ss.git) 这个版本跟stable-diffusion-webui的界面很像,只不过是训练模型专用而已,打开的端口同样是7860。 1.双击setup.bat,选择1安装好xformers,pytorch等和cuda…

docker容器技术篇:rancher管理平台部署kubernetes集群

rancher管理平台部署kubernetes集群 Rancher 是一个 Kubernetes 管理工具,让你能在任何地方和任何提供商上部署和运行集群。 Rancher 可以创建来自 Kubernetes 托管服务提供商的集群,创建节点并安装 Kubernetes,或者导入在任何地方运行的现…

electron 视频抓图并保存图片到本地

1. 思路: 1.1 通过canvas生成一块画布,在画布上绘制图形 let videoEl document.getElementById("testVideo");let params {videoEl,quality:0.95}let canvasEl document.createElement(canvas);canvasEl.width videoEl.width;canvasEl.he…

表白成功率百分百的向女朋友表白网页源代码,向女友表白HTML源代码

表白成功率百分百的向女朋友表白网页源代码&#xff0c;向女友表白HTML源代码 效果&#xff1a; 完整代码下载地址&#xff1a;向女友表白HTML源代码 <!DOCTYPE html> <!--STATUS OK--> <html><head><meta http-equiv"Content-Type" c…

254 基于matlab的钢筋混凝土非线性分析

基于matlab的钢筋混凝土非线性分析&#xff0c;根据梁本构关系&#xff0c;然后进行非线性分析&#xff0c;绘制弯矩-曲率曲线。可设置梁的截面尺寸、混凝土本构&#xff0c;钢筋截面面积等相关参数&#xff0c;程序已调通&#xff0c;可直接运行。 254 钢筋混凝土非线性分析 弯…