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

uvm中的run_test作用

        在SystemVerilog和UVM验证环境中,run_test() 是启动UVM仿真流程的核心函数。它负责初始化UVM框架、创建测试用例实例,并触发UVM的Phase机制来执行验证环境的构建和运行

1. run_test() 的作用

run_test() 是UVM提供的内置函数,定义在UVM库中(uvm_root.svh),主要功能如下:

  • 初始化UVM根对象uvm_root),启动全局Phase流程。

  • 根据参数动态创建测试用例实例(通过UVM工厂机制)。

    • 根据指定的测试用例名称(通过参数或命令行),使用 UVM 的工厂机制创建相应的测试用例对象。

  • 触发UVM各阶段的执行(如 build_phaseconnect_phaserun_phase 等)。

    • 测试用例对象会调用 build_phase 方法,在这个阶段会创建并配置验证环境中的各个组件,如激励发生器(Sequencer)、驱动器(Driver)、监测器(Monitor)、计分板(Scoreboard)等。

  • 结束仿真:当所有阶段执行完毕后,仿真结束。

2. run_test() 的调用位置

通常在顶层模块(top)的 initial 块中调用,位于DUT实例化和时钟/复位生成之后:

module top;
    // 时钟和复位生成
    initial begin
        clk = 0;
        forever #5 clk = ~clk;
        rst = 1;
        #10 rst = 0;
    end

    // DUT实例化
    dut u_dut(.clk(clk), ...);

    // UVM启动
    initial begin
        // 配置接口到uvm_config_db(可选)
        uvm_config_db#(virtual dut_if)::set(null, "*", "dut_vif", dut_if_inst);
        // 启动测试用例
        run_test("my_test_case");
    end
endmodule

3. run_test() 的执行流程

(1) 初始化UVM根对象
  • 创建 uvm_root 单例
    UVM通过 uvm_root::get() 获取全局根对象,负责管理所有UVM组件和Phase调度。

(2) 动态创建测试用例
  • 工厂模式(Factory)
    run_test("my_test_case") 中的字符串参数对应一个已注册的测试用例类。
    UVM工厂根据该名称创建测试用例实例(my_test_case 必须通过 uvm_component_utils 宏注册)。

    class my_test_case extends uvm_test;
        `uvm_component_utils(my_test_case)  // 注册到工厂
        ...
    endclass

(3) 启动Phase机制
  • 自顶向下执行Phase
    run_test() 触发UVM的Phase流程,从根对象(uvm_root)开始,递归调用所有组件的Phase方法:

    1. build_phase:创建子组件并配置参数。

    2. connect_phase:连接TLM端口和分析端口。

    3. end_of_elaboration_phase:验证环境构建完成后的最终检查。

    4. start_of_simulation_phase:仿真开始前的初始化操作。

    5. run_phase:启动激励生成、监测和检查(并行执行)。

    6. run_phase 结束run_phase 是执行实际测试逻辑的主要阶段,当 run_phase 中的所有任务都完成后,该阶段结束。通常,测试用例中的激励生成、数据监测等操作都在这个阶段完成。
    7. 后续清理阶段执行run_phase 结束后,会依次执行后续的清理阶段。例如,extract_phase 用于提取测试结果数据,check_phase 用于检查测试结果是否符合预期,report_phase 用于生成测试报告。
    8. 验证环境结束:当所有阶段都执行完毕后,验证环境结束,仿真也随之停止。

 

相关文章:

  • C语言基础要素(007):使用变量
  • 自然语言处理NLP入门 -- 第十节NLP 实战项目 2: 简单的聊天机器人
  • uniapp 系统学习,从入门到实战(六)—— 样式与布局
  • [思考记录]AI时代下,悄然的改变
  • 大白话前端性能优化方法的分类与具体实现
  • Python 科学计算生态入门 2 - NumPy 基础与示例
  • Numpy基础知识
  • Highcharts 配置语法详解
  • redis repl_backlog_first_byte_offset 这个字段的作用
  • 安装 Windows Docker Desktop - WSL问题
  • NAT 代理服务 内网穿透
  • 【SQL】MySQL中的字符串处理函数:concat 函数拼接字符串,COALESCE函数处理NULL字符串
  • 详解ESP32使用select函数来监听串口数据
  • 99分巧克力
  • Python可视化大框架的研究与应用
  • Python大战Java:AI时代的编程语言‘复仇者联盟‘能否换C位?
  • Uniapp开发微信小程序插件的一些心得
  • AI Agent 定义与核心要素详解
  • 二、双指针——5. 移动零
  • SQLAlchemy系列教程:SQLAlchemy快速入门示例项目
  • 柳州做网站/代运营公司哪家好一些
  • 要建一个网站怎么做/百度惠生活怎么优化排名
  • 毕业设计做网站哪种好/cdq百度指数
  • 一个网站的成本/肇庆疫情最新情况
  • 甘肃做网站价格/网络推广公司是干嘛的
  • 华资源网站建设/俄罗斯搜索引擎入口 yandex