Difference between revisions of "Does Verific support XMR?"

From Verific Design Automation FAQ
Jump to: navigation, search
Line 1: Line 1:
 
'''Q: Does Verific support cross module references (XMR)?'''
 
'''Q: Does Verific support cross module references (XMR)?'''
  
With and without "hierarchy tree" feature, Verific fully supports XMR in analysis and static elaboration. But without it, support for XMR in RTL elaboration is limited.
+
Reference: [http://www.verific.com/docs/index.php?title=Hierarchy_Tree Hierarchy Tree]
 +
<br />Code example: [https://www.verific.com/faq/index.php?title=Hierarchy_tree_RTL_elaboration Hierarchy tree RTL elaboration]
 +
 
 +
<br />With and without "hierarchy tree" feature, Verific fully supports XMR in analysis and static elaboration. But without it, support for XMR in RTL elaboration is limited.
  
 
"hierarchy tree" is included in "static elaboration" feature.
 
"hierarchy tree" is included in "static elaboration" feature.
Line 26: Line 29:
  
 
A side effect: defparam containing interface instance reference (SystemVerilog) is not supported in RTL elaboration.
 
A side effect: defparam containing interface instance reference (SystemVerilog) is not supported in RTL elaboration.
 
Code example: [https://www.verific.com/faq/index.php?title=Hierarchy_tree_RTL_elaboration Hierarchy tree RTL elaboration]
 
 
Reference: [http://www.verific.com/docs/index.php?title=Hierarchy_Tree Hierarchy Tree]
 

Revision as of 18:09, 25 February 2021

Q: Does Verific support cross module references (XMR)?

Reference: Hierarchy Tree
Code example: Hierarchy tree RTL elaboration


With and without "hierarchy tree" feature, Verific fully supports XMR in analysis and static elaboration. But without it, support for XMR in RTL elaboration is limited.

"hierarchy tree" is included in "static elaboration" feature.

The reason for limited support in RTL elaboration (without "hierarchy tree" feature) for XMR is that for Verilog, the order of elaboration of modules is nondeterministic. If module "foo" has not been elaborated, the elaborator will not be able to resolve "foo.bar". As a collorary, without "hierarchy tree," "circular XMR," as in the testcase below (instance i1 refers to a signal in instance i2, and vice versa), is not supported:

   module sub2(out);
       output out;
       assign top.i1.out = 0;
   endmodule 
   module sub1(out);
       output out;
       assign top.i2.out = 0;
   endmodule
   module top();
       sub1 i1();
       sub2 i2();
   endmodule

Note that for XMR support in RTL elaboration (even though limited), these runtime flags need to be enabled (set to 1) before design analysis:

   db_preserve_user_nets
   db_allow_external_nets

A side effect: defparam containing interface instance reference (SystemVerilog) is not supported in RTL elaboration.