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)beginseq_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

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spark本地模式安装

【图书介绍】《Spark SQL大数据分析快速上手》-CSDN博客 《Spark SQL大数据分析快速上手》【摘要 书评 试读】- 京东图书 大数据与数据分析_夏天又到了的博客-CSDN博客 Hadoop完全分布式环境搭建步骤-CSDN博客,前置环境安装参看此博文 Spark本地模式安装 Spark本地模式的安…

SpringSecurity6+OAuth2.0 从入门到熟练使用

文章目录 简介1、快速入门1.1 准备工作我们先要搭建一个SpringBoot工程① 创建工程 添加依赖② 创建启动类③ 创建Controller1.2 引入SpringSecurity2、 认证2.1 登录校验流程2.2 原理分析2.2.1 SpringSecurity完整流程2.2.2 认证流程详解概念速查:2.3 解决问题2.3.1 思路分析2…

计算机网络——SDN

分布式控制路由 集中式控制路由

自动驾驶革命:从特斯拉到百度,谁将主宰未来交通?

内容概要 自动驾驶技术正在经历一个前所未有的革命性变化,各大企业纷纷抢占这一充满潜力的新市场。以特斯拉和百度为代表的行业巨头,正利用各自的优势在这一技术的赛道上展开激烈竞争。特斯拉凭借其在电动汽车和自动驾驶领域的前瞻性设计与不断革新的技…

Group By、Having用法总结(常见踩雷点总结—SQL)

Group By、Having用法总结 目录 Group By、Having用法总结一、 GROUP BY 用法二、 HAVING 用法三、 GROUP BY 和 HAVING 的常见踩雷点3.1 GROUP BY 选择的列必须出现在 SELECT 中(🤣最重要的一点)3.2 HAVING 与 WHERE 的区别3.3 GROUP BY 可以…

MySQL存储目录与配置文件(ubunto下)

mysql的配置文件: 在这个目录下,直接cd /etc/mysql/mysql.conf.d mysql的储存目录: /var/lib/mysql Ubuntu版本号:

深度学习经典模型之Network in Network

1 Network in Network 1.1 模型介绍 ​ Network In Network (NIN)是由 M i n L i n Min Lin MinLin等人提出,在CIFAR-10和CIFAR-100分类任务中达到当时的最好水平,因其网络结构是由三个多层感知机堆叠而被成为NIN [ 5 ] ^{[5]} [5]。NIN以一种全新的角…

Java版ERP管理系统源码解析:利用Spring Cloud Alibaba和Spring Boot实现微服务架构

ERP系统,亦称为企业资源计划系统,是一种融合了企业多元部门和复杂业务的综合管理信息系统。在全球经济蓬勃发展及企业竞争日趋激烈的背景下,ERP系统已逐步跃升为现代企业管理的核心工具。该系统通过优化资源配置及提升业务流程效率&#xff0…

Python 基础笔记之生成器generator

生成斐波拉契数列 def fib(length):a,b0,1n0while n<length:yield aa,bb,abn1return abc g2fib(10) try:print(next(g2)) 生成器方法&#xff1a; __next__():获取下一个元素 send(value):向每次生成器调用中传值 注意&#xff1a;第一次调用send(None) def gen():i0while…

vscode翻译插件

vscode翻译插件 需求 &#xff1a; 在编写代码的时候&#xff0c; 打印或者定义变量的时候总是想不起来英文名称&#xff0c; 所有就开发了一款中文转换为英文的插件。 功能 1、目前支持选中中文&#xff0c;右键选择打印或者变量进行转换。 2、目前支持选中中文&#xff0…

美格智能5G车规级通信模组:高精度定位守护极致安全

物联网时代&#xff0c;众多应用和设备都需要位置相关服务&#xff0c;尤其是对移动场景而言&#xff0c;定位的需求更加重要。随着自动驾驶、高阶辅助驾驶等智能车载技术的高速发展&#xff0c;在智能车载领域的定位需求除基础的位置信息之外&#xff0c;还对信息获取的速度、…

SpringMVC学习记录(三)之响应数据

SpringMVC学习记录&#xff08;三&#xff09;之响应数据 一、页面跳转控制1、快速返回模板视图2、转发和重定向 二、返回JSON数据1、前置准备2、ResponseBody 三、返回静态资源1、静态资源概念2、访问静态资源 /*** TODO: 一个controller的方法是控制层的一个处理器,我们称为h…

药品进销存表格制作 佳易王药店药品入库出库台账库存管理系统操作教程

一、概述 【软件试用版资源文件下载可以点文章最后官网卡片】 药品进销存表格制作 药店药品入库出库台账库存管理系统操作教程 ‌核心功能全面‌&#xff1a;涵盖药品进货、销售、库存管理&#xff0c;以及数据分析与报表生成。 ‌药品进货管理‌&#xff1a;记录供应商信息和…

网页版五子棋——用户模块(服务器开发)

前一篇文章&#xff1a;网页版五子棋—— WebSocket 协议-CSDN博客 目录 前言 一、编写数据库代码 1.数据库设计 2.配置 MyBatis 3.创建实体类 4.创建 UserMapper 二、前后端交互接口 1.登录接口 2.注册接口 3.获取用户信息 三、服务器开发 1.代码编写 2.测试后端…

A day a tweet(seventeen)——Visualize Convolution Neural Network!

a.形象化地CNNs visually explained! . .CNN(Convolution Neural Network) 卷积神经网络 a.不可思议的,难以置信的 v.使形象化CNN explainer is an incredible interactive tool to visualize the internal workings of a CNN. n.解释器;讲解员 …

将vscode的终端改为cygwin terminal

现在终端是默认的power shell&#xff0c;没有显示cygwin 接下来选择默认配置文件 找到cygwin的选项即可 然后提示可能不安全什么的&#xff0c;点是&#xff0c;就有了

大语言模型训练的全过程:预训练、微调、RLHF

一、 大语言模型的训练过程 预训练阶段&#xff1a;PT&#xff08;Pre training&#xff09;。使用公开数据经过预训练得到预训练模型&#xff0c;预训练模型具备语言的初步理解&#xff1b;训练周期比较长&#xff1b;微调阶段1&#xff1a;SFT&#xff08;指令微调/有监督微调…

《AI在企业战略中的关键地位:以微软和阿里为例》

内容概要 在当今商业环境中&#xff0c;人工智能&#xff08;AI&#xff09;的影响力如滔滔洪水&#xff0c;愈演愈烈。文章将揭示AI在企业战略中的崛起&#xff0c;尤其以微软和阿里巴巴为代表的企业&#xff0c;这两家科技巨头通过不同方式&#xff0c;将智能技术融入其核心…

aspose如何获取PPT放映页“切换”的“持续时间”值

文章目录 项目场景问题描述问题1&#xff1a;从官方文档和资料查阅发现并没有对切换的持续时间进行处理的方法问题2&#xff1a;aspose的依赖包中&#xff0c;所有的关键对象都进行了混淆处理 解决方案1、找到ppt切换的持续时间对应的混淆对象中的字段2、获取ppt切换的持续时间…

Linux挖矿病毒(kswapd0进程使cpu爆满)

一、摘要 事情起因:有台测试服务器很久没用了&#xff0c;突然监控到CPU飙到了95以上&#xff0c;并且阿里云服务器厂商还发送了通知消息&#xff0c;【阿里云】尊敬的xxh: 经检测您的阿里云服务&#xff08;ECS实例&#xff09;i-xxx存在挖矿活动。因此很明确服务器中挖矿病毒…