-
Notifications
You must be signed in to change notification settings - Fork 397
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2446 from verilog-to-routing/routing_constraints
Global Nets Routing constraints
- Loading branch information
Showing
62 changed files
with
2,916 additions
and
1,232 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
from sphinxcontrib.domaintools import custom_domain | ||
from sphinx.util.docfields import * | ||
|
||
|
||
def setup(app): | ||
app.add_domain( | ||
custom_domain( | ||
"VPRConstraintsDomain", | ||
name="vpr_constraints", | ||
label="Place and Route Constraints", | ||
elements=dict( | ||
tag=dict( | ||
objname="Attribute", | ||
indextemplate="pair: %s; Tag Attribute", | ||
fields=[ | ||
GroupedField( | ||
"required_parameter", label="Required Attributes", names=["req_param"] | ||
), | ||
GroupedField( | ||
"optional_parameter", label="Optional Attributes", names=["opt_param"] | ||
), | ||
Field("required", label="Tag Required", names=["required"]), | ||
], | ||
), | ||
), | ||
) | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
Global Routing Constraints | ||
========================== | ||
.. _global_routing_constraints: | ||
|
||
VPR allows users to designate specific nets in the input netlist as global and define the routing model for the global nets by utilizing a VPR constraints XML file. These routing constraints for global nets are specified inside the VPR constraints file in XML format, as described in the following section. | ||
|
||
A Global Routing Constraints File Example | ||
------------------------------------------ | ||
|
||
.. code-block:: xml | ||
:caption: An example of a global routing constraints file in XML format. | ||
:linenos: | ||
<vpr_constraints tool_name="vpr"> | ||
<global_route_constraints> | ||
<set_global_signal name="clock*" route_model="dedicated_network" network_name="clock_network"/> | ||
</global_route_constraints> | ||
</vpr_constraints> | ||
Global Routing Constraints File Format | ||
--------------------------------------- | ||
.. _global_routing_constraints_file_format: | ||
|
||
.. vpr_constraints:tag:: <global_route_constraints>content</global_route_constraints> | ||
Content inside this tag contains a group of ``<set_global_signal>`` tags that specify the global nets and their assigned routing methods. | ||
|
||
.. vpr_constraints:tag:: <set_global_signal name="string" route_model="{ideal|route|dedicated_network}" network_name="string"/> | ||
:req_param name: The name of the net to be assigned as global. Regular expressions are also accepted. | ||
:req_param route_model: The route model for the specified net. | ||
|
||
* ``ideal``: The net is not routed. There would be no delay for the global net. | ||
|
||
* ``route``: The net is routed similarly to other nets using generic routing resources. | ||
|
||
* ``dedicated_network``: The net will be routed through a dedicated clock network. | ||
|
||
:req_param network_name: The name of the clock network through which the net is routed. This parameter is required when ``route_model="dedicated_network"``. | ||
|
||
|
||
Dedicated Clock Networks | ||
-------------------------- | ||
|
||
Users can define a clock architecture in two ways. First, through the architecture description outlined in section :ref:`Clocks <clock_architecture>`. By using the ``<clocknetworks>`` tag, users can establish a single clock architecture with the fixed default name "clock_network". When routing a net through the dedicated network described with this tag, the network name must be set to ``"clock_network"``. | ||
|
||
Alternatively, users can define a custom clock network architecture by inputting a custom resource routing graph. In this approach, users can specify various clock routing networks, such as a global clock network and multiple regional clock networks. There are three main considerations for defining a clock network through a custom RR graph definition, as described in the following sections. | ||
|
||
Virtual Sinks Definition for Clock Networks | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
For VPR to route global nets within defined clock networks, there needs to be a virtual sink node defined in the RR graph per each clock network. This virtual sink, which is of the type ``"SINK"``, must have incoming edges from all drive points of the clock network. The two-stage router used for global net routing will initially route to the virtual sink (which serves as the entry point of the clock network) in the first stage and then from the entry point to the actual sink of the net in the second stage. | ||
|
||
To indicate that a node represents a clock network virtual sink, users can utilize the ``"clk_res_type"`` attribute on a node setting it to ``"VIRTUAL_SINK"``. | ||
|
||
Distinguishing Between Clock Networks | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
Given the support for multiple clock networks, VPR needs a way to distinguish between different virtual sinks belonging to various clock networks. This is achieved through the optional ``"name"`` attribute for the rr_node, accepting a string used as the clock network name. Therefore, when the ``"clk_res_type"`` is set to ``"VIRTUAL_SINK"``, the attribute ``"name"`` becomes a requried parameter to enable VPR to determine which clock network the virtual sink belongs to. | ||
|
||
When specifying the network_name in a global routing constraints file for routing a global net through a desired clock network, as described in the :ref:`above <global_routing_constraints_file_format>` section, the name defined as an attribute in the virtual sink of the clock network should be used to reference that clock network. | ||
|
||
Segment Definition for Clock Networks | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
The node types ``"CHANX"`` and ``"CHANY"`` can construct the clock routing architecture, similar to a generic routing network. However, to identify nodes that are part of a clock network, one can define unique segments for clock networks. To indicate that a segment defined is a clock network resource, users can use the optional attribute ``res_type="GCLK"``. Therefore, nodes with a segment ID of this defined segment are considered to be part of a clock network. | ||
|
||
While VPR currently does not leverage this distinction of clock network resources, it is recommended to use the ``res_type="GCLK"`` attribute, as this preparation ensures compatibility for future support. | ||
|
||
|
||
Example of RR Graph Definition for Clock Networks | ||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
|
||
Below are snapshots of a sample RR graph that illustrate how to define a clock network. This example demonstrates the definition of a virtual sink node, a clock network segment, and a CHANY node that is part of the clock network. | ||
|
||
For the node with ``id="12746"``, the ``res_type="VIRTUAL_SINK"`` attribute marks it as the virtual sink node of a clock network named ``"global_network"``, as specified by the ``name`` attribute. | ||
|
||
For the segment with ``id="1"``, the ``res_type="GCLK"`` attribute indicates that this segment is a clock network resource. | ||
|
||
The ``"CHANY"`` node with the ``id="12746"`` has ``segment_id="1"``, which means this resource belongs to the clock network. | ||
|
||
.. code-block:: xml | ||
:caption: Example snippets from an RR graph describing part of a clock network. | ||
:linenos: | ||
<rr_nodes> | ||
<!-- Definition of a virtual sink node for a clock network named "global_network" --> | ||
<node capacity="1" clk_res_type="VIRTUAL_SINK" id="12746" name="global_network" type="SINK"> | ||
<loc layer="0" ptc="72" xhigh="6" xlow="6" yhigh="6" ylow="6"/> | ||
<timing C="0" R="0"/> | ||
</node> | ||
<!-- Definition of a CHANY node as part of the clock network --> | ||
<node capacity="1" direction="BI_DIR" id="12668" type="CHANY"> | ||
<loc layer="0" ptc="20" xhigh="6" xlow="6" yhigh="6" ylow="6"/> | ||
<timing C="1.98240038e-13" R="50.4199982"/> | ||
<segment segment_id="1"/> | ||
</node> | ||
<!-- ... other nodes ... --> | ||
</rr_nodes> | ||
<segments> | ||
<!-- Definition of a clock network segment --> | ||
<segment id="1" name="spine1_drive" res_type="GCLK"> | ||
<timing C_per_meter="2.06999995e-14" R_per_meter="50.4199982"/> | ||
</segment> | ||
<!-- ... other segments ... --> | ||
</segments> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
VPR Constraints | ||
========================= | ||
.. _vpr_constraints: | ||
|
||
VPR allows users to run the flow with placement constraints that enable primitives to be locked down to a specific region on the chip and global routing constraints that facilitate the routing of global nets through clock networks. | ||
|
||
Users can specify these constraints through a constraints file in XML format, as shown in the format below. | ||
|
||
.. code-block:: xml | ||
:caption: The overall format of a VPR constraints file | ||
:linenos: | ||
<vpr_constraints tool_name="vpr"> | ||
<partition_list> | ||
<!-- Placement constraints are specified inside this tag --> | ||
</partition_list> | ||
<global_route_constraints> | ||
<!-- Global routing constraints are specified inside this tag --> | ||
</global_route_constraints> | ||
</vpr_constraints> | ||
.. note:: Use the VPR option :option:`vpr --read_vpr_constraints` to specify the VPR constraints file that is to be loaded. | ||
|
||
The top-level tag is the ``<vpr_constraints>`` tag. This tag can contain ``<partition_list>`` and ``<global_route_constraints>`` tags. The ``<partition_list>`` tag contains information related to placement constraints, while ``<global_route_constraints>`` contains information about global routing constraints. The details for each of these constraints are given in the respective sections :ref:`Placement Constraints <placement_constraints>` and :ref:`Global Route Constraints <global_routing_constraints>`. | ||
|
||
.. toctree:: | ||
:maxdepth: 2 | ||
|
||
placement_constraints | ||
global_routing_constraints | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.