在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 6216|回复: 12

[求助] 关于randomize的使用问题

[复制链接]
发表于 2014-9-22 14:13:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
请问下,一个帧包要生成不定长的payload,在transcation中生成帧包格式,在generator中对transcation进行了实例化以后,执行run task,是否需要在run task中使用randomize对transcation进行随机化?用的是uvm1.0
发表于 2014-9-22 17:11:51 | 显示全部楼层
随机处理实在uvm_do或者 start_item     finish_item之间做的。当然也可以用uvm_do_with(item,{item.xxx== yyy;})
发表于 2014-9-22 17:22:15 | 显示全部楼层
回复 1# 周嬷嬷

一般随机化动作在uvm_object派生出来的uvm_sequence的body()里做,不用uvm_component派生出来的组件里做。当然一定要的话,那就在run_phase里做吧,然后用tlm传出去。随机化可以用randomize, 也可以用do_with系列宏,若出于灵活性的考量,直接使用randomize为宜
 楼主| 发表于 2014-9-23 09:29:43 | 显示全部楼层
回复 2# allencherry


    您好:就是我的代码,是在generator中需要对实例化的帧包进行赋值,然后传递到driver中,在run task中,需要生成一个帧包,那是否可以将其randomize,然后连接上tlm接口呢?
 楼主| 发表于 2014-9-23 09:31:43 | 显示全部楼层
回复 3# seabeam


    您好:那是否意味着,在run task中可以直接randomize帧包,然后用tlm通道传递到driver中去呢?
发表于 2014-9-23 10:48:22 | 显示全部楼层
回复 5# 周嬷嬷

可以,用mailbox传递也可以
发表于 2014-9-23 16:22:38 | 显示全部楼层



我不太明白你的意思。 UVM是在sequence中进行随机,通过sequencer传递给driver的, 你是要在generator中进行随机化处理吗?
 楼主| 发表于 2014-9-23 16:56:29 | 显示全部楼层
回复 7# allencherry


    您好:因为我们公司不使用sequence机制,所以需要在generator中进行随机化处理
发表于 2014-9-23 18:08:19 | 显示全部楼层
当然需要在generator里面执行randomize了。driver是用于驱动数据的,它不能产生数据。所以送给driver之前数据已经randomize好了。按照你的描述,你只能在generator里面randomize,没有其它的选择。
发表于 2014-9-24 08:42:31 | 显示全部楼层


回复  allencherry


    您好:因为我们公司不使用sequence机制,所以需要在generator中进行随机化处理 ...
周嬷嬷 发表于 2014-9-23 16:56


那就在generator中进行实例化和随机吧,然后通过端口发送给驱动。 SV里面有讲这方面的
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-9-21 13:27 , Processed in 0.024178 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表