UVM phase机制(一)

标签: UVM文章

UVM的执行严格按照phase机制在执行的,顺序是:

->build_phase
->connect_phase
->end_of_elaboration_phase
->start_of_simulation_phase
->run_phase
->extract_phase
->check_phase
->report_phase
->finial_phase
既然是按照上述所示执行,那么UVM的运行的过程中必然会生成相应的执行架构,下面我们来介绍一下UVM是如何生成phase的执行架构的

在介绍之前我们要知道phase家族的整体结构
在这里插入图片描述上图就是整个UVM_PHASE家族的整体架构,具体细节我们会在下面一一讲到

在调用uvm_root::run_test的时候会生成执行架构(在UVM中叫做domain),通过调用uvm_phase::m_run_phases,有关创建整个phase架构的核心是下面这个方法

uvm_domain::get_common_domain()

这个方法首先创建一个名字叫做common的domain,这里叫做common_domain,接着向这个common_domain中增加常规的phase,也叫做common_phase(非run_time phase),add方法如下。

common_domain.add(uvm_build_phase::get())

下面列出来是如何一步一步完成phase架构的
第一步:加入common phase
在这里插入图片描述
在这里插入图片描述
如上图所示,common_phase加入到common_domain中是以node的形式,每个node中有自有的变量指向这个node表示的phase,比如build_node
在这里插入图片描述
这样所有的common_phase均是以node的形式加入到common domain中构成phase架构,在phase架构中存在前驱后继的概念,比如build_node的前驱是common domain,后继是connect_node。这样的组织形式形成了链表式的结构,到目前为止,这个phase结构中所有的元素前驱后继的元素是唯一的。
第二步:生成uvm_schedule,这一步和第一步基本上完全一样,只是这一步加入的12个run time phase
在这里插入图片描述
第三步:生成uvm domain
这一步主要是将第二步生成的uvm_schedule结构加入到uvm domain中
在这里插入图片描述
第四步:将第三步生成的uvm domain加入到common domain中
在这里插入图片描述
在这一步中出现了一些变化,
首先start_of_simulation_node的后继变成两个,分别的run_node和uvm_domain。
其次extract_node的前驱变成两个,分别是run_node和uvm_end_node

这样通过上述的4步,最终生成了phase的执行结构->common domain

版权声明:本文为liuwei848原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/liuwei848/article/details/103751449

智能推荐

linux上安装Qt4.8.6+QtCreator4.0.3

一、Qt简介 Qt是1991年奇趣科技开发的一个跨平台的C++图形用户界面应用程序框架。它提供给应用程序开发者建立艺术级的图形用户界面所需的所有功能。Qt很容易扩展,并且允许真正地组件编程。 准备工作 操作系统:centos6.5 位数:64位 二、安装 1、获取源码Qt4.8.6 2、获取源码QtCreator4.0.3 2、安装QtCreator4.0.3 进入QtCreator安装界面,指定...

react-native metro 分析

文章目录 前言 概念 Resolution Transformation Serialization 打包方式 Moudles Plain bundle Indexed RAM bundle File RAM bundle 流程 前置流程 resolve流程 Transformer流程 序列化流程 缓存 为什么要缓存 缓存的请求与缓存 Metro配置 结构 前言 metro是一种支持ReactNa...

嵌入式Linux——应用调试:用户态打印段错误信息

简介:     很多时候我们会遇到段错误:segmentation fault,而段错误有时是由内核引起的,有时是由应用程序引起的。在内核态时,发生段错误时会打印oops信息,但是在用户态时,发生段错误却只会打印segmentation fault而并不会打印其他的信息。所以本文主要介绍在用户态时,通过修改内核设置和添加启动参数来打印引发segmentati...

springboot1.4.1整合logback 遇到的问题

springboot1.4.1整合logback 遇到的问题 项目使用了springboot1.4.1整合logback,然而设置的过期时间15 并没有生效, 2GB达到2G自动删除也没有生效,仅仅实现了按大小分割。 经过查看pom 父工程内的源码发现是默认的logback版本是1.1.7,而过期时间配置是在logback 1.1.8以后才支持的。 不得不说这是springboot1.4.1 的b...

记一次C/S架构的渗透测试

概述 目标站点是http://www.example.com,官网提供了api使用文档,但是对其测试后没有发现漏洞,目录、端口扫描等都未发现可利用的点。后发现官网提供了客户端下载,遂对其进行一番测试。 信息收集 先抓了下客户端的包,使用Fiddler和BurpSuite都抓不到,怀疑走的不是HTTP协议,用WireShark查看其确实用的是HTTP协议,但是数据包不好重放,这里最后使用了WSExp...

猜你喜欢

Linux:结合Securecrt进行文件上传(lrzsz)P2

1、安装rzsz软件   2、点击Scurecrt的option——X/Y/Z配置上传和下载目录   3、首先在Linux里切换到一个目录,然后用rz命令,文件就会上传到钙Linux的目录下   只要敲rz即可,然后在弹出的对话框里选择需要上传的文件即可 4、下载文件用sz   下载单个文件:在当前目录下有该文件     sz filename   下载...

SQL 提示作为 布局 生存工具指南

下面是一些展示AdventureWorks中表现最好的销售人员并列出他们的经理的结构化查询语言代码。 它产生以下结果。 所以,代码是有效的,但它是丑陋的。 如果我需要理解和改进代码,我首先需要把它变成可读的形式。 我有结构化查询语言提示,所以我可以按下计算机的ctrl按键键 踢你自己),它会应用默认的内置代码样式,并对此进行修复。 不,不是,因为我相信你仍然不喜欢它的格式。 没有两个开发人员能够就...

Vue+Springboot解决数据传输时参数格式不匹配问题

前端:使用的是ant design vue ,端口号为8000 后端:使用的是springboot框架开发,端口号为8080 需求:已经解决跨域问题,前端发送登录的信息给后台,后台接收不到 样例: 前端: 后台: 请求的数据格式为json格式,后台参数类型不匹配 解决方案 第一种: 修改后端,参数类型: 第二种方式: 在前端vue框架中加入qs插件,qs 是一个增加了一些安全性的查询字符串解析和序...

Flex布局做出自适应页面--语法和案例

本文发布在: github项目地址:https://github.com/tenadolanter/flex-layout-demo SegmentFault地址:https://segmentfault.com/a/1190000012916949/ CSDN地址:http://blog.csdn.net/qq_34648000/article/details/79115294 博客园地址:ht...

Java - 基于 Apache POI 创建 Excel 文件

基于 Apache POI 创建 Excel 文件 准备 新建 Maven Project,引入依赖: 创建行和列 设置列宽 设置列宽(第 19 行): 注意:其他行的首列的宽度是受第一行、第一列的影响而变宽,并非我们设置的。 设置字体颜色 设置字体颜色(第 25 ~ 31 行): 设置网页超链接 设置网页超链接(第 18、27 ~ 29 行): 参考 java操作excel常用的两种方式...