通过uvm_config_db类访问的UVM配置数据库,是在多个测试平台组件之间传递不同对象的绝佳方式。

methods

有两个主要函数用于从数据库中放入和检索项目,分别是 set() 和 get()。

static function void set (  uvm_component   cntxt,string          inst_name,string          field_name,T               value);static function bit get (   uvm_component  cntxt,string         inst_name,string         field_name,inout T              value);

rules

为 inst_name 中的 field_name 在 cntxt 下创建或更新配置设置;
该设置在 cntxt 下生效,完整作用域为 {cntxt, ".", inst_name};
若 cntxt 为空,则 inst_name 提供设置的完整作用域信息;
field_name 是目标字段;
inst_name 和 field_name 均可采用通配符风格或正则表达式风格的匹配模式;
来自更高层级结构的设置具有更高优先级;
同一层级结构的设置遵循"最后设置生效"语义;

how to debug uvm_config_db 

The best way to understand how the combination of cntxtinst_name and field_name works is by enabling the commandline debug +UVM_CONFIG_DB_TRACE switch for UVM that dumps information on all the set() and get() calls within a simulation.

$> irun <all_other_options> +UVM_CONFIG_DB_TRACE

example

我们将观察当从不同层级调用setget方法时,两个测试平台环境的行为表现。

1. Test and Env

要了解config_db如何验证表达式,我们将建立一个带有空环境的小型测试台结构,如下所示。表达式从测试类中设置,并在环境的build_phase阶段获取。

Case #1

我们将 cntxt 设为 null 并将 inst_name 设为 uvm_test_top,以表明测试中的所有组件都能访问该条目。为简化操作,我们将放入一个标记为 Friend 的字符串条目。

class base_env extends uvm_env;...string name;virtual function void build_phase (uvm_phase phase);super.build_name ();// Retrieve the string that was set in config_db from the test classif (uvm_config_db #(string) :: get (null, "uvm_test_top", "Friend", name))`uvm_info ("ENV", $sformatf ("Found %s", name), UVM_MEDIUM)endfunction
endclassclass base_test extends uvm_test;...base_env 	m_env;virtual function void build_phase (uvm_phase phase);...// Set this string into config_dbuvm_config_db #(string) :: set (null, "uvm_test_top", "Friend", "Joey");endfunction
endclass

很明显,第一个参数cntxt只能是uvm_component对象。从以下仿真日志可以看出,当+UVM_CONFIG_DB_TRACE作为命令行开关时,仿真会将所有对setget的函数调用记录到日志中。其中我们关注的行已用颜色高亮显示:黄色代表set调用,绿色代表成功的get调用。由于setget调用时的cntxtinst_namefield_name组合完全匹配,数据库成功找到并返回了标记为"Frie

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/88853.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/88853.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/88853.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(C++)任务管理系统(文件存储)(正式版)(迭代器)(list列表基础教程)(STL基础知识)

目录 前言&#xff1a; 源代码&#xff1a; 代码解析&#xff1a; 一.头文件和命名空间 1. #include - 输入输出功能2. #include - 链表容器3. #include - 字符串处理4. using namespace std; - 命名空间 可视化比喻&#xff1a;建造房子 &#x1f3e0; 二.menu()函数 …

Java 中的异步编程详解

前言 在现代软件开发中&#xff0c;异步编程&#xff08;Asynchronous Programming&#xff09; 已经成为构建高性能、高并发应用程序的关键技术之一。Java 作为一门广泛应用于后端服务开发的语言&#xff0c;在其发展过程中不断引入和优化异步编程的支持。从最初的 Thread 和…

MySQL逻辑删除与唯一索引冲突解决

问题背景 在MySQL数据库设计中&#xff0c;逻辑删除&#xff08;软删除&#xff09;是一种常见的实践&#xff0c;它通过设置标志位&#xff08;如is_delete&#xff09;来标记记录被"删除"&#xff0c;而不是实际删除数据。然而&#xff0c;当表中存在唯一约束时&am…

php命名空间用正斜杠还是反斜杠?

在PHP中&#xff0c;命名空间使用反斜杠&#xff08;\&#xff09;作为分隔符&#xff0c;这是PHP语言规范明确规定的。反斜杠在命名空间中扮演路径分隔的角色&#xff0c;用于区分不同层级的命名空间。 具体说明&#xff1a;语法规则 PHP命名空间使用反斜杠&#xff08;\&…

《从依赖纠缠到接口协作:ASP.NET Core注入式开发指南》

在C#的ASP.NET Core开发中&#xff0c;依赖注入绝非简单的技术技巧&#xff0c;而是重构代码关系的底层逻辑。它像一套隐形的神经网络&#xff0c;让程序模块摆脱硬编码的束缚&#xff0c;在运行时实现动态连接&#xff0c;从而为系统注入可测试、可进化的核心生命力。理解其深…

星云ERP本地环境搭建笔记

看到星云ERP两个比较实用的功能&#xff0c;编号规则和打印模板&#xff0c;如下图所示&#xff0c;于是本地跑起来学习学习。开发环境必备&#xff1a;1. JDK 1.82. MySQL 5.73. Redis 44. RabbitMQ 3.12.45. nodejs 206. pnpm 9.7.1 (npm install -g pnpm9.7.1)其他开发工具&…

RedisJSON 的 `JSON.ARRAPPEND`一行命令让数组动态生长

