UVM中的class
UVM中的类包括:基类(base)------------uvm_void/uvm_object/uvm_transaction/uvm_root/uvm_phase/uvm_port_base
报告(reporting)--------uvm_report_object/uvm_report_handler/uvm_report_server/uvm_report_catcher
Factory---------uvm_*_register/uvm_factory
配置(config)------uvm_resource/uvm_resoure_db/uvm_config_db
sequencer--------uvm_sequencer_base/uvm_sequencer_param/uvm_squencer/uvm_push_sequencer
sequence--------uvm_sequence_item/uvm_sequence_base/uvm_sequence
sychronization------uvm_event/uvm_event_callback/uvm_barrier/uvm_objection/uvm_heartbeat
containers----------uvm_pool/uvm_queue
TLM
component--------uvm_component/uvm_callback/uvm_test/uvm_env/uvm_agent/uvm_monitor/uvm_scoreboard/
uvm_driver/uvm_push_driver/uvm_random_stimulus/uvm_subscriber/comparators
Reg model
Macro
Commamd Line
uvm_event/uvm_pool/uvm_queue完成对SV中event, queue, mailbox的封装,实现tlm的通信;
uvm_source利用uvm_pool完成factory机制的实现,实现重载和config_db;
uvm_callback实现callback的基类;
uvm_phase/uvm_objection实现uvm中phase的控制;
uvm_sequence/uvm_sequencer实现blueprint的环境设置;
1)uvm_void(virtual)---一个没有member和function的纯虚类。所有class的基类。
2)uvm_object(virtual)---data和component的基类,定义了一系列常用操作
virtual function:get_name/get_full_name/get_inst_id/do_copy/create
function:copy/compare/pack/pack_bytes
3)uvm_transaction(virtual)------variable:events-----event pool中为该transaction instance的event
begin_event/end_event
function:get_event_pool/set_initiator(initiator of this transaction)/get_initiator
is_active
4)uvm_root------所有uvm的潜在top-level,同时控制整个phase的执行。
virtual methods:run_test(+testname)或者cmd中加+UVM_TESTNAME=
function:print_topology/set_timeout
variable:uvm_top------const uvm_root uvm_top = uvm_root::get()
5)uvm_phase------用户可以extend自己的phase,基类(uvm_task_phase/uvm_topdown_phase/uvm_bottomup_phase)
(build phase是topbottom phase,connect是bottomtop phase)
virtual function:raise_objection/drop_objection/ exec_func/exec_task(CB)
function:jump
(new的时候,会有uvm_objection的类型传递)
uvm_factory用来创建UVM中的object和component,通过typedef和macro invocation来实现。

6)uvm_component_registry#(T,Tname)--------virtual function:get_type_name
static function:create/set_type_override/set_inst_override
7)uvm_object_registry#(T,Tname)--------virtual function:get_type_name
static function:create/set_type_override/set_inst_override
8)uvm_factory--------function:set_inst_override_by_type/set_inst_override_by_name/
set_type_override_by_type/set_type_override_by_name/
create_object_by_type/create_component_by_type/
create_object_by_name/create_component_by_name/
Configuration和Resource Class,提供一个database,供读写。通过queues的方式,可以保存scalar/class handle/
queues/list/virtual interface的结构,保存三部分内容name_table, type_table, set_of scope(通过expression实现)
uvm_resource_db:较低水平的resource database
uvm_config_db:较高水平的resource database,提供configuration的interface
9) virtual class uvm_resource_base--------task:wait_modified()
function:set_scope()
10)uvm_resource_pool--------static function:get()
funciton:set()/set_override()/set_name_override()/set_type_override()
lookup_name()/get_by_name()

11)uvm_resoure #(T)-----------function: read/write()/set/get_by_name/get_by_type
12)uvm_resoure_db #(T)-----------function:/set/get_by_name/get_by_type
13)uvm_config_db #(T)-----------static function:get()/set()/exist()/wait_modified()
uvm_event对SV中的event类型的一次封装:

14)uvm_event---------virtual task wait_on/wait_off/wait_trigger
virtual function reset/add_callback
15)uvm_event_callback(virtual)-------virtual function pre_trigger/post_trigger(uvm_event e, uvm_object data = null)
16)uvm_barrier-------virtual task wait_for()
virtual function reset()/set_threshold/get_threshold/cancel

