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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 6920|回复: 8

[求助] 关于uvm中package与import uvm_pkg::*的疑问

[复制链接]
发表于 2020-11-16 15:33:45 | 显示全部楼层 |阅读模式

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

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

x
最近在学习搭建uvm验证环境,写道package的时候有些疑惑,首先我们写好driver, trans, monitor等组件的内容,然后将其打包在package中如图所示;
如果我们在package中写了                import uvm_pkg::*;
                                                       `include "uvm_macros.svh"
各组件内是否还需要添加这两句呢?之前有说法是package 中包含了这两句,组件内部就不需要再写这两句了。求解答。

Snipaste_2020-11-16_15-27-50.png
 楼主| 发表于 2020-11-16 15:36:16 | 显示全部楼层
我自己用questasim尝试的时候发现是不行的,即使package中包含了这两句,依然无法编译通过,只有driver中也导入才可以,同样的,我的driver中用到了transaction,是否还需要再driver中include transaction.sv呢?
发表于 2020-11-16 16:10:46 | 显示全部楼层
在package中添加这两个,组件中不用添加。最后只需编译package即可
 楼主| 发表于 2020-11-16 16:13:03 | 显示全部楼层


chip_z 发表于 2020-11-16 16:10
在package中添加这两个,组件中不用添加。最后只需编译package即可


感谢回复,我大概明白了,只需要编译package就等同于将所有包含的文件进行了编译,不需要再去分别编译组件文件,是这样的吧?
发表于 2020-11-16 18:12:39 | 显示全部楼层
include是直接把代码复制过来。所以只需要编译package的文件,原文件是不需要编译的
 楼主| 发表于 2020-11-16 19:12:22 | 显示全部楼层


空白MAX 发表于 2020-11-16 18:12
include是直接把代码复制过来。所以只需要编译package的文件,原文件是不需要编译的 ...


感谢回复,明白了!
发表于 2021-12-2 17:45:07 | 显示全部楼层


Traviss 发表于 2020-11-16 15:36
我自己用questasim尝试的时候发现是不行的,即使package中包含了这两句,依然无法编译通过,只有driver中也 ...


在package中添加这两个,组件中不用添加。最后只需编译package即可?  
所以这是编译顺序和内容的问题咯?


发表于 2022-11-15 16:33:37 | 显示全部楼层


空白MAX 发表于 2020-11-16 18:12
include是直接把代码复制过来。所以只需要编译package的文件,原文件是不需要编译的 ...


想问下,如果top顶层写了import uvm_pkg和include “uvm_macros.svh", 那在agent_pkg中或者env_pkg中还要不要加这两句
发表于 2023-3-20 17:55:03 | 显示全部楼层


zhao7 发表于 2022-11-15 16:33
想问下,如果top顶层写了import uvm_pkg和include “uvm_macros.svh", 那在agent_pkg中或者env_pkg中还要 ...


我这边是试了一下,要考虑编译顺序的问题。如果顶层在编译的后面,前面的pkg就要加
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2024-11-14 22:19 , Processed in 0.022572 second(s), 7 queries , Gzip On, Redis On.

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