news 2026/2/16 11:17:27

10-1 phase:basic UVM测试平台层次结构与Phase执行顺序解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
10-1 phase:basic UVM测试平台层次结构与Phase执行顺序解析

文章目录

  • 原始代码及log
  • UVM测试平台层次结构与Phase执行顺序解析
    • 🧩 仿真结果图示
  • UVM测试平台层次结构与Phase执行顺序深度解析
    • 🧩 仿真结果图示
    • 🔍 UVM Phase执行顺序核心原理
      • ✅ UVM Phase执行顺序规则
    • 🧪 UVM组件层次结构分析
    • 📊 Phase执行时间线分析
      • 1. build_phase (0ns)
      • 2. end_of_elaboration_phase (0ns)
      • 3. start_of_simulation_phase (0ns)
      • 4. run_phase (关键阶段)
    • ✅ UVM Phase执行顺序核心原则
      • 1. 构建阶段(build_phase):自底向上
      • 2. 运行阶段(run_phase):自顶向下
      • 3. 结束阶段(extract/check/report_phase):自底向上
    • 🔥 本例的关键发现
    • 💡 为什么其他组件的run_phase在500ns前结束?
    • ✅ UVM最佳实践总结
      • ✅ 正确使用UVM Phase
      • ✅ 测试结束协调
      • ✅ 组件层次设计
    • 💬 与UVM官方文档一致
    • ✅ 重要结论
  • 追更
  • build_phase执行顺序与打印顺序
    • ✅ UVM官方文档确认
    • ✅ 仿真结果验证
    • 仿真日志的打印顺序示例
    • UVM测试平台设计规范
    • 💬 为什么UVM设计为build_phase自底向上?

原始代码及log

module top;import uvm_pkg::*;//Create a topology// top// | |// u1(A) u2(A)// | | | |// b1(B) d1(D) b1(B) d1(D)//No run phaseclassDextends uvm_component;functionnew(string name,uvm_component parent);super.new(name,parent);endfunction functionvoidbuild_phase(uvm_phase phase);$display("%0t: %0s: build",$time,get_full_name());endfunction functionvoidend_of_elaboration_phase(uvm_phase phase);$display("%0t: %0s: end_of_elaboration",$time,get_full_name());endfunction functionvoidstart_of_simulation_phase(uvm_phase phase);$display("%0t: %0s: start_of_simulation",$time,get_full_name());endfunction functionvoidextract_phase(uvm_phase phase);$display("%0t: %0s: extract",$time,get_full_name());endfunction functionvoidcheck_phase(uvm_phase phase);$display("%0t: %0s: check",$time,get_full_name());endfunction functionvoidreport_phase(uvm_phase phase);$display("%0t: %0s: report",$time,get_full_name());endfunction endclass//Has run phaseclassBextends uvm_component;rand logic[7:0]delay;functionnew(string name,uvm_component parent);super.new(name,parent);endfunction functionvoidbuild_phase(uvm_phase phase);$display("%0t: %0s: build",$time,get_full_name());endfunction functionvoidend_of_elaboration_phase(uvm_phase phase);$display("%0t: %0s: end_of_elaboration",$time,get_full_name());endfunction functionvoidstart_of_simulation_phase(uvm_phase phase);$display("%0t: %0s: start_of_simulation",$time,get_full_name());endfunction functionvoidextract_phase(uvm_phase phase);$display("%0t: %0s: extract",$time,get_full_name());endfunction functionvoidcheck_phase(uvm_phase phase);$display("%0t: %0s: check",$time,get_full_name());endfunction functionvoidreport_phase(uvm_phase phase);$display("%0t: %0s: report",$time,get_full_name());endfunction taskrun_phase(uvm_phase phase);$display("%0t: %0s: start run phase",$time,get_full_name());#delay;$display("%0t: %0s: end run phase",$time,get_full_name(
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/10 17:25:57

人工智能行业迎来新突破:多模态大模型推动智能交互变革

人工智能行业迎来新突破:多模态大模型推动智能交互变革 【免费下载链接】granite-4.0-h-small 项目地址: https://ai.gitcode.com/hf_mirrors/unsloth/granite-4.0-h-small 近年来,人工智能技术的发展呈现出日新月异的态势,尤其是大语…

作者头像 李华
网站建设 2026/2/13 5:27:12

46、Windows Server 2008 网络管理指南之上

Windows Server 2008 网络管理指南之上 1. 域的创建 在网络管理中,创建域是一项基础且重要的工作。要创建一个新的域,首先需指定一台 Windows Server 2008 R2 系统作为新域的控制器。你可以使用相关向导来完成这一操作,此向导在首次安装 Windows Server 2008 R2 时会自动启…

作者头像 李华
网站建设 2026/2/15 22:08:00

40、Oracle数据库在Unix和Linux系统中的内存与磁盘I/O管理

Oracle数据库在Unix和Linux系统中的内存与磁盘I/O管理 1. ISM与LOCK_SGA参数 1.1 ISM(Intimate Shared Memory) 在Solaris 2.6及更高版本,以及Oracle 8i及更高版本中,ISM默认是启用的。数据库中的 init.ora 参数 USE_ISM 默认将该参数设置为 TRUE 。可以在操作系统…

作者头像 李华
网站建设 2026/2/9 11:37:20

BUPT网络安全之防火墙实验(实验三)

实验目的 (一)配置linux系统下iptables防火墙 1.学习iptables防火墙基本操作。 2.设置iptables防火墙的包过滤规则,分别实现以下功能:禁止所有主机ping本地主机;仅允许某特定IP主机ping本地主机;允许每…

作者头像 李华
网站建设 2026/2/13 15:55:03

20、C语言内存模型与存储管理全解析

C语言内存模型与存储管理全解析 1. C语言内存模型规则 在C语言中,变量和复合字面量的访问有着严格的规则。变量和复合字面量必须通过其声明的类型或字符类型指针来访问,且该规则没有例外,不能更改此类变量或复合字面量的类型。 例如以下代码: unsigned char A[sizeof(…

作者头像 李华