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类的特点,类的定义,成员与方法,构造函数,对象的复制和深/浅拷贝,父类/子类关系,类的继承,作用域的规则,对象的句柄以及赋值,方法 ...
随机推荐
- [development][vim] vim显示空白字符
1. 作为一个严谨的程序员,你必须关心你敲下过的没一个字符.其中包括空白字符. 2. 有时候你需要review别人的代码,对于哪些肆意使用tab,space,enter的人.你怎么发现那些被他们留下的 ...
- word 使用总结
1.标题: 开始->标题栏 2.插入目录: 引用---->更新目录 3.保持分页:页面布局->分隔符->分页符
- 使用@import导入实现了ImportBeanDefinitionRegistrar接口的类,不能被注册为bean
今天在调试公司spring项目的时候发现了这样一个问题,由于我们的项目使用的是springboot就以springboot为例,代码如下: @Import({DataSourceRegister.cl ...
- linux进程间通信同步-共享内存
参考:https://www.cnblogs.com/charlesblc/p/6142868.html 使用有名信号量,sem_open().sem_close().sem_post().sem_w ...
- 防止atoi函数内存越界
函数形式为: int atoi(const char *nptr); 函数说明: 参数nptr字符串,如果第一个非空格字符不存在或者不是数字也不是正负号则返回零,否则开始做类型转换,之后检测到非 ...
- 洛谷P4425 转盘 [HNOI/AHOI2018] 线段树+单调栈
正解:线段树+单调栈 解题报告: 传送门! 1551又是一道灵巧连题意都麻油看懂的题,,,,所以先解释一下题意好了,,,, 给定一个n元环 可以从0时刻开始从任一位置出发 每次可以选择向前走一步或者在 ...
- es中如何定位不合法搜索
GET /test_index/test_type/_validate/query?explain{ "query": { "math": { "te ...
- python json 模块
什么是json? json是返回的是字符串格式,把python数据类型列表.字典转换成json字符串格式, 这种格式java php 其他语言都可以认识的字符串,可以跨语言交流. json,用于字符串 ...
- 数据库——MySQL及安装
what's the MySQL MySQL是一个关系型数据库管理系统,MySQL 是目前最流行的关系型数据库管理系统之一,在 WEB 应用方面MySQL是最好的 RDBMS (Relational ...
- open():打开文件
1.open():使用指定的模式和编码打开文件,返回文件读写对象 2.使用说明: (1)使用格式:open(filename [, mode [, bufsize]])(2)打开一个文件,返回一个fi ...