UVM的callback机制

文章目录

    • 1.作用
    • 2.callback机制的实现
      • (1)首先定义类A:
      • (2)声明一个A_pool类
      • (3)my_driver中的uvm_register_cb宏
      • (4)my_driver中的uvm_do_callbacks宏
      • (5)从A派生的一个类:
      • (6)在测试用例中将my_callback实例化,并将其假如A_pool中:
    • 3.总结一下步骤
    • 4.debug

1.作用

callback机制最大的用处就是提高验证平台的可重用性,还可以构建异常用例。
广义的callback机制一般有pre_body和post_body,pre_do,mid_do,post_do。

2.callback机制的实现

(1)首先定义类A:

class A extends uvm_callback;
    virtual task pre_tran(my_driver drv,ref my_transaction tr);
    endtask
endclass

A类一定要从uvm_callback派生,另外还需要定义一个pre_tran任务,此任务的类型一定要是virtual的,因为从A派生的类需要重载这个任务。

(2)声明一个A_pool类

typedef uvm_callbacks#(my_driver, A) A_pool;
A_pool的声明相当简单,只需要一个typedef语句即可。另外,在这个声明中除了要指明这个A类型的池子外,还要指明这是一个A类型的池子外,还要指明这个池子将会被那个类使用。在本例中,my_driver将会使用这个池子,所以要将此池子声明为my_driver专用的。

(3)my_driver中的uvm_register_cb宏

typedef class A;

class my_driver extends uvm_driver#(my_transaction);
...
    `uvm_component_utils(my_driver)
    `uvm_register_cb(my_driver,A)
...
endclass

(4)my_driver中的uvm_do_callbacks宏

这个声明与A_pool的类似,要指明my_driver和A。在my_driver的main_phase中调用pre_tran时并不如上节所以的那么简单,而是调用了一个宏来实现:

