杂谈
+徐火火+
这个作者很懒,什么都没留下…
展开
-
关于put_response和get_response的总结
记录相关链接:原创 2023-12-10 23:42:18 · 345 阅读 · 1 评论 -
SV杂谈-pre_randomize和post_randomize在子类父类中的调用
【代码】SV杂谈-randomize中的pre和post在子类父类中的调用。原创 2022-09-04 17:16:50 · 718 阅读 · 0 评论 -
SV杂谈-关于$cast
基于此,如果想要把父类句柄给到子类句柄,那么需要的条件是:创建了一个子类对象,同时有一个父类句柄,两个子类句柄。先执行(1)中的内容,也就是把创建实例的子类给到句柄给到父类句柄,保证子类父类句柄指向的空间是一致的,在这个基础上用$case(另一个子类句柄,转化后的父类句柄)实现转化。通过父类句柄调用变量和函数的时候,对于变量显示的是父类的变量(针对同名变量,不同名的变量哪里有显示哪里的),对于方法,如果是同名方法,并且父类中的同名方法没有声明virtual,那么调用的任然是父类的,反之子类;...原创 2022-08-12 21:36:47 · 292 阅读 · 0 评论 -
SV杂谈- 关于时钟块的采样和驱动
对于输入的信号,由于dut的信号实际是由driver时钟块驱动的,因此这里的输入信号两者会在同一拍,只会差1ns的时间(参考dut信号和variable5);对于输出信号,由于输出的信号对于driver的时钟块是输入,其采集的时候会在dut输入的信号时钟沿之前采集,因此这两个信号差一拍(参考dut信号和variable6)。两种情况第一种是输入给dut的数据通过monitor采样,由于时钟块的存在,实际上输入给dut的信号在第二拍才能采集到;参考dut信号和这里的variable1和variable2...原创 2022-07-16 21:14:04 · 1424 阅读 · 1 评论 -
UVM杂谈-sequence启动的几种方式
1.start2.宏3.virtual sequence(1)第一种用法:vrirtual sequence使用多个sequencer来控制激励的产生和发送,是所有sequence的顶层,它包含所用sequence和对应的sequencer,起到一个调度的作用。注意:一般会在virtual sequence上层的test的connect phase中将相应的sequencer的句柄进行连接;在virtual sequence中将各个sequence通过start函数挂载在sequencer上;而在virtu原创 2022-06-26 14:14:43 · 1955 阅读 · 0 评论 -
sv杂谈-双向约束、->、solve before
1.双向约束强调的是各个约束块之间执行的过程是并行的,也就是最终的结果是A约束块和B约束块综合出来的结果。2.->强调的是前后两个值之间的约束关系,比如:(1)当x = 0的时候y一定为0;(2)当x != 0的时候,y的值随意;(3)当y == 0的时候,x值是随意的;(4)当 y != 0的时候,x一定不为0;总结就是x为0的时候y一定为0需要注意的是,->和if==约束中使用if else语句看起来似乎是有先后条件的,但是实际上他仍然是并行执行的,也就是x和y的值是同时确定的,但是在确定的时候是原创 2022-06-23 10:02:12 · 4011 阅读 · 1 评论 -
SV杂谈-关于覆盖率中的箭头符号
覆盖率中的->和=>通常表示的是翻转覆盖率,最需要注意的是:1. 1=>3[=2]=>6和1=>3[->2]=>6之间的区别:(1)对于前者表示的是1...=>3...=>3...=>6也就是每次翻转之间可以相邻也可以不相邻。(2)对于后者表示的是1...=>3...=>3=>6,也就是最后一次翻转是必须相邻。2.区分0=>1[*3]和1[*3:5]之间的区别:前者表示的是0=>1这个式子重复3次,后者表示1进行3或4或5次重复。针对apb协议,应用翻转覆盖率,例子如下:...原创 2022-06-16 08:54:43 · 1109 阅读 · 0 评论