UVM中最基础,也最常用的几个知识点

1.为什么在TOP里面uvm_config_db set的时候都需要用到uvm_test_top,它针对不同的case产生的实例名字是一样的吗?

是一样的。对于+UVM_TESTNAME=example_case_(0…n),UVM验证平台会创建一个example_case_(0…n)的实例,他们的实例有一个共同的名字:uvm_test_top,所以你在top中congig_db的时候都会自上而下指定UVM component的路径,UVM树的最高就是uvm_test_top

2.怎么可以更好的理解uvm_object,uvm_component,sequence,sequence_item以及config?

我觉得zhangqiang写得《UVM1.1应用指南及源代码分析》一书中比喻的很通俗,原文如下:

uvm_object是一分子,用这个分子可以搭建成许许多多的东西,如既可以搭建成动物,还可以搭建成植物,更加可以搭建成没有生命意识的岩石,空气等。uvm_component就是由uvm_object搭建成的一种高级有生命体或者无生命体,而sequence_item则是由其搭建成的血液或者其他,它流通在各个(uvm_component)之间,sequence则是众多sequence_item的组合,config则是由其搭建的用于规范生命体或者无生命体(uvm_component)行为方式的准则。

3.new和create一个类的实例时有什么区别么?

当你使用了uvm_component_utils注册了之后就可以使用类似于A=example::type_id::create(“a”,this)的形式,create其实是factory重载了new函数,是factory方式实例化;如果你没有使用uvm_component_utils去注册,则只能使用systemverilog的new函数去实例化了,但是使用create产生的实例可以使用uvm的很多功能,比如overide功能(set_type_override_by_type(a1::get_type(),a2::get_type()))。使用上的区别可以这样简单理解,但是,如果觉得还想深入了解请阅读uvm factory源码。

4.UVM常用的phase有哪些?

uvm常用的phase,其实我经常用到的就是build_phase例化,connect_phase连接,run_phase(main_phase)以及report_phase,如果你要使用report_phase,那么建议你最好把要report的变量定义为全局类型的。


5.uvm不同components的同一phase的执行顺序是怎样的?

   uvm中对于build_phase是自父类到子类的自上而下的方式去执行的,否则你都没有执行agent的build_phase就去执行driver或者monitor的build_phase那会报错的,因为他们都还没有在agent的build_phase中实例化。除了build_phase,其他的function phase(注意这个地方)都是自下而上的方式,比如connect_phase,都是先执行driver或者monitor的connect_phase再执行agent的connect_phase,以此类推。如果是同一层次的driver和monitor是按照实例化之后的名字的字典顺序执行的,比如driver实例化为“A”,monitor实例化为“B”,那么就先执行driver的phase。对于需要消耗仿真时间的task phase则是自下而上的启动,同时在运行,不存在“等”的情况存在。

6.如果一个component中需要get的变量个数比较多时,怎么可以减少这种uvm_config_db #(type)::get()的工作量呢?

可以你只要在你的component中使用field_automation把需要get的变量都要注册了factory机制,在当前component的build_phase()中调用super.build_phase()就可以了,但是set()中中的第三个和第四个变量名需要一致。

比如

class my_driver extends uvm_driver;

  int num_0;

  int num_1;

  `uvm_component_utils_begin(my_driver)

     `uvm_field_int(num_0,UVM_ALL_ON)

     `uvm_field_int(num_1,UVM_ALL_ON)

  `uvm_component_utils_end

  function void build_phase(uvm_phase phase)

Super.build_phase(phase)

(此处就不需要一一get()了啊)

endfunction

endclass

7.寄存器访问为什么要有BACKDOOR的存在呢?

因为有时候用frontdoor是没有办法改变某些寄存器的值的。如在DUT中有一个写清的计数器,当DUT内部发生改变时,这寄存器的值会一直增加。对于用户来说,可以对此寄存器做两种操作,一是通过总线frontdoor来读取这个寄存器的值,二是通过写操作把这个寄存器清零,假设现在要测试一下这个寄存器的进位功能,也即要写入16’hFFFF等值,此时只有通过backdoor的方式来进行。另外,backdoor相对frontdoor来说,是不消耗仿真时间的(即backdoor前后$time的返回值不会改变),backdoor的速度比frontdoor也快的多。

8.寄存器模型是怎么去操作的frontdoor的?

说白了,其实是通过default_map去进行frontdoor操作的

9.常用操作对register model的镜像值和期望值的影响有哪些?

  read&write:使用BACKDOOR或FRONTDOOR的方式从DUT中读取或者写入指定寄存器的值,当操作完成后,会根据读写的结果更新register model中的渴望值和镜像值(二者相等)。

peek&poke:peek几乎等同于使用BACKDOOR方式的read,poke几乎等同于BACKDOOR方式的write,与read和write的区别是peek和poke不会模仿寄存器的行为。如对于一个读清的寄存器来说,进行read操作,那么无论BACKDOOR还是FRONTDOOR,那么DUT中寄存器的值依然保持不变。peek和poke操作之后,register model中的渴望值和镜像值都会更新(二者一致)。

get&set:这两个操作都是只针对渴望值的。只有渴望值会改变,镜像值不会改变。

  randomize:randomize之后,渴望值将会随机出来的数值,镜像值不会改变。

  update:这个操作会检查寄存器的渴望值和镜像值是否一致,如果不一致就会把渴望值写入到DUT中,并且更新新镜像值,使其与渴望值一致。每个由uvm_reg派生出来的类都会有update操作。另外,每个由uvm_reg_block派生出来的类也有update操作,它将会调用加入到此block中的所有寄存器的update。

mirror:它将会读取DUT,并且更新镜像值和渴望值。读取的方式可以选择BACKDOOR或者FRONTDOOR。与update类似,每个uvm_reg派生来的类都有mirror操作,每个由uvm_reg_blcok派生出来的类也有mirror操作。mirror操作可以指定是否报告DUT中寄存器的值与register model中镜像值不一样。如果选择了这一项,那么就可以检查某些计数器的值是否DUT中相应计数器的值一致。

predict:它将会把register model中的镜像值和渴望值都更新为要设置的值。它与set的区别是后者只更新渴望值而不更新镜像值。这个操作非常有用。假如DUT中有一个寄存器用于统计包的数量,当收到一个包时,DUT中寄存器的数值加1,而验证平台中要想同步的更新register model中相关寄存器的值就要用到predict操作。

10.如果我们的环境不在Makefile脚本里面设置打印级别,那么默认的打印severity是什么?

如果我们的环境中不设置打印级别,那么将会直接返回m_max_verbosity_level,它是int整型变量,系统在初始化的时候设置为UVM_MEDIUM。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容