嵌套的sequence中容易被忽略的bug

在sv以及UVM的学习开发中,遇到了一个很容易忽略的bug,并且此bug让自己卡在了do while循环中,于是记录。

嵌套的sequence

关于嵌套的sequence参见张强的《UVM实战》一书6.4章节。

在6.4.2章节中特意提到了在sequence中使用rand变量时需要注意变量的命名。其实不论是rand变量,还是其他的变量命名,都要注意此bug,即尽量不要用同一个名称

例如,我有一个sequence1,其body中声明了transaction为tr,如下

class sequence1 extends uvm_sequence#(transaction)
...
	virtual task body()
		sequence2	seq2;
		transaction tr;
		`uvm_do(seq2)

		`uvm_do_with(tr, tr.randomize())
		...
	endtask
...
endclass

另一个sequence2如下:

class sequence2 extends uvm_sequence#(transaction)
...
	virtual task body()
		transaction tr;
		`uvm_do_with(tr, tr.xxx == 1)
		...
		do begin
		xxx
		end while( ~ tr.xxx)
	endtask
...
endclass

当seq2在sequence1中执行时,seq2中的tr,实际上是seq1中的tr,并非seq2中的tr,所以当我的sequence2中的do while循环执行时,永远等不到tr中对应的位的拉高,导致seq2一直卡在了循环中。

那么这又是为什么呢?在张强书中的185页已经说得很明白:当执行seq2的时候,编译器首先会去寻找外层的tr,如果找到了,就不会再寻找了。

推荐的方法是,将seq2中的tr换个不同于seq1中的tr的名字,比如seq2_tr

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值