task my_driver::main_phase(uvm_phase phase);
...
    while(1)begin
        seq_item_port.get_next_item(req);
        `uvm_do_callbacks(my_driver,A,pre_tran(this,req))
        driver_one_pkt(req);
        seq_item_port.item_done();    
    end
entask

uvm_do_callback宏的第一个参数是调用pre_tran的类的名字,这里自然是my_driver,第二个参数是那个类具有pre_tran,这里是A,第三个参数是调用的是函数/任务,这里是pre_tran,在指明的是pre_tran时,要顺便给出pre_tran的参数。
到目前为止是VIP的开发者应该做的事情,作为使用VIP的用户来说,需要做如下的事情:

(5)从A派生的一个类:

class my_callback extends A;
    

    vitual task pre_tran(my_driver drv,ref my_transaction tr);
        `uvm_info("my_callback","this is pre_tran task",UVM_MEDIUM)
    endtask
    
    `uvm_object_utils(my_callback)
    
endclass

(6)在测试用例中将my_callback实例化,并将其假如A_pool中:

function void my_case0::connect_phase(uvm_phase phase);
    my_callback my_cb;
    super.connect_phase(phase);
    my_cb = my_callback::type_id::create("my_cb");
    A_pool::add(env.i_agt.drv,my_cb);
endfunction

my_callback的实例化是在connect_phase中完成的,实例化完成后需要将my_cb加入A_pool中。同时,在加入时需要指定是那个 my_driver使用的。因为很可能整个base_test中实例化了多个my_env,从而有多个my_driver的实例,所以要将my_driver的路径作为add函数的第一个参数。

3.总结一下步骤

(1)定义一个A类
(2)声明一个A_pool类
(3)在要预留callback函数/任务接口的类中调用uvm_register_cb宏
(4)在要调用callback函数/任务接口的函数/任务重,使用uvm_do_callbacks宏
(5)在A类派生一个类,在这个类中定义好pre_tran
(6)在测试用例的connect_phase(或者其他phase,但是一定要在步骤(4)之前)中奖A派生的类实例化,并将其加入A_pool中

4.debug

发现根据上述代码会移植到其他框架中会出现错误
报错内容为:too many arguments to function/task call
the above function/task call is done with more aarguments than needed
解决方法:在步骤(1)和步骤(5)中都需要定义一下new

function new(string name = "A");
    super.new(name);
endfunction

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/910744.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

操作系统学习笔记-3.2虚拟内存

文章目录 虚拟内存请求分页管理方式页面置换算法最佳置换算法工作原理OPT 算法的示例最佳置换算法的优点和缺点 先进先出置换算法最近最久未使用时钟置换算法时钟置换算法的工作原理:算法的步骤: 改进型时钟置换算法改进型时钟置换算法的特点&#xff1a…

【数学】通用三阶矩阵特征向量的快速求法 超简单!!!

目录 三个定理1、3个特征值(即根互不相等)例题实践2、2个特征值(即有一个双重根)3、1个特征值(即有一个三重根)定理证明 三个定理 本定理适用于 所有三阶矩阵 的特征向量求法! 1、3个特征值&…

16通道AD采集方案,基于复旦微ARM + FPGA国产SoC处理器平台

测试数据汇总 表 1 本文带来的是基于复旦微FMQL20S400M四核ARM Cortex-A7(PS端) + FPGA可编程逻辑资源(PL端)异构多核SoC处理器设计的全国产工业评估板的AD采集案例。本次案例演示的开发环境如下: Windows开发环境:Windows 7 64bit、Windows 10 64bit PL端开发环境:P…

文件系统和日志管理

文件系统和日志管理 文件系统:文件系统提供了一个接口,用户用来访问硬件设备(硬盘、光驱)------------- 在硬件设备上对文件的管理 1、文件存储在硬盘上(机械硬盘:一个扇区 2、文件中硬盘上的最小存储单位…

数据结构---排序总结

1.排序的时间复杂度(均为平均值) O(n^2) :冒泡排序,选择排序,插入排序。 O(n * log(n)):堆排序,快速排序,归并排序。 O(n^1.3):希尔排序 2.空间复杂度: O(n) …

数据结构:七种排序及总结

文章目录 排序一插入排序1直接插入排序2希尔排序二选择排序3直接选择排序4堆排序三 交换排序5冒泡排序6快速排序四 归并排序7归并排序源码 排序 我们数据结构常见的排序有四大种,四大种又分为七小种,如图所示 排序:所谓排序,就是…

【操作系统】基于环形队列的生产消费模型

目录 一、单生产单消费 1.环形队列的实现 (1) void P(sem_t &sem); (2) void V(sem_t &sem); (3) RingQueue() (4) ~RingQueue() (5) void Push(const T &in); (6) void Pop(T *out); 2.上层调用逻辑 二、多生产多消费 1.环形队列的实现 (1) RingQueue…

Linux下的WatchDog

看门狗🐕 看门狗简介 看门狗定时器(Watchdog Timer)是一种定时器,用于检测系统是否正常运行。如果系统在规定时间内没有向看门狗定时器发送复位信号,看门狗定时器就会产生复位信号,使系统复位。看门狗定时…

基于SpringBoot的速食零食商城+LW示例参考

1.项目介绍 功能模块:管理端(用户管理、账号管理、商品分类管理、商品信息管理、订单管理等),用户端(商品信息、登录注册、我的订单等)技术栈:SpringBoot,thymeleaf,MyB…

springboot020基于Java的免税商品优选购物商城设计与实现

🍅点赞收藏关注 → 文档最下方联系方式领取本源代码、数据库🍅 本人在Java毕业设计领域有多年的经验,陆续会更新更多优质的Java实战项目希望你能有所收获,少走一些弯路。🍅关注我不迷路🍅 一 、设计说明 1…

认识物联网

新一代信息技术 物联网 物物相连的互联网,即物联网,又称传感器常见的传感器 • 温度传感器 • 压力传感器 • 声音传感器 • 02 • */08521 物联网概念 • 通过射频识别,红外传感器,全球定位系统GPS,激光扫描…

CODESYS可视化桌面屏保-动态气泡制作详细案例

#一个用于可视化(HMI)界面的动态屏保的详细制作案例程序# 前言: 在工控自动化设备上,为了防止由于人为误触发或操作引起的故障,通常在触摸屏(HMI)增加屏幕保护界面,然而随着PLC偏IT化的发展,在控制界面上的美观程度也逐渐向上位机或网页前端方面发展,本篇模仿Windows…

Java基础——反射

反射是框架设计的灵魂 (使用的前提条件:必须先得到代表的字节码的Class,Class类用于表示.class文件(字节码)) 翻译成人话就是:反射技术,指的是加载类的字节码到内存,并以…

Node.js——文件上传

文件上传 插件:formidable,地址:https://www.npmjs.com/package/formidable,参考里面with Express.js部分。 html部分截图参考: 用express-generator生成的示例代码: const formidable require(formi…

PCA9632笔记

个人学习笔记,有错漏。具体请以官方数据手册为准 I2C地址 PCA9632使用I2C通信,I2C设备地址固定 发出START后输出访问设备地址(8bit版本地址固定) 0x62(7位地址) 地址最后一位为1读 为0写 8位写地址 0xC4…

【算法】递归+回溯+剪枝:78.子集

目录 1、题目链接 2、题目 3、解法(回溯剪枝) 4、代码 1、题目链接 78.子集(LeetCode) 2、题目 3、解法(回溯剪枝) 思路: 枚举子集(答案)的第一个数选谁,第二个数选谁,第三个数选谁&#x…

HCIP(7)-边界网关协议BGP基本配置(对等体peer,宣告network,引入import)

边界网关协议(Border Gateway Protocol,BGP)是一种用来在路由选择域之间交换网络层可达性信息(Network Layer Reachability Information,NLRI)的路由选择协议。由于不同的管理机构分别控制着他们各自的路由…

基于python的机器学习(二)—— 使用Scikit-learn库

目录 一、样本及样本划分 1.1 划分样本的方法 1.1.1 train_test_split()函数 1.1.2 时间序列划分 1.1.3 交叉验证 二、导入或创建数据集 2.1 导入Sklearn自带的样本数据集 2.2 利用Sklearn生成随机的数据集 2.3 读入自己创建的数据集 2.3.1 用Python直接读取文本文件…

Webpack5常用配置

1、序言 Webpack属于构建工具,可以将开发者代码转化成浏览器能识别的代码,让开发者专注代码实现,不用过多关注浏览器兼容性问题。 Webpack常见功能: 模块打包:Webpack 可以将项目中的所有模块(包括 JavaScr…

DFA算法实现敏感词过滤

DFA算法实现敏感词过滤 需求:检测一段文本中是否含有敏感词。 比如检测一段文本中是否含有:“滚蛋”,“滚蛋吧你”,“有病”, 可使用的方法有: 遍历敏感词,判断文本中是否含有这个敏感词。 …