1 、 为什么选择 JSON.ARRAPPEND 在传统的键值模型里&#xff0c;若要往数组尾部追加元素&#xff0c;通常需要 取→改→写 三步&#xff1a; GET 整个 JSON&#xff1b;在应用层把元素 push 进数组&#xff1b;SET 回 Redis。 一条 JSON.ARRAPPEND 则可一次完成&#xff0c;具…

14:00开始面试,14:08就出来了,问的问题有点变态。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到4月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…

Unity物理系统由浅入深第四节:物理约束求解与稳定性

Unity物理系统由浅入深第一节&#xff1a;Unity 物理系统基础与应用 Unity物理系统由浅入深第二节&#xff1a;物理系统高级特性与优化 Unity物理系统由浅入深第三节&#xff1a;物理引擎底层原理剖析 Unity物理系统由浅入深第四节&#xff1a;物理约束求解与稳定性 物理引擎的…

深入浅出Kafka Consumer源码解析:设计哲学与实现艺术

一、Kafka Consumer全景架构 1.1 核心组件交互图 #mermaid-svg-JDEEOd2M5PzLkYa6 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-JDEEOd2M5PzLkYa6 .error-icon{fill:#552222;}#mermaid-svg-JDEEOd2M5PzLkYa6 .erro…

Matplotlib(一)- 数据可视化与Matplotlib

文章目录一、数据可视化1. 数据可视化的概念2. 数据可视化流程3. 数据可视化目的4. 常见的可视化图表4.1 折线图4.2 柱形图4.3 条形图4.4 堆积图4.4.1 堆积面积图4.4.2 堆积柱形图和堆积条形图4.5 直方图4.6 箱形图4.7 饼图4.8 散点图4.9 气泡图4.10 误差棒图4.11 雷达图二、Py…

传输层协议UDP原理

端口号回顾端口号的作用类似pid&#xff0c;用来标识进程的唯一性。只是为了与系统解耦&#xff0c;所以有了端口号。通过ip来确定唯一主机&#xff0c;再通过端口号找到指定的进程。就可以让全网内唯一的两个进程通信了。所以一个完整的报文至少要携带ip和端口号&#xff0c;i…

【牛客刷题】小红的数字删除

文章目录 一、题目介绍1.1 题目描述1.2 输入描述:1.3 输出描述:1.4 示例11.5 示例2二、解题思路2.1 核心观察2.2 关键问题处理三、算法实现四、算法分析4.1 算法流程图4.2 为什么这么设计算法?4.3 算法复杂度五、模拟演练数据示例1: "103252"示例2: "333&quo…

《大数据技术原理与应用》实验报告三 熟悉HBase常用操作

目 录 一、实验目的 二、实验环境 三、实验内容与完成情况 3.1 用Hadoop提供的HBase Shell命令完成以下任务 3.2 现有以下关系型数据库中的表和数据&#xff0c;要求将其转换为适合于HBase存储的表并插入数据&#xff1a; 四、问题和解决方法 五、心得体会 一、实验目的…

微服务初步入门

服务拆分原则 单一职责原则 单一职责原则原本是面向对象设计的一个基本原则&#xff0c;是指一个类应该专注于单一的功能&#xff0c;不要存在多于一个导致类变更的原因 在微服务架构中&#xff0c;是指一个微服务只负责一个功能或者业务领域&#xff0c;每个服务应该由清晰的定…

Liunx操作系统笔记5

用户管理命令&#xff1a; useradd命令&#xff1a; useradd命令的功能是创建并设置用户信息。使用useradd命令可以自动完成用户信息、基本组、家目录等的创建工作&#xff0c;并在创建过程中对用户初始信息进行定制。语法格式:useradd 参数 用户名常用参数: -M 不建立用…

spring-ai-alibaba 接入Tushare查询股票行情

最近spring-ai-alibaba主干分支新增了对Tushare的支持&#xff0c;一起来看看如何使用简单样例老样子&#xff0c;分三步进行&#xff1a;第一步&#xff1a;添加依赖<dependency><groupId>com.alibaba.cloud.ai</groupId><artifactId>spring-ai-aliba…

Java使用Langchai4j接入AI大模型的简单使用(一)

一、LangChain4j 简介 LangChain4j 是 Java 生态中的 LangChain 实现&#xff0c;是一个用于构建大语言模型(LLM)应用程序的框架。它提供了与各种LLM服务集成的能力&#xff0c;并简化了构建复杂AI应用的过程。 LangChain4j官方文档&#xff1a;Integrations | LangChain4j …

Linux —— A / 基础指令

建议学习路径&#xff1a;Linux系统与系统编程 ⇒ Linux网络和网络编程 ⇒ MySQL一、初识shell命令 1.1、关于 Linux 桌面很多同学的 Linux 启动进⼊图形化的桌⾯. 这个东西⼤家以后就可以忘记了。以后的工作中没有机会使用图形界面。思考: 为什么不使用图形界面? 1.2、下…

[论文阅读] 人工智能 + 软件工程 | 用大语言模型+排名机制,让代码评论自动更新更靠谱

LLMCup&#xff1a;用大语言模型排名机制&#xff0c;让代码评论自动更新更靠谱 LLMCup: Ranking-Enhanced Comment Updating with LLMsarXiv:2507.08671 LLMCup: Ranking-Enhanced Comment Updating with LLMs Hua Ge, Juan Zhai, Minxue Pan, Fusen He, Ziyue Tan Comments: …