news 2026/5/9 0:46:42

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

作者头像

张小明

前端开发工程师

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

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

这个案例和上一篇10-1基本类似,可以跳过,区别是这个案例少了上篇很奇怪的AA类的中间层

文章目录

  • ✅ 区别总结:代码1 与 代码2 的核心差异
  • UVM Phase执行顺序的准确解析:组件层次结构对执行顺序的影响
    • 一、核心问题:组件层次结构如何影响UVM Phase执行顺序
    • 二、关键代码差异:中间组件AA的有无
      • 代码1(包含多余中间组件AA):
      • 代码2(直接使用A组件,无多余中间层次):
    • 三、组件层次结构对比
      • 代码1的层次结构(包含AA中间组件):
      • 代码2的层次结构(直接使用A组件):
    • 四、执行顺序对比
      • 代码1的`build_phase`执行顺序(自底向上):
      • 代码2的`build_phase`执行顺序(自底向上):
    • 五、仿真日志对比
      • 代码1的build_phase日志:
      • 代码2的build_phase日志:
    • 六、关键分析:为什么这个差异很重要?
      • 1. UVM核心机制:自底向上执行顺序
      • 2. 日志输出顺序与执行顺序的混淆
      • 3. 为什么代码1中的AA是多余的?
    • 七、UVM最佳实践:组件层次结构设计
      • ✅ 正确做法(代码2风格):
      • ❌ 错误做法(代码1风格):
    • 八、UVM设计哲学:为什么需要自底向上执行?
      • 代码1的错误示例(如果在AA中访问a):
    • 九、UVM Phase执行顺序的权威验证
    • 十、结论:组件层次结构是UVM设计的核心
    • 十一、UVM最佳实践建议
      • ✅ 正确设计组件层次结构
      • ❌ 错误设计(避免)
    • 十二、总结

基于上一篇代码小修一下,这里将上一篇代码简称为1,修改后为2
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",
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 0:46:34

python用openpyxl操作excel-合并格式相同的excel文件

python用openpyxl操作excel-合并指定路径下格式相同的excel文件,参见如下实列代码import logging import com.pro001.log.pro_log_config as pro_log_config #参见另一篇博文 from openpyxl import Workbook, load_workbook from openpyxl.styles import Font, Ali…

作者头像 李华
网站建设 2026/5/9 11:26:43

基于Spring Boot的在线教育平台(源码+lw+部署文档+讲解等)

课题介绍本课题聚焦传统线下教育场景受限、优质教育资源分配不均的痛点,开展基于Spring Boot的在线教育平台的设计与实现工作。系统以Java作为核心开发语言,依托Spring Boot框架搭建轻量高效的后端服务架构,负责处理用户认证、课程管理、在线…

作者头像 李华
网站建设 2026/5/9 0:47:20

基于Python+django的智能停车系统的设计与实现(源码+lw+部署文档+讲解等)

课题介绍本课题聚焦传统停车场管理效率低、车位利用率不足、车主找位难的痛点,开展基于PythonDjango的智能停车系统的设计与实现工作。系统以Python作为核心开发语言,依托Django框架搭建高效稳定的后端服务架构,负责处理车位状态监测、车辆进…

作者头像 李华
网站建设 2026/5/9 0:47:19

基于Python+Django的智能停车管理系统(源码+lw+部署文档+讲解等)

课题介绍本课题聚焦传统停车场管理效率低、车位利用率不足、车主找位难的痛点,设计并开发基于PythonDjango的智能停车管理系统。系统以Python作为核心开发语言,依托Django框架搭建高效稳定的后端服务架构,负责处理车位状态监测、车辆进出管理…

作者头像 李华
网站建设 2026/5/9 0:46:43

代码随想录 1971.寻找图中是否存在路径

方法一&#xff1a;并查集class Solution {private int[] p;public boolean validPath(int n, int[][] edges, int source, int destination) {p new int[n];for(int i 0;i < n;i){p[i] i;}for(int[] e : edges){p[find(e[0])] find(e[1]);}return find(source) find(d…

作者头像 李华