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的更多相关文章

  1. uvm设计分析——field automation

    uvm中的field_automation主要实现了class中的基础元素的copy,compare等函数, 实现方式分为两种:1)用户注册,field系列宏:uvm内部调用static status ...

  2. UVM中Callback机制

    Callback机制,其实是使用OOP来实现的一种程序开发者向程序使用者提供的模块内部的接口.可以在Test_case的高度改变其他component的一些行为. Systemverilog中已经提供 ...

  3. uvm设计分析——reg

    项目中的reg_model一般只有一份,set到reg_sequence上,所以多个sequence并行启动结束的时候,reg model会成为一个共享资源. uvm_reg_field中的volat ...

  4. uvm设计分析——factory

    uvm的factory机制,通过实例一个static类型default factory,并且通过宏将所有例化extend出来的object,component register到该factory的内部 ...

  5. uvm设计分析——report

    uvm_report实现中的类图,如下: 1)uvm_component均从uvm_report_object extend而来,其中定义了report_warning,error,info,fata ...

  6. uvm设计分析——tlm

    tlm模块,用来在不同模块之间实现实时通信,主要基于两个定义在通信双方的port类来实现. 两个port之间,通过connect函数,来拿到双方的class指针,进而调用对方的function. 但是 ...

  7. callback源码分析——callbacks

    uvm的callback必须是提供者有预见性的留一些方法在function前后,这样在使用的时候,进行遍历调度即可 设计者,需要从uvm_callback定义一个基类,只定义function原型,定义 ...

  8. UVM中的class

    UVM中的类包括:基类(base)------------uvm_void/uvm_object/uvm_transaction/uvm_root/uvm_phase/uvm_port_base 报告 ...

  9. (转)UVM内容梗概

    1. 类: 面向对象基础传统的面向对象编程与systemverilog类的特点,类的定义,成员与方法,构造函数,对象的复制和深/浅拷贝,父类/子类关系,类的继承,作用域的规则,对象的句柄以及赋值,方法 ...

随机推荐

  1. Entity Framework 6如何进行导航属性的筛选(context.Msg.First(t=>t.Id==1).Include(t=>t.MsgDetail),筛选MsgDetail带条件)

    问题: https://q.cnblogs.com/q/98333/ Msg表(Id,Content,IsDel).内有 virtual ICollection<MsgDetail> Ms ...

  2. day 0308 编码的进阶 文件操作

    一.编码的进阶: 在python3以后,字符串和bytes类型彻底分开,字符串以字符为单位进行处理的,bytes类型是以字节为单位处理的. bytes数据类型在所有的操作和使用与字符串方法基本一样,也 ...

  3. Boost 常用的库

    boost是一系列C++模板库组成的免费,可移植,开源的程序库.网络上关于boost的文章已经很多.     这里摘记一些库的信息,供自己日后参考. 0.foreach - BOOST_FOREACH ...

  4. teamviewer 卸载干净

    1 点击开始菜单,控制面板,卸载程序,找到软直接卸载2 按住Ctrl+R,输入%AppData%,删除teamview 相关文件夹3 输入regedit打开注册表HKEY_LOCAL_MACHINE\ ...

  5. postgre

    切换用户:su postgres 启动:psql 查看有哪些数据库: \l 切换到数据库air: \c air 列出数据库中所有表: \d 列出指定表的所有字段信息: \d+ dag 或者 \d da ...

  6. 内部排序->交换排序->快速排序

    文字描述  快速排序是对起泡排序的一种改进.它的基本思想是,通过一趟排序将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个 ...

  7. LeetCode 812 Largest Triangle Area 解题报告

    题目要求 You have a list of points in the plane. Return the area of the largest triangle that can be for ...

  8. 安装IIS

    1.打开控制面板,找到“程序与功能”,点进去  2.选择打开或关闭Windows功能,选择internet信息服务,点击确定 3.安装完成后,再回到控制面板里面,找到“管理工具”,点进入 4.双击“I ...

  9. JavaScript学习笔记--语言工具的了解

    基础学习,快速入门资料:网站 https://www.liaoxuefeng.com ,http://www.runoob.com/js/js-tutorial.html 笔记: 编程工具:SubLi ...

  10. python-面向对象-12_模块和包

    模块和包 目标 模块 包 发布模块 01. 模块 1.1 模块的概念 模块是 Python 程序架构的一个核心概念 每一个以扩展名 py 结尾的 Python 源代码文件都是一个 模块 模块名 同样也 ...