对应代码:

1、在UVM组件中主操作函数或者任务之前或者之后内嵌callback函数或任务

 1 class driver extends uvm_driver #(transaction);
2 `uvm_register_cb(driver, driver_callback); //登记
3 ...
4 virtual task run_phase(uvm_phase phase)l
5 forever begin
6 seq_item_port.get_next_item(req);
7 `uvm_do_callbacks(driver, driver_callback, pre_send(this, req)); //使用宏嵌入函数或任务
8 send(req);
9 `uvm_do_callbacks(driver, driver_callback, post_send(this, req)); // 就是在哪个类中,使用哪个callback,以及这个callback的哪个方法
10 seq_item_port.item_done();
11 end
12
13 endclass: drvier
14

2、创建一个uvm_callback 空壳类(facade class)

 1 typedef class driver;
2 class driver_callback extends uvm_callback;
3 function new(string name = "driver_callback");
4 super.new(name);
5 endfunction: new
6
7 virtual task pre_send(driver drv, transaction tr);   //这是注入错误的
8 endtask
9
10 virtual task post_send(driver drv, transaction tr);  //这是用来收集覆盖率的
11 endtask
12 endcalss: driver_callback

3、从callback空壳类扩展

  ①注入错误

1 class driver_error_callback extends driver_callback;
2 virtual task pre_send(driver drv, transaction tr);
3 drv.req.payload.delete()
4 endtask: pre_send
5 endclass: driver_error_callback

  ②收集覆盖率

 1 class driver_cov_callback extends driver_callback;
2 covergroup drv_cov with function sample(transaction tr);
3 coverpoint tr.sa;
4 coverpoint tr.da;
5 endcovergroup
6
7 function new();
8 drv_cov = new();
9 endfunction: new
10
11 virtual task post_send(driver drv, transaction tr);
12 drv_cov.sample(tr);
13 endtask: pre_send
14 endclass: driver_error_callback

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

  ①

1 class driver_err_test extends test_base;
2 driver_error_callback drv_err_cb; // ↓
3 virtual function void connect_phase(uvm_phase, phase);
4 super.connect_phase(phase);
5 drv_err_cb = new(); //创建
6 uvm_callbacks #(driver, driver_callback)::add(env.drv, drv_err_cb); // 登记对象
7 uvm_callbacks #(driver, driver_callback)::display(); //方便调试
8 endfunction: connect_phase
9 endcalss: driver_err_test

  ②

 1 class driver_cov_test extends test_base;
2 ...
3 driver_cov_callback drv_err_cb; // ↓
4 virtual function void connect_phase(uvm_phase, phase);
5 super.connect_phase(phase);
6 drv_cov_cb = new(); //创建
7 uvm_callbacks #(driver, driver_callback)::add(env.drv, drv_cov_cb); // 登记对象
8 uvm_callbacks #(driver, driver_callback)::display(); //方便调试
9 endfunction: connect_phase
10 endcalss: driver_cov_test

这个例子就到此结束了。还有一个例子。


两个例子基本一致的,就是个别宏的使用方法有点小异。

  1 `include "uvm_macros.svh"
