The BUILD_ECS MACRO Creates a Named ELECTRICAL_CONSTRAINT_SET (ECS) which can be applied to matching NetNames
Electrical Constraint Sets
An Electrical Constraint Set (ECS) is use to constrain the Electrical attributes of signals on each routing layer. Nets
BUILD_ECS can constrain many different parameters for specify many different constraints to apply to a group of signals, and can also apply a PHYSICAL_CONSTRANT_SET (PCS) to the same group.
PARAMETERS that can be constrained include:
VIAS_MAX,VIAS_MATCH,MIN_PROP_DLY,MAX_PROP_DLY,MIN_TOTAL_ETCH,MAX_TOTAL_ETCH,
TOP_MAP_MODE,TOP_VERIFY_SCHEDULE,TOP_SCHEDULE_CONTROL,STUB_LENGTH,MAX_EXPOSED,MAX_PARALLEL,LAYER_SETS
BUILD_ECS
This Line tells dal constraints to create a new named ECSsyntax
Syntax:
BUILD_ECS | NAME=> | NAME_FOR_ECS
TYPE
the The TYPE => Attribute tells dal constraints what type of ECS the user wants to create
Valid options
are:
DIFF_PAIR and SINGLE_ENDED
Syntax:
TYPE=>[DIFF_PAIR|SINGLE_ENDED
UNITS
The UNITS=>Attribute tells dal constraints what units to use for the PCS
Valid options are: MILS and MM
ON_LAYERS
the ON_LAYERS=> attribute lets the user exclude certain routing layers for the target nets
The ON_LAYERS attribute is converted to AllegroPCB ALLOW_ETCH contraints
All nets default to ALLOW_ETCH =1 for every layer.
The ON_LAYERS lets us turn off the ALLOW_ETCH for specific layers
Syntax:
ON_LAYERS=>-12,-15
this command says that the target nets are allowed on every layer except Layers 12 and 15
TRACE_WIDTH_PARAMETERS
the TRACE_WIDTH_PARAMETERS attribute provides a list of routing widths and spacing for each routing layer (using the UNITS attribute)
example syntax for TYPE=>DIFF_IMPEDANCE
TRACE_WIDTH_PARAMETERS=> L1,L24=10/7.5:L4,L5,L8,L9,L16,L17,L20,L21=3.7/5
This specifies that target diff_pair nets on Layers 1 and 24 should be routed at 10 mils and 7.5 mil edge to edge spacing. On layers 4,5,6,7,8,9,16,17 and 21 target diff_pairs should be routed at 3.75 mils and 5 mil spacing
example syntax for TYPE=>SINGLE_ENDED_IMPEDANCE
TRACE_WIDTH_PARAMETERS=> L1,L24=12:L4,L5,L8,L9,L16,L17,L20,L21=6
This specifies that target single_ended nets on Layers 1 and 24 should be routed at 12 mils, On layers 4,5,6,7,8,9,16,17 and 21 target single_ended nets should be routed at 6 mils
example syntax for TYPE=>POWER
TRACE_WIDTH_PARAMETERS=> L1,L24=25:L4,L5,L8,L9,L16,L17,L20,L21=18]
The SINGLE_ENDED ECS allows the user to define multiple sets of properties to apply to a group of single ended signals.
The DIFF_PAIR ECS can be used to add the same parameters as the SINGLE_ENDED, and can be used to add the DIFF_PAIR ECS Properties/Attributes listed below
SINGLE_ENDED Properties/Attributes supported by Allegro Constraint System
If Bold they are also supported by dal constraint
- VIAS_MAX
- VIAS_MATCH
- MIN_PROP_DLY
- MAX_PROP_DLY,
- MIN_TOTAL_ETCH
- MAX_TOTAL_ETCH
- TOP_MAP_MODE
- TOP_VERIFY_SCHEDULE
- TOP_SCHEDULE_CONTROL
- STUB_LENGTH
- MAX_EXPOSED
- MAX_PARALLEL
- LAYER_SETS
DIFF_PAIR ECS Properties/Attributes
The Dynamic Diff Pair constraints are used to track and flag the intra-pair skew from the signal source to its destination.
Differential pair routing only works well when the signal edges or transitions are closely aligned as they travel from one end to the other. As speeds increase, the edge times get smaller and smaller and the margin for error becomes greater. When a diff pair route turns a corner, the outside pair wire takes a longer path than the inside pair wire causing unwanted skew between the signals. If this skew is significant, the edge transitions start to get out of phase and the differential pair loses some of its magical properties. In this case the skew needs to be removed as quickly as it can be. This can be accomplished by making sure the next turn goes the opposite direction so that the inside wire is now the outside wire. Another method is to add a small 'bump' to the inside wire whose length match the extra length that the outside wire experienced. The bump should be added as close as possible to the corner turn so that the signal transitions travel the majority of the diff_pair length in match step.
The Cadence Allegro Constraint System provides a handful of diff_pair tolerance properties to enable tracking of the skew from the transmitter output to the receiver input.
Properties are:
- GATHER_CONTROL
- MAX_UNCOUPLED
- DPA_TOLERANCE
- DPA_MAX_LEN
- STATIC_PHASE
In the sample CRF worksheet a DIFF_PAIR_CALC_WORKSHEET page is provided to help calculate rational values for these parameters that are used to constrain the DIFF_PAIRS, based on the Bit Rate of the actual DiffPair. It can be very beneficial to use a reference to the cells that hold the values calculated on the WORKSHEET to set the value for the properties instead of hard-coding the values. If you use a reference to a cell that holds a calculation, and update something in the the Calculation worksheet, then the property values will automatically be updated.
AUTO_IDENTIFY_PIN_DIR MACRO with Dynamic DiffPair
The Dynamic Phase constraints always start at the driver pin and end at the receiver pin so its important that the pinTypes are correctly defined in the netlist. PinType information is extracted from the schematic symbol when the netlist is created and some organizations do not pay close attention to the types when they create their symbols (some may define every pin as an inout). The AUTO_IDENTIFY_PIN_DIR MACRO in the CRF allows the user to override the pinTypes in the netlist to ensure the Dynamic Phase constraints are properly applied.
dalTools diffpair utility
The dalTools diffpair utility provides a very helpful video on how to route diffPairs which have been constrained using the Dynamic Phase Constraints. The video is available on the 'Dyn phase' tab
ASSIGN_PCS
The ASSIGN_PCS Attribute assigns an existing named PCS to any nets that are assigned to this ECS.
This provides a powerful way to define the controlled Impedance and or line widths for a whole group of nets.
The PCS may have been created using the BUILD_PCS MACRO or when dal constraints imported the stackup.
Syntax:
ASSIGN_PCS=>PCS_NAME
Example:
ASSIGN_PCS=>90_OHM_DIFF
Using the ASSIGN_PCS
In the picture below we show the BUILD_ECS referencing to a custom 90_OHM_DIFF PCS created by the BUILD_PCS MACRO.
Using the ASSIGN_PCS is a convenience, saving the user from having to identify the NETS for the BUILD_PCS MACRO And for the BUILD_ECS MACRO.
Note that the majority of PCS will be created when importing the stackup, so the user may need to refer to the Constraint Manager Physical Tab or the stackup import report
to actually see and use the resulting PCS names from the import.
MEMBERS
The MEMBERS=> Attribute tells dal constraints what nets to apply the new PCS ECS to.
This is an optional attribute when you are creating a PCS that will be assigned from an ECS.
The syntax isSyntax:
MEMBERS=>net_match1,net_match2.... net_matchNlike
Example:
MEMBERS=>P48V>VCC,P48V_RTNVDD
This tells dal constraints to assign this PCS ECS to any net containing 'P48V' or 'P48V_RTN'
in this case the net_match is a simple text pattern
The MEMBERS net_matches are treated as regular expressions by dal constraints and are quite powerful.
To see more information on regular expression entry see Regular Expressions In CadEnhance Tools
NOT_MATCHING
the NOT_MATCHING =>Attribute Attribute is optional and works together with the MEMBERS attribute to fully define the set of target nets
Syntax:
the NOT_MATCHING is a comma seperated separated list of patterns that will be used to exclude nets from the set of nets that match the MEMBER patternsTogether the 2 attributes make very simple to define
Example:
NOT_MATCHING=>_GOOD,_MON,_SENSE
MEMBERS and NOT_MATCHING
Together the MEMBERS and NOT_MATCHING attributes make it very efficient to target a large set of diverse nets without having to create a very large long list of specific matches. You can create a very general set of matches with the MEMBERS attribute and then exclude certain pattern matches with the NOT_MATCHING patterns.
In the above example, with MEBERS set to VCC,VDD and NOT_MATCHING set to _GOOD, _MON and _SENSE,
any netName containing VCC or VDD would be targeted unless they contained _GOOD, _MON or _SENSE
so VCC1P8,VDD3P3_PWR, PVDD_12V, P1R5VDD would be included but VCC1P8_GOOD, PVDD_12V_SENSE and P1R5VDD_MON would not