UVM树通过uvm_component来实现树形结构。所有的UVM树看的结点都是一个uvm_component。每一个uvm_component都有一个特点:他们在new的时候需要指定一个类型为uvm_component,名字为parent的变量。
uvm_component有phase的概念。
对于每一个uvm_component,它都有一个m_child[]用来保存它的孩子,同理也告诉这些孩子他们的父母是谁。
data:image/s3,"s3://crabby-images/e2800/e28005dba891c985c0f00d6728f2be00d2f5bd17" alt=""
先来看看uvm_component.svh对应的源码:
data:image/s3,"s3://crabby-images/33704/337048607cf0dea576d0b5b4115e03a4fa2d0b79" alt=""
- m_parent/m_children[string]/m_children_by_handle[]构建了整个UVM的树形结构。
data:image/s3,"s3://crabby-images/f24f5/f24f5e9dc8dc12818245b08b22f428f8f249f01a" alt=""
- line1736-1739,uvm_root的name==top,但是set_name("")所有在get_full_name等函数调用的时候,就不会显示这一级。
- 判断出来是最顶层,直接return,m_parent == null并且m_child[]也不会赋值。
data:image/s3,"s3://crabby-images/b6c93/b6c93d7a28efc7a68826683a44c09fb06b5917a2" alt=""
- line1748,相信看过uvm_phase就会知道这个函数。
- line1749,判断uvm_build_phase是不是在common_domain里面。
- line1771,通常在uvm_test_top,case的那一层parent的参数设置为null。
data:image/s3,"s3://crabby-images/85363/85363520b30dbdcc55e0075963a90be0f729d957" alt=""
data:image/s3,"s3://crabby-images/43aed/43aed39d37aad0597d9ec4a1c3653d4fedc1a67f" alt=""
data:image/s3,"s3://crabby-images/e918b/e918bdcb289864f1acfa2df6b3cbd34d2dae3314" alt=""
- m_parent
- m_children[]
- m_children_by_handle[]
构建了UVM树形结构
data:image/s3,"s3://crabby-images/8e6fc/8e6fcaa1c69257d2cb688c042d9670100dd40a56" alt=""
网友评论