1.核心基类:uvm_object
(1)虚类只能声明,不能例化。
(2)uvm_object提供的方法
2.域的自动化(field automation)
(1)简述
(2)示例
格式:在注册中声明成员变量。
(3)域的自动化添加后,可直接调用copy等方法,而无需像SV那样仔细定义copy()。
(4)对于新手,应养成习惯
3.拷贝-copy
(1)在UVM的数据操作中,需要对copy和clone加以区分。前者默认已经创建好了对象,只需要对数据进行拷贝;后者则会自动创建对象并对source object进行数据拷贝,再返回target object句柄。无论是copy或者clone,都需要对数据进行复制。
(2)示例
从示例可以看到,在进行copy时,默认进行的是深拷贝(deep copy) ,即会执行copy()和do_copy()。
(3)示例中要点
(4)示例结果
4.比较-compare
(1)简述
(2)示例
(3)输出结果
前两行是系统打印的,第二行发现只有1个miscompare。那是因为compare是立即返回的,不会继续对比其他变量。
(4)要点
(5)全局对象
发现全局对对象是与top是同级的,不在层次里。
5.打印-print
(1)概述
(2)示例
示例中包含了自定义的printer。
输出结果
(3)
6.打包与解包(pack&unpack)
(1)概述
(2)示例
(3)要点