uvm设计分析——callback
uvm_callback,设计者在进行class的function设计时,有意留下的一些hook,总是遍历某个pool中的对象;
使用者在使用时,将实现添加到某个pool中;
callback中,最重要的三个class;
1)pool类,uvm_callbacks,实现pool的register和add;
2)调用接口类,uvm_callback_iter,实现对pool中对象的遍历;
3)uvm_callback,供extend的基础类,只是定义了callback的mode;
uvm_callbacks类:其中定义了两类pool:
1)不指定uvm_object(null类型)的,m_tw_cb_q;
2)指定具体的uvm_object的,m_pool;

uvm_callbacks_base,只是实现了add和register的小的function的原型定义;
定义了m_b_inst的static变量,以及m_pool的以uvm_object为索引的,uvm_queue,
uvm_typed_callbacks,实现了对uvm_queue中的callback进行add,delete,get,find的function;
定义了m_t_inst的static变量,以及m_tw_cb_q类型的uvm_queue,其中保存uvm_callback;
uvm_callbacks,定义了register,add,delete,add_by_name,delete_by_name的function;
add function,会根据uvm_object是会为null,来判断是写入m_pool还是tw_cb_q中;
delete function,类似;add_by_name,delete_by_name,首先根据uvm_root找到
某个child的对象queue,之后再遍历调用相应的函数;
m_get_q,根据uvm_object是否为null,来拿到tw_cb_q或者m_pool中的queue;
uvm_derived_callbacks,目前感觉用处不大;
之上定义的很多function都是static类型,
uvm_callback_iter,参数化uvm_object,以及uvm_callback的两个参数,虽然pool或者queue都是static的;
但是uvm_object以及callback可以作为删选类型,来保证拿到的queue是需要的那一组;
static函数,first,last,next,prev;
uvm_callback,只定义了enable_mode,其他的function,都供设计者,进行extend设计,
然后使用者在进行extend,继而add到相应的pool,
所以uvm_callback会被继承两层。
callback相关的macros:
1)由于很多参数化类的关系,所以callbacks以及callback_iter都对具体类型进行了typedef;
如对于uvm_reg,分别对pool和iter进行了typedef;uvm_reg_cbs是设计者已经extend的一级class;

2)对register函数的包装:
macros,uvm_register_cb(T,CB),调用相应callbacks的m_register_pair函数;
3)do callback函数的包装;
macros,uvm_do_callbacks,遍历iter提供的对象;可以直接在宏中制定function名字;

macros,uvm_do_obj_callbacks_exit_on,在函数的某个返回值,退出;
应用中,环境设计者:
1)对uvm_callbacks进行typedef;

2)从uvm_callback extend出新的class;

3)在相应的component中留下function接口;

使用者:
1)从uvm_driver_callback extend出新的实现function的class;可以不同的实现都做extend;


2)在top上进行new和add 操作;

这样cb1和cb2 对象都被加到m_root中以driver为索引的uvm_queue中;
add函数的调用,可以不同bus_driver_cbs_t,也可以使用其他的pool的def,但是必须保证存在该class;
add函数,只需要uvm_object对象,以及相应实现正确类型的callback对象;
uvm设计分析——callback的更多相关文章
- uvm设计分析——field automation
uvm中的field_automation主要实现了class中的基础元素的copy,compare等函数, 实现方式分为两种:1)用户注册,field系列宏:uvm内部调用static status ...
- UVM中Callback机制
Callback机制,其实是使用OOP来实现的一种程序开发者向程序使用者提供的模块内部的接口.可以在Test_case的高度改变其他component的一些行为. Systemverilog中已经提供 ...
- uvm设计分析——reg
项目中的reg_model一般只有一份,set到reg_sequence上,所以多个sequence并行启动结束的时候,reg model会成为一个共享资源. uvm_reg_field中的volat ...
- uvm设计分析——factory
uvm的factory机制,通过实例一个static类型default factory,并且通过宏将所有例化extend出来的object,component register到该factory的内部 ...
- uvm设计分析——report
uvm_report实现中的类图,如下: 1)uvm_component均从uvm_report_object extend而来,其中定义了report_warning,error,info,fata ...
- uvm设计分析——tlm
tlm模块,用来在不同模块之间实现实时通信,主要基于两个定义在通信双方的port类来实现. 两个port之间,通过connect函数,来拿到双方的class指针,进而调用对方的function. 但是 ...
- callback源码分析——callbacks
uvm的callback必须是提供者有预见性的留一些方法在function前后,这样在使用的时候,进行遍历调度即可 设计者,需要从uvm_callback定义一个基类,只定义function原型,定义 ...
- UVM中的class
UVM中的类包括:基类(base)------------uvm_void/uvm_object/uvm_transaction/uvm_root/uvm_phase/uvm_port_base 报告 ...
- (转)UVM内容梗概
1. 类: 面向对象基础传统的面向对象编程与systemverilog类的特点,类的定义,成员与方法,构造函数,对象的复制和深/浅拷贝,父类/子类关系,类的继承,作用域的规则,对象的句柄以及赋值,方法 ...
随机推荐
- [Day3]Scanner类、Random类、流程控制语句
1.Scanner类 (1)Scanner类属于引用数据类型 数据类型 变量名=new 数据类型(); (2)每种引用类型都有自己的功能 变量.功能名(); (3)Scanner类是引用数据类型的一种 ...
- [development][dpdk] dpdk与CONFIG_RTE_MAX_MEMSEG有关的错误
dpdk程序无法启动, 错误如下: EAL: Requesting pages of size 2MB EAL: Requesting pages of size 2MB EAL: Can only ...
- python实现单链表反转(经典笔试题)
https://blog.csdn.net/su_bao/article/details/81072849 0.说在前面的话 链表结构,说难不难,说易不易,一定要亲自编程实现一下.其次就是一定要耐心, ...
- 转:Mysql float类型where 语句判断相等问题
原文地址:https://www.2cto.com/database/201111/111983.html 原文内容如下: Mysql where 语句中有float 类型数据判断相等时,检索不出记录 ...
- Transparent HugePages(透明大页)
Transparent HugePages(透明大页) 1. 介绍 从RedHat6, RedHat7, OL6, OL7 SLES11 and UEK2 kernels开始,透明大页默认是被开启的以 ...
- iOS APP 在前台时弹出本地通知
iOS10 之后使用才有效果 1.在 AppDelegate.m 文件里面添加下面的方法. - (void)userNotificationCenter:(UNUserNotificationCent ...
- JavaScript学习(五)
- IGMP协议
IGMP报文格式: 4bit的IGMP版本(1)+4bit的IGMP类型(1-2)+8bit未用+16bit检验和(同ICMP)+32bit组地址(D类IP地址) 类型为1说明是由多播路由器发出的查询 ...
- 萌新接触前端的第二课——CSS
前端知识——CSS CSS(英文全称:Cascading Style Sheets) 中文名层叠样式表,是一种用来表现HTML或XML等文件样式的计算机语言.CSS不仅可以静态地修饰网页,还可以配合各 ...
- 2017-2018-2 20165236 实验四《Android开发基础》实验报告
2017-2018-2 20165236 实验四<Android开发基础>实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:郭金涛 ...