• 概述UVM中的build、configure和connect【uvm】


    LINK

    UVM testbench开始发送激励之前,必须构建其组件层次结构以及验证组件之间的连接关系。

    UVM testbench 的第一阶段(phase)是build phase,在此阶段自上而下地实例化组成验证环境层次结构中的各个uvm_component类。

    Image

    当在顶层的initial 语句块中调用run_test()方法时,就开始激活验证平台的构建,即从testcase开始依次调用各组件的build_phase。在执行test case的build phase期间,需要准备好testbench配置对象,并将virtual interface赋值给testbench中各个组件中的virtual interface句柄。

    在下一级的层次结构(uvm_env)中,将根据从testcase获取的配置对象进一步地配置(uvm_agent)并可以根据实际情况进行更改。在build phase完成后,将开始connect phase确保完成所有组件之间的连接(自下而上)。等到所有的uvm_phase运行完成,会将控制权再给到test case。

    简而言之,在发送测试激励之前需要完成验证组件的构建、配置和组件之间的连接。

    Image

    UVM testbench 的构建过程从test case开始,决定了构建怎样的验证平台:

    • 进行factory override,以便将配置对象或组件对象替换为为派生类型

    UVM factory 允许一个UVM类在构建时被另一个派生类替换,必须在构建对象之前就指定factory override,因此需要在该组件上层的build phase进行指定。

    • 设置一个层次化的env配置对象,其中包含各种子组件所需的配置对象

    每个验证组件如env或agent ,都应该有一个定义其结构和行为的配置对象。这些配置对象应该在build phase方法中创建,并根据测试用例的要求进行配置。如果验证子组件的配置比较复杂或者可能需要发生更改,那么值得添加一个 virtual function调用并在扩展的测试用例中重载

    class spi_test_base extends uvm_test;
    `uvm_component_utils(spi_test_base
    • 1
  • 相关阅读:
    Tomcat为什么支持线程池?
    leetcode算法每天一题 020: 有效的括号(c++ stack<> queue<>的简单使用 )
    学习心得——数据预处理(探索性数据分析)
    IE停止维护 导致 @vue/cli-plugin-babel 编译失败
    LeetCode581:最短无序连续子数组
    深入分析APK文件格式
    Nginx自签名证书的配置
    设计模式—桥接模式
    声明式事务还是编程式事务,如何选择?
    基于Python+Tkinter实现一个贪食蛇小游戏
  • 原文地址:https://blog.csdn.net/weixin_39060517/article/details/126932086