当前位置: 首页 > news >正文

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(
http://www.cnnetsun.cn/news/28679.html

相关文章:

  • 人工智能领域重大突破:Qwen3-VL-235B-A22B-Thinking模型引领多模态交互新纪元
  • 2025年12月最值得信赖的GEO代运营机构实力榜单
  • GSW-Gemma3-270M-20251206-1636-GGUF:轻量级对话模型部署与应用指南
  • Qt ---- Qt6.5.3 连接MySQL数据库
  • 63、网络资源与术语全解析
  • 49、Oracle数据库中Java与WebDB/Oracle Portal的配置与使用
  • 51、互联网应用服务器(iAS)全面解析
  • 15、C语言编程:风格、命名与文档的艺术
  • 腾讯混元大模型Hunyuan-Large开源在即:3890亿参数MoE架构引领AI技术新突破
  • NCMconverter:解锁网易云音乐加密文件的专业解决方案
  • 腾讯混元3D开源P3-SAM:引领三维零件分割进入全自动时代
  • NextStep-1横空出世:140亿参数开启连续令牌 autoregressive 图像生成新纪元
  • Llama-Factory能否用于构建智能营养师推荐系统?
  • 突破2.4万亿参数壁垒:文心大模型5.0全模态能力深度解析与实测
  • 通义大模型矩阵震撼发布:多模态AI技术引领千行百业智能化革命
  • 31、Linux文件所有权与权限设置全解析
  • 32、Linux 文件权限与网络连接管理全解析
  • 22、网络、互联网与万维网基础全解析
  • SElinux策略文件配置
  • 瑞士发布国家级开源大模型Apertus:AI公共基础设施的全球新范式
  • 2025年AI推理里程碑:Inclusion AI开源万亿参数模型Ring-1T,数学推理性能跃升14%
  • 5、内核调试技术全解析
  • 8、Linux内核中的时间处理、延迟与异步工作调度
  • 10、与硬件通信:I/O端口和内存的使用指南
  • 17、Linux 块设备驱动开发全面解析
  • 20、Linux内核开发资源与技术要点解析
  • 29、Linux系统启动与电源管理全解析
  • 32、深入理解进程与线程
  • 45、基于IP地址十六进制表示创建软件密钥及任意进制转换脚本
  • 中文跨模态里程碑:Chinese-CLIP-ViT-Base-Patch16模型深度解析与应用指南