uvm factory

UVM Factory 是验证环境中实现动态对象和组件创建的核心机制,它通过类型注册和覆盖(Override)机制,允许在不修改原有代码的情况下替换组件或事务类型,从而提升验证环境的灵活性和可重用性。以下是Factory机制的详细解析:


Factory 的核心概念

  1. 核心作用

    • 动态对象创建:通过类型名称(字符串)或代理类(Proxy Class)创建对象。
    • 类型覆盖:在运行时替换默认组件或事务类型(例如将普通Driver替换为调试版本)。
    • 提高可维护性:解耦代码中的具体类型依赖,便于扩展和配置。
  2. 关键术语

    • 类型注册(Type Registration):将类注册到Factory,使其可被动态创建。
    • 代理类(Proxy Class):每个注册的类对应一个代理类(如 type_id),用于创建对象实例。
    • 覆盖(Override):指定用子类替换父类的规则。

Factory 的运作流程

  1. 类型注册
    使用 uvm_component_utils(组件类)或 uvm_object_utils(对象类)宏将类注册到Factory。

    class my_driver extends uvm_driver;`uvm_component_utils(my_driver)  // 注册组件类
    endclassclass my_transaction extends uvm_sequence_item;`uvm_object_utils(my_transaction)  // 注册对象类
    endclass
    
  2. 对象创建
    通过代理类(type_id::create())创建对象实例,Factory根据覆盖规则决定实际实例化的类型。

    my_transaction tr;
    tr = my_transaction::type_id::create("tr");  // 动态创建事务对象
    
  3. 类型覆盖
    在Test中指定用子类替换父类(例如替换默认Driver为调试Driver)。

    class debug_driver extends my_driver;`uvm_component_utils(debug_driver)
    endclass// 在Test中覆盖类型
    initial begindebug_driver::type_id::set_type_override(my_driver::get_type());
    end
    

Factory 的类型覆盖机制

1. 覆盖类型
  • 类型覆盖(Type Override)
    替换所有父类实例为指定子类(全局生效)。

    debug_driver::type_id::set_type_override(my_driver::get_type());
    
  • 实例覆盖(Instance Override)
    仅替换特定路径下的父类实例(例如只替换某个Agent中的Driver)。

    debug_driver::type_id::set_inst_override(my_driver::get_type(), "uvm_test_top.env.agent.driver"  // 组件层次路径
    );
    
2. 覆盖优先级
  • 实例覆盖 > 类型覆盖:若同时存在,实例覆盖优先生效。
  • 后设置的覆盖优先:同一类型的多次覆盖,最后一次生效。

Factory 的实际应用场景

1. 动态替换组件
  • 场景:在测试用例中替换默认Driver为支持协议调试的版本。
    class my_test extends uvm_test;function void build_phase(uvm_phase phase);// 覆盖默认Driver类型debug_driver::type_id::set_type_override(my_driver::get_type());super.build_phase(phase);endfunction
    endclass
    
2. 注入错误事务
  • 场景:在错误测试用例中,强制事务生成错误数据。
    class error_transaction extends my_transaction;`uvm_object_utils(error_transaction)constraint force_error { error == 1; }  // 强制错误标志
    endclass// 覆盖默认事务类型
    error_transaction::type_id::set_type_override(my_transaction::get_type());
    
