UVM的Messages机制有些时候很繁琐,很多时候希望能够在UVM messages的基础上做一些个人化的订制,这里给出来一个找到的例子作为参考。
my_macros.sv:
`define my_info(MSG, VERBOSITY) \
begin \
if(uvm_report_enabled(VERBOSITY,UVM_INFO,get_full_name())) \
uvm_report_info(get_full_name(), $sformatf MSG, 0, `uvm_file, `uvm_line); \
end
`define my_err(MSG) \
begin \
if(uvm_report_enabled(UVM_NONE,UVM_ERROR,get_full_name())) \
uvm_report_error(get_full_name(), $sformatf MSG, UVM_NONE, `uvm_file, `uvm_line); \
end
`define my_warn(MSG) \
begin \
if(uvm_report_enabled(UVM_NONE,UVM_WARNING,get_full_name())) \
uvm_report_warning(get_full_name(), $sformatf MSG, UVM_NONE, `uvm_file, `uvm_line); \
end
`define my_fatal(MSG) \
begin \
if(uvm_report_enabled(UVM_NONE,UVM_FATAL,get_full_name())) \
uvm_report_fatal(get_full_name(), $sformatf MSG, UVM_NONE, `uvm_file, `uvm_line); \
end
my_init.sv:
initial begin
my_report_server_c report_server = new("my_report_server");
if($value$plusargs("fname_width=%d", fwidth)) begin
report_server.file_name_width = fwidth;
end
if($value$plusargs("hier_width=%d", hwidth)) begin
report_server.hier_width = hwidth;
end
uvm_pkg::uvm_report_server::set_server(report_server);
// all "%t" shall print out in ns format with 8 digit field width
$timeformat(-9,0,"ns",8);
end
my_report_server.sv:
class my_report_server_c extends uvm_report_server;
`uvm_object_utils(my_report_server_c)
string filename_cache[string];
string hier_cache[string];
int unsigned file_name_width = 28;
int unsigned hier_width = 60;
uvm_severity_type sev_type;
string prefix, time_str, code_str, fill_char, file_str, hier_str;
int last_slash, flen, hier_len;
function new(string name="my_report_server");
super.new();
endfunction : new
virtual function string compose_message(uvm_severity severity, string name, string id, string message,
string filename, int line);
// format filename & line-number
last_slash = filename.len() - 1;
if(file_name_width > 0) begin
if(filename_cache.exists(filename))
file_str = filename_cache[filename];
else begin
while(filename[last_slash] != "/" && last_slash != 0)
last_slash--;
file_str = (filename[last_slash] == "/")?
filename.substr(last_slash+1, filename.len()-1) :
filename;
flen = file_str.len();
file_str = (flen > file_name_width)?
file_str.substr((flen - file_name_width), flen-1) :
{{(file_name_width-flen){" "}}, file_str};
filename_cache[filename] = file_str;
end
$swrite(file_str, "(%s:%6d) ", file_str, line);
end else
file_str = "";
// format hier
hier_len = id.len();
if(hier_width > 0) begin
if(hier_cache.exists(id))
hier_str = hier_cache[id];
else begin
if(hier_len > 13 && id.substr(0,12) == "uvm_test_top.") begin
id = id.substr(13, hier_len-1);
hier_len -= 13;
end
if(hier_len < hier_width)
hier_str = {id, {(hier_width - hier_len){" "}}};
else if(hier_len > hier_width)
hier_str = id.substr(hier_len - hier_width, hier_len - 1);
else
hier_str = id;
hier_str = {"[", hier_str, "]"};
hier_cache[id] = hier_str;
end
end else
hier_str = "";
// format time
$swrite(time_str, " {%t}", $time);
// determine fill character
sev_type = uvm_severity_type'(severity);
case(sev_type)
UVM_INFO: begin code_str = "%I"; fill_char = " "; end
UVM_ERROR: begin code_str = "%E"; fill_char = "_"; end
UVM_WARNING: begin code_str = "%W"; fill_char = "."; end
UVM_FATAL: begin code_str = "%F"; fill_char = "*"; end
default: begin code_str = "%?"; fill_char = "?"; end
endcase
// create line's prefix (everything up to time)
$swrite(prefix, "%s-%s%s%s", code_str, file_str, hier_str, time_str);
if(fill_char != " ") begin
for(int x = 0; x < prefix.len(); x++)
if(prefix[x] == " ")
prefix.putc(x, fill_char);
end
// append message
return {prefix, " ", message};
endfunction : compose_message
endclass : my_report_server_c
- 定制个性化码表技术 ibus
在不同用户的工作环境中,都会根据各自使用的字符集的不同,而需要定制优化各自的输入法码表,例如,在GB18030中的大量汉字,或许因为输入法码表的老旧,而难于利用自己熟悉的“五笔”方法快速录入,同样,需 ...
- 【OpenStack】OpenStack系列14之Dashboard定制开发
django概述 参考资料:http://blog.javachen.com/2014/01/11/how-to-create-a-django-site.html http://djangobook ...
- scss组件定制的一些学习
应组织上的要求,简化前端开发,提高工作效率,开始着手研究scss框架及组件化. 把一些长的像的弄在一起,就有了组件化. 但组件只用一部分需要的,就有了定制. 下面是参考一个button组件写出的一些简 ...
- 浏览器扩展系列————在WPF中定制WebBrowser快捷菜单
原文:浏览器扩展系列----在WPF中定制WebBrowser快捷菜单 关于如何定制菜单可以参考codeproject上的这篇文章:http://www.codeproject.com/KB/book ...
- [技术] 如何正确食用cnblogs的CSS定制
用过cnblogs的估计都知道cnblogs提供了相对比较开放的个性化选项,其中最为突出的估计就是页面CSS定制了.但是没学过Web前端的人可能并不会用这个东西... 所以我打算在此分享一些定制CSS ...
- django学习记录
1.参考资料问题: 现在django发布了1.11版本,离线文档下载引擎地址 文档下载地址 在线文档:https://docs.djangoproject.com/en/1.10/intro/tuto ...
- gson笔记 解析json数据
gson中负责json数据解析的类是JsonReader. Json格式有两种结构,一种是对象(键值对的组合,无序),另外一种是数组(值的有序集合). 因此针对这两种格式,JsonReader提供了不 ...
- PostgreSQL全文检索zhparser使用
本文引用自: http://blog.chinaunix.net/uid-20726500-id-4820580.html 防止文章丢失才进行复制 PostgreSQL支持全文检索,其内置的缺省的分词 ...
- linux PPTP VPN客户端安装
转载于http://www.2cto.com/os/201209/157462.html 下载pptp-1.7.2.tar.gz http://pptpclient.sourceforge.net/ ...
随机推荐
- poj 1659 判断是否能构成图Havel-Hakimi定理
//用到了Havel-Hakimi定理,判断是否能够构图 //两种情况不能构图,1:对剩下序列排序后,最大的度数超过了剩下的顶点数 // 2:对最大的度数后面的f个度数减-后,出现了负数 //记录到临 ...
- springboot 2.x 集成 drools 7.x
简介:springboot 2.0.4.RELEASE 集成 drools 7.11.0.Final 1.项目结构 2. pom.xml文件 <?xml version="1.0&qu ...
- codevs2449 骑士精神
题目描述 Description 在一个5×5的棋盘上有12个白色的骑士和12个黑色的骑士, 且有一个空位.在任何时候一个骑士都能按照骑士的走法(它可以走到和它横坐标相差为1,纵坐标相差为2或者横坐标 ...
- 关于Git的简单使用
新电脑git push一直出问题,到现在也没有解决,但是一些git的命令还是有用的,就先记下来吧.(下图就是没解决的报错) 一.上传本地项目到git 1.初始化git git init 2.配置用户名 ...
- androidannotations的background和UiThread配合使用參考
简单介绍 androidannotations在开发中的代码规范思考:(MVC思考)时间太紧,先贴代码: Activity的代码: package edu.njupt.zhb.main; import ...
- Solidworks如何另存为和打开OBJ文件
1 点击工具-插件,勾选ScanTo3D(最好后面的启动也勾选上,否则下次启动将不会默认自动启动这个插件,还需要再做一次才能打开或者另存为OBJ) 2 注意打开零件图的方式,你不能直接打开Soli ...
- 基于Volley,Gson封装支持JWT无状态安全验证和数据防篡改的GsonRequest网络请求类
这段时间做新的Android项目的client和和REST API通讯框架架构设计.使用了非常多新技术,终于的方案也相当简洁优雅.client仅仅须要传Java对象,server端返回json字符串, ...
- HTTP 错误 404.15 - Not Found 请求筛选模块被配置为拒绝包含的查询字符串过长的请求。
HTTP 错误 404.15 - Not Found 请求筛选模块被配置为拒绝包含的查询字符串过长的请求. 2018-04-20 14:00 by 码农小周, 21 阅读, 2 评论, 收藏, 编辑 ...
- Test While You Sleep (and over Weekends)
Test While You Sleep (and over Weekends) Rajith Attapattu RELAX. I am not referring to offshore deve ...
- 操作系统的时区设置会影响数据库查询SYSDATE和SYSTIMESTAMP的值
SYSDATE和SYSTIMESTAMP的值并不受数据库參数DBTIMEZONE的影响,操作系统时区的环境变量(如TZ)会影响它们的输入,由于SYSDATE和SYSTIMESTAMP实际是调用操作系统 ...