UVM:callback机制的意义和用法

2024-09-09 04:04

本文主要是介绍UVM:callback机制的意义和用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 作用

        Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。

2. 使用步骤

        (1)在UVM组件中内嵌callback函数或任务;

        (2)声明一个UVM callback空壳类;

        (3)从UVM callback空壳类中扩展UVM callback类;

        (4)在验证环境中创建并登记UVM callback实例。

3. callback实现举例

        第一步首先声明一个空壳类,注意所有的方法都声明为virtual,函数体为空

class driver_callback extends uvm_callback;`uvm_object_utils(driver_callback)function new (string name = "driver_callback");super.new(name);endfunctionvirtual task pre_drive (driver drv, transaction tr);endtask      virtual task post_drive (driver drv, transaction tr);endtask    
endclass

        第二步,在主操作函数、任务之前或之后嵌入callback函数:

typedef class driver_callback;      //类的预定义,以便后续提前使用未定义的driver类class driver extends uvm_driver#(transaction);     //嵌入Callback函数`uvm_register_cb(driver, driver_callback);   //在组件中登记UVM_callback...virtual task run_phase(uvm_phase phase);forever beginseq_item_port.get_next_item(req);      //申请数据发送`uvm_do_callbacks(driver,driver_callback,pre_drive(this,req)); //在数据处理前,使用宏`uvm_do_callbacks嵌入Callback函数或者任务drive(req);          `uvm_do_callbacks(driver,driver_callback,post_drive(this,req)); //在数据处理后,使用宏`uvm_do_callbacks嵌入Callback函数或者任务seq_item_port.item_done();     endendtaskendclass

        使用宏`uvm_register_cb在组件中对callback类进行注册;

        使用宏`uvm_do_callbacks在具体行为前后嵌入callback函数或者任务。

        第三步,编写具体的callback函数内容:

class driver_error_callback extends driver_callback; //继承Callback空壳类,实现覆盖`uvm_object_utils(driver_error_callback)function new(string name="driver_error_callback");super.new(name);endfunctionvirtual task pre_drive(driver drv, transaction tr);drv.req.payload.delete();         //在主函数操作前注入错误endtaskvirtual task post_drive(driver drv, transaction tr);`uvm_info("DRIVER_ERROR_CALLBACK","Inside post_drive method",UVM_LOW);  //在主函数操作之后,打印endtask     endclass

        最后一步,在测试案例中创建并登记callback的实例:

class driver_err_test extends test_base;  //在测试用例中创建对象并登记`uvm_component_utils(driver_err_test)function new(string name = "driver_err_test", uvm_component parent=null);super.new(name,parent);endfunction…………driver_error_callback  drv_err_cb;    //声明句柄function void build_phase(uvm_phase phase);super.build_phase(phase);drv_err_cb = driver_error_callback_callback::type_id::create("callback_1", this);     //创建Callback实例uvm_callbacks #(driver,driver_callback)::add(env.agt.drv, drv_err_cb);    //调用add()方法将回调类添加到testuvm_callbacks #(driver,driver_callback)::display();   //显示并打印登记信息用于调式endfunction
endclass

         需要在测试用例中创建和例化callback对象;并调用uvm_callbacks #(T, CB) :: add(t,cb)将callback对象添加到test。

最后在编译调试时,添加选项+UVM_CB_TRACE_ON即可。

这篇关于UVM:callback机制的意义和用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1150105

相关文章

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

Java中自旋锁与CAS机制的深层关系与区别

《Java中自旋锁与CAS机制的深层关系与区别》CAS算法即比较并替换,是一种实现并发编程时常用到的算法,Java并发包中的很多类都使用了CAS算法,:本文主要介绍Java中自旋锁与CAS机制深层... 目录1. 引言2. 比较并交换 (Compare-and-Swap, CAS) 核心原理2.1 CAS

Spring Boot 集成 mybatis核心机制

《SpringBoot集成mybatis核心机制》这篇文章给大家介绍SpringBoot集成mybatis核心机制,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值... 目录Spring Boot浅析1.依赖管理(Starter POMs)2.自动配置(AutoConfigu

Java序列化之serialVersionUID的用法解读

《Java序列化之serialVersionUID的用法解读》Java序列化之serialVersionUID:本文介绍了Java对象的序列化和反序列化过程,强调了serialVersionUID的作... 目录JavChina编程a序列化之serialVersionUID什么是序列化为什么要序列化serialV

python3中正则表达式处理函数用法总结

《python3中正则表达式处理函数用法总结》Python中的正则表达式是一个强大的文本处理工具,用于匹配、查找、替换等操作,在Python中正则表达式的操作主要通过内置的re模块来实现,这篇文章主要... 目录前言re.match函数re.search方法re.match 与 re.search的区别检索

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

MySQL 中的 JSON_CONTAIN用法示例详解

《MySQL中的JSON_CONTAIN用法示例详解》JSON_CONTAINS函数用于检查一个JSON文档中是否包含另一个JSON文档,这篇文章给大家介绍JSON_CONTAINS的用法、语法、... 目录深入了解 mysql 中的 jsON_CONTAINS1. JSON_CONTAINS 函数的概述2

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java8 Collectors.toMap() 的两种用法

《Java8Collectors.toMap()的两种用法》Collectors.toMap():JDK8中提供,用于将Stream流转换为Map,本文给大家介绍Java8Collector... 目录一、简单介绍用法1:根据某一属性,对对象的实例或属性做映射用法2:根据某一属性,对对象集合进行去重二、Du