3. 多配置环境复用
  • 场景:同一验证环境支持不同协议(如AXI和AHB),通过覆盖切换Agent类型。
    class axi_agent extends uvm_agent;`uvm_component_utils(axi_agent)
    endclass// 在Test中选择协议类型
    axi_agent::type_id::set_type_override(ahb_agent::get_type());
    

Factory 的底层实现原理

  1. 类型代理类(Proxy Class)

    • 每个注册的类自动生成一个代理类(如 my_driver::type_id)。
    • 代理类包含 create() 方法,用于实例化对象。
  2. 覆盖表(Override Table)

    • Factory维护一个全局表,记录父类与子类的映射关系。
    • 调用 create() 时,Factory检查覆盖表以决定实际实例化的类型。
  3. 创建流程

    my_driver::type_id::create("driver") → 检查是否被覆盖 → 实例化 debug_driver(若被覆盖)→ 否则实例化 my_driver
    

Factory 的最佳实践

  1. 明确注册所有类
    所有需要动态创建的组件和事务必须注册到Factory。

  2. 优先使用类型覆盖
    除非需要局部替换,否则使用类型覆盖简化配置。

  3. 避免循环覆盖
    确保覆盖关系是单向的(例如子类不能再覆盖父类)。

  4. 调试覆盖问题
    使用 print_override_info() 打印当前覆盖配置。

    initial beginmy_driver::type_id::print_override_info();
    end
    
  5. 与配置机制结合
    通过 uvm_config_db 传递覆盖信息,而非硬编码在Test中。


示例:完整Factory流程

// 定义基类Driver
class base_driver extends uvm_driver;`uvm_component_utils(base_driver)function new(string name, uvm_component parent);super.new(name, parent);endfunction
endclass// 定义调试Driver子类
class debug_driver extends base_driver;`uvm_component_utils(debug_driver)function new(string name, uvm_component parent);super.new(name, parent);endfunction
endclass// 在Test中覆盖Driver类型
class my_test extends uvm_test;function void build_phase(uvm_phase phase);debug_driver::type_id::set_type_override(base_driver::get_type());super.build_phase(phase);endfunction
endclass// 创建Driver时实际实例化debug_driver
base_driver drv;
drv = base_driver::type_id::create("drv", null);  // 实际创建的是debug_driver

总结

UVM Factory 是验证环境灵活性的核心机制,通过类型注册和覆盖,实现了“代码无需修改,行为动态可配”的目标。合理使用Factory机制,能够显著提升验证代码的可维护性和场景覆盖率,是现代芯片验证方法学中不可或缺的一部分。

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

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

相关文章

旅游CMS选型:WordPress、Joomla与Drupal对比

内容概要 在旅游行业数字化转型进程中,内容管理系统(CMS)的选择直接影响网站运营效率与用户体验。WordPress、Joomla和Drupal作为全球主流的开源CMS平台,其功能特性与行业适配性存在显著差异。本文将从旅游企业核心需求出发&…

LeetCode349两个数组的交集

思路: 这个题目是查找交集,考虑用哈希数组,c语言用数组建立哈希表来解题,题目限定了数组长度在1000以内,那么可以设定一个result数组用于存储交集 1.我们需要将nums1映射到哈希表中 2.遍历nums2查询哈希表中是否存在该…

安装教程:windows上安装oracle详细教程

文章目录 前言一、下载 Oracle 安装包二、安装步骤三、连接ORACLE可视化工具1.1 PL/SQL Developer1.2 navicat 结束语优质源码分享 windows上安装oracle详细教程,在Windows上安装Oracle数据库需遵循以下步骤:首先,从官网下载对应版本的Oracle…

4、网工软考—VLAN配置—hybird配置

1、实验环境搭建: 2、实验过程 SW1: 先创建vlan2和vlan3 [Huawei-Ethernet0/0/2]port link-type hybrid //hybird端口 [Huawei-Ethernet0/0/2]port hybrid pvid vlan 2 [Huawei-Ethernet0/0/2]port hybrid untagged vlan 10 //撕掉vlan10的标签 …

平台清洗行动:AI浏览器用户生存率高出传统方案17倍

平台清洗行动:AI 浏览器用户生存率高出传统方案 17 倍 在这个数字化时代,网络环境的复杂性不断增加,用户在浏览网页时面临着各种风险,包括恶意软件、钓鱼攻击和隐私泄露等。为了应对这些挑战,AI 浏览器应运而生&#…

【C++篇】C++入门基础(一)

💬 欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习! 👍 点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对C感兴趣的…

MaskFormer语义分割算法测试

MaskFormer是一套基于transformer结构的语义分割代码。 链接地址: https://github.com/facebookresearch/MaskFormer/tree/main 测试用的数据集:ADE20k Dataset MIT Scene Parsing Benchmark 该数据集可通过上述链接下载,其中training含有…

javaWeb vue的简单语法

一、简介 两大核心优势: 声明式渲染:Vue 基于标准 HTML 拓展了一套模板语法,使得我们可以声明式地描述最终输出的 HTML 和 JavaScript 状态之间的关系。 响应性:Vue 会自动跟踪 JavaScript 状态并在其发生变化时响应式地更新 D…

vue create创建 Vue-router 工程

vue create创建 Vue-router 工程 参考 创建vue项目的两种方式:vue-create与vite https://www.cnblogs.com/reverse-x/p/16806534.html Vue2 脚手架 创建工程 测试程序 https://blog.csdn.net/wowocpp/article/details/146590400 在 上面的基础上 cd .\vue2-demo\…

CXL UIO Direct P2P学习

前言: 在CXL协议中,UIO(Unordered Input/Output) 是一种支持设备间直接通信(Peer-to-Peer, P2P)的机制,旨在绕过主机CPU或内存的干预,降低延迟并提升效率。以下是UIO的核心概念及UI…

口腔种植全流程AI导航系统及辅助诊疗与耗材智能化编程分析

一、系统架构与编程框架设计 口腔种植全流程人工智能导航系统的开发是一项高度复杂的多学科融合工程,其核心架构需在医学精准性、工程实时性与临床实用性之间实现平衡。系统设计以模块化分层架构为基础,结合高实时性数据流与多模态协同控制理念,覆盖从数据采集、智能决策到…

李宏毅机器学习笔记(1)—机器学习基本概念+深度学习基本概念

机器学习基本概念 1、获取模型 步骤 1.1、假定未知函数 带未知参数的函数 1.2、定义损失函数 真实值:label MAE MSE 几率分布,cross-entropy? 1.3、优化 单独考虑一个参数 让损失函数最小,找导数为零的点 单独考虑w,w…

专注自习室:番茄工作法实践

专注自习室:番茄工作法实践 我需要一个任务管理工具,但在网上找了很多都找不到合适的工具。市面上的大多数产品过于强调任务完成性,给我带来了很强的心理压力,这种压力最终反而降低了我的工作效率。于是我决定自己动手&#xff0…

【银河麒麟高级服务器操作系统 】虚拟机运行数据库存储异常现象分析及处理全流程

更多银河麒麟操作系统产品及技术讨论,欢迎加入银河麒麟操作系统官方论坛 https://forum.kylinos.cn 了解更多银河麒麟操作系统全新产品,请点击访问 麒麟软件产品专区:https://product.kylinos.cn 开发者专区:https://developer…

阿里云数据学习20250327

课堂链接:阿里云培训中心 (aliyun.com) 一、课堂问题 (一)课时3 1.支持字符集的含义是什么

使用QuickReporter将多张图片插入在word多行的表格中

之前有一位QuickReporter的用户提到过一个需求。他有大量的图片需要插入在word里面,他的想法是将图片放在一个文件夹内,按编号1,2,3,...编号,然后自动将这些图片从前到后插入到表格中。 这次偶然发现了该需求是可以实现的,且在当…

【大模型】激活函数之SwiGLU详解

文章目录 1. Swish基本定义主要特点代码实现 2. GLU (Gated Linear Unit)基本定义主要特点代码实现 3. SwiGLU基本定义主要特点代码实现 参考资料 SWiGLU是大模型常用的激活函数,是2020年谷歌提出的激活函数,它结合了Swish和GLU两者的特点。SwiGLU激活函…

vs2017开启性能探测器失败

开启性能探测器失败 错误: 无法启用性能探测器服务没有及时响应启动或控制请求。 (HRESULT: 0xe1110002) Microsoft.DiagnosticsHub.Diagnostics.CollectionStartFailedHubException”的异常。 各种原因排查: 1.管理员启动 2.开启各种诊断服务&…

FPGA——分秒计数器设计(DE2-115开发板)

一、项目创建 1.创建工程 点击File->New Project Wizard...或者直接在页面处点击 在第一行选择文件存放地点,第二行为项目名称,第三行为顶级设计实体名称 (下面的步骤可以暂时不做直接点Finish,因为是先写代码先把它跑出来暂…

香蕉成熟度检测和识别1:香蕉成熟度数据集说明(含下载链接)

一. 前言 本篇博客是《香蕉成熟度检测和识别》系列文章之《香蕉成熟度数据集说明(含下载链接)》,网上有很多香蕉成熟度数据集的数据,百度一下,一搜一大堆,但质量参差不齐,很多不能用,即使一个一个的看也会…