2
3 package bus_driver_pkg;
4
5 import uvm_pkg::*;
6
7 typedef class bus_driver;
8 typedef class bus_driver_cb;
9 typedef uvm_callbacks #(bus_driver,bus_driver_cb) bus_driver_cbs_t;  // 这样定义好之后,使用::add的时候就不要带那么多参数了。
10
11 class bus_tr extends uvm_transaction;
12 rand int addr;
13 rand int data;
14 virtual function string convert2string();
15 convert2string = $sformatf("addr=%0h data=%0h",addr,data);
16 endfunction
17 endclass
18
19 virtual class bus_driver_cb extends uvm_callback;   // 空壳类
20
21 virtual function bit trans_received(bus_driver driver, bus_tr tr);
22 return 0;
23 endfunction
24
25 virtual task trans_executed(bus_driver driver, bus_tr tr);
26 endtask
27
28 function new(string name="bus_driver_cb_inst");
29 super.new(name);
30 endfunction
31
32 static string type_name = "bus_driver_cb";
33
34 virtual function string get_type_name();
35 return type_name;
36 endfunction
37
38 endclass
39
40 class bus_driver extends uvm_component;
41
42 uvm_blocking_put_imp #(bus_tr,bus_driver) in;
43
44 `uvm_register_cb(bus_driver, bus_driver_cb)    // 注册
45
46 function new (string name, uvm_component parent=null);
47 super.new(name,parent);
48 in = new("in",this);
49 endfunction
50
51 static string type_name = "bus_driver";
52
53 virtual function string get_type_name();
54 return type_name;
55 endfunction
56
57 virtual function bit trans_received(bus_tr tr);
58 `uvm_do_callbacks_exit_on(bus_driver,bus_driver_cb,trans_received(this,tr),1)    // 这里的callback函数用在了主任务所调用的函数里,也是可以的
59 endfunction
60
61 virtual task trans_executed(bus_tr tr);
62 `uvm_do_callbacks(bus_driver,bus_driver_cb,trans_executed(this,tr))
63 endtask
64
65 virtual task put(bus_tr t);
66 uvm_report_info("bus_tr received",t.convert2string());
67 if (!trans_received(t)) begin
68 uvm_report_info("bus_tr dropped",
69 "user callback indicated DROPPED\n");
70 return;
71 end
72 #100;
73 trans_executed(t);
74 uvm_report_info("bus_tr executed",{t.convert2string(),"\n"});
75 endtask
76
77 endclass
78
79 endpackage // bus_driver_pkg
80
81 import uvm_pkg::*;
82 import bus_driver_pkg::*;
83
84 class my_bus_driver_cb extends bus_driver_cb;    //第一个重载
85
86 function new(string name="bus_driver_cb_inst");
87 super.new(name);
88 endfunction
89
90 virtual function bit trans_received(bus_driver driver, bus_tr tr);
91 static bit drop = 0;
92 driver.uvm_report_info("trans_received_cb",
93 {" bus_driver=",driver.get_full_name()," tr=",tr.convert2string()});
94 drop = 1 - drop;
95 return drop;
96 endfunction
97
98 virtual task trans_executed(bus_driver driver, bus_tr tr);
99 driver.uvm_report_info("trans_executed_cb",
100 {" bus_driver=",driver.get_full_name()," tr=",tr.convert2string()});
101 endtask
102
103 virtual function string get_type_name();
104 return "my_bus_driver_cb";
105 endfunction
106
107 endclass
108
109 class my_bus_driver_cb2 extends bus_driver_cb;    //第二个
110
111 function new(string name="bus_driver_cb_inst");
112 super.new(name);
113 endfunction
114
115 virtual task trans_executed(bus_driver driver, bus_tr tr);
116 driver.uvm_report_info("trans_executed_cb2",
117 {" bus_driver=",driver.get_full_name()," tr=",tr.convert2string()});
118 endtask
119
120 virtual function string get_type_name();
121 return "my_bus_driver_cb2";
122 endfunction
123
124 endclass
125
126 module top;
127 import uvm_pkg::*;
128 import bus_driver_pkg::*;
129
130 bus_tr tr = new;
131 bus_driver driver = new("driver");
132 my_bus_driver_cb cb1 = new("cb1");    // 由于本例结构简单,声明实例一起完成了
133 my_bus_driver_cb2 cb2 = new("cb2");
134
135 initial begin
136 bus_driver_cbs_t::add(driver,cb1);
137 bus_driver_cbs_t::add(driver,cb2);
138 bus_driver_cbs_t::display();
139 for (int i=1; i<=5; i++) begin
140 tr.addr = i;
141 tr.data = 6-i;
142 driver.in.put(tr);
143 end
144 begin
145 uvm_report_server svr = uvm_report_server::get_server();
146 svr.summarize();
147 end
148 end
149
150 endmodule

UVM——callback机制应用示例的更多相关文章

  1. UVM中Callback机制

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

  2. 实验三:klee的执行重现机制(示例分析)

    结论性内容: (1)如果是在程序中使用klee_make_symbolic,则可以使用下列脚本进行重现. export LD_LIBRARY_PATH=/home/klee/xiaojiework/k ...

  3. callback机制之内核通知链表【转】

    本文转载自:http://bbs.chinaunix.net/thread-2011776-1-1.html 1.通知链表简介    大多数内核子系统都是相互独立的,因此某个子系统可能对其它子系统产生 ...

  4. UVM基础之------uvm phases机制

    代码的书写顺序会影响代码的实现,在不同的时间做不同的事情,这是UVM phase的设计哲学,UVM phase提供了一个通用的TB phase 解决方案.支持显示的隐式的同步方案,运行时刻的线程控制和 ...

  5. UVM基础之-------uvm factory机制override<博>

    override功能是UVM中一个比较重要的功能,这个功能也是在factory里面实现的,我们会在env或者具体的case中使用override功能. class case_x extends bas ...

  6. UVM基础之---------uvm factory机制register

    factory机制的一大特点就是根据类的名字来创建类的实例. factory 机制中根据类名来创建类的实例所用到的技术:一是参数化的类,二是静态变量和静态函数.这两者是factory机制实现的根本所在 ...

  7. UVM基础之---------uvm factory机制base

    从名字上面就知道,uvm_factory用来制造uvm_objects和component.在一个仿真过程中,只有一个factory的例化存在. 用户定义的object和component types ...

  8. UVM基础之---------uvm report 机制分析

    uvm 中的信息报告机制相对来说比较简单,功能上来说主要分为两部分: 第一通过ID对component的信息报告冗余级别进行控制,针对每个冗余级别进行不同的行为控制.这部分工作主要由uvm_repor ...

  9. jQuery新的事件绑定机制on()示例应用

    投稿:whsnow 字体:[增加 减小] 类型:转载   从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定,下面通过示例为大家介绍下     ...

  10. Java: server/client 心跳机制实现 示例

    心跳机制 心跳机制是定时发送一个自定义的结构体(心跳包),让对方知道自己还活着,以确保连接的有效性的机制. 大部分CS的应用需要心跳机制.心跳机制一般在Server和Client都要实现,两者实现原理 ...

随机推荐

  1. 浅谈promise对象

    背景: 最近项目在做小程序的开发,涉及设计一个统一的登录公共方法,当实现时涉及到多个异步请求,那么问题来了,如何让多个异步请求先后同步进行呢?很多人会想到使用多层嵌套套来实现,就像这样: functi ...

  2. 体验一个前端视图层的mvvm的框架Knockoutjs(双向绑定,模板..)..解放您的双手,不再处理那么多的dom操作..快速实现视图层数据与UI的交互处理

    笔者之前对于类似前端展示的,可能都是自己开发js对象,集合外加dom事件进行处理..  近期看到相关资料,了解了Knockoutjs这个框架,下面来段代码: <script type=" ...

  3. [机器学习] Yellowbrick使用笔记1-快速入门

    Yellowbrick是一个机器学习可视化库,主要依赖于sklearn机器学习库,能够提供多种机器学习算法的可视化,主要包括特征可视化,分类可视化,回归可视化,回归可视化,聚类可视化,模型选择可视化, ...

  4. react 高效高质量搭建后台系统 系列 —— antd和样式

    其他章节请看: react 高效高质量搭建后台系统 系列 antd 后续要做登录模块(主页),不仅要解决请求数据的问题,还需要完成 antd 配置以及样式的准备. antd 多种主题风格 详情请看 这 ...

  5. Ubuntu 安装播放器

    安装 VLC sudo snap install vlc snap 下载慢的看这里https://www.cnblogs.com/Ahtelek/p/ubuntu-snap.html

  6. 【Django drf】视图类APIView之五层封装 ApiView的类属性 drf配置文件

    目录 ApiView的类属性 drf 配置文件之查找顺序 drf之请求 APIView之请求相关配置 drf之响应 APIView之响应相关配置 Response对象属性 视图类 序列化类 路由 基于 ...

  7. 关于Vue2.x与Es6一些特性

    关于Vue2.x与Es6一些特性 Vue的定位,就是快速开发. 这些特性,我没有过于熟练,导致写的代码质量不高. 过滤器 <template> <div> {{title | ...

  8. ASP.NET Core - .NET 6 的入口文件

    自从.NET 6 开始,微软对应用的入口文件进行了调整,移除了 Main 方法和 Startup 文件,使用顶级语句的写法,将应用初始化的相关配置和操作全部集中在 Program.cs 文件中,如下: ...

  9. 构建api gateway之 openresty 中如何使用 wasm

    openresty 中如何使用 wasm WASM 是什么? WebAssembly是一种运行在现代网络浏览器中的新型代码,并且提供新的性能特性和效果.它设计的目的不是为了手写代码而是为诸如C.C++ ...

  10. Visual Studio 集成了.NET 升级助手插件

    .NET团队2023年2月16日在官方博客上发布了名为".NET Upgrade Assistant"的全新 Visual Studio 扩展,帮助开发人员升级.NET 应用程序. ...