uvm_objection的class,提供end_of_test的机制。
17)uvm_objection------virtual function raise_objection/drop_objection/raised/dropped/set_drain_time
Container class,针对SV中的queue和associative array做的封装。
18)uvm_pool #(type KEY = int, T = uvm_void)-----------get/add/num/delete/first/last/nect/prev

19)uvm_queue #(T)

UVM中的class的更多相关文章
- UVM中的sequence使用(一)
UVM中Driver,transaction,sequence,sequencer之间的关系. UVM将原来在Driver中的数据定义部分,单独拿出来成为Transaction,主要完成数据的rand ...
- UVM中的regmodel建模(三)
总结一下UVM中的寄存器访问实现: 后门访问通过add_hdl_path命令来添加寄存器路径,并扩展uvm_reg_backdoor基类,定义read与write函数,最后在uvm_reg_block ...
- UVM中的regmodel建模(一)
UVM中的regmodel继承自VMM的RAL(Register Abstract Layer),现在可以先将寄存器模型进行XML建模,再通过Synopsys 家的工具ralgen来直接生成regmo ...
- UVM中factory机制的使用
UVM中的factory机制一般用在sequence的重载,尤其是virtual sequence.当Test_case变化时,通过virtual sequence的重载,可以很容易构建新的测试. 因 ...
- UVM中的factory机制实现
首先在Systemverilog中便有对于重载的最基本的支持. 1)定义task/function时,使用virtual关键字.那之后在test_case中调用时,便使用句柄指向的对象的类型而不是句柄 ...
- uvm_hdl——DPI在UVM中的实现(四)
我们可以在uvm中实现HDL的后门访问,具体包括的function有uvm_hdl_check_path,uvm_hdl_deposit, uvm_hdl_force,uvm_hdl_release, ...
- UVM中的driver组件
一般UVM环境中的Driver组件,派生自uvm_driver. uvm_dirver派生自uvm_component. class uvm_driver #(type REQ = uvm_sequ ...
- UVM中的regmodel建模(二)
UVM的寄存器模型,对一个寄存器bit中有两种数值,mirror值,尽可能的反映DUT中寄存器的值.expected值,尽可能的反映用户期望的值. 几种常用的操作: read/write:可以前门访问 ...
- UVM中Callback机制
Callback机制,其实是使用OOP来实现的一种程序开发者向程序使用者提供的模块内部的接口.可以在Test_case的高度改变其他component的一些行为. Systemverilog中已经提供 ...
随机推荐
- Java_动态加载
Java类动态加载(一)——java源文件动态编译为class文件最近在做java动态加载这方面的工作,起初也遇到了很多困难.网上关于这方便的东西很零散,为了便于日后回过头来再看,于是我将这几天的心得 ...
- Maven_如何为开发和生产环境建立不同的配置文件 --我的简洁方案
其实也是最近才看Maven, 以前都是用ant+ivy, 对于轻量级的项目来说足够了, 而且非常灵活. 看了看Maven, 约定.... 现在编程都说约定, 约定是挺好, 问题是超出约定的事情太多了, ...
- Hibernate条件查询
设计上可以灵活的根据 Criteria 的特点来方便地进行查询条件的组装.现在对 Hibernate的Criteria 的用法进行总结:Hibernate 设计了 CriteriaSpecificat ...
- 关于Go,你可能不注意的7件事(转的)
http://tonybai.com/2015/09/17/7-things-you-may-not-pay-attation-to-in-go/ code https://github.com/bi ...
- Sumsets
题目连接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=91209#problem/A 题意:给定一个整数几何S,找出一个最大的d,使得a ...
- 1071. Speech Patterns (25)
People often have a preference among synonyms of the same word. For example, some may prefer "t ...
- [转载]CRect::DeflateRect
1基本内容 void DeflateRect(int x,int y); void DeflateRect(SIZE size); void DeflateRect(LPCRECT lpRect); ...
- angular.js学习笔记之一
angular也是一个MVC框架,其中M即model模型表示服务器,V即view视图代表html代码,C即control控制器用来处理用户交互的部分.
- C# 安装和卸载 Windows Service
特别注意: 安装Window Service 的时候,一定要用管理员打开命令提示符(cmd) 1. 创建Windows Service 服务项目 2. Service设计界面:右键-->选择安装 ...
- 非静态的字段、方法或属性“System.Web.UI.Page.ClientScript...”要求对象引用 (封装注册脚本)
在写项目时想对asp.net的注册前台脚本事件进行封装,就添加了一个BasePage.cs页面,但一直报错‘非静态的字段.方法或属性“System.Web.UI.Page.ClientScript.. ...