## Star

eConfig is a design rule checker and device configuration tool for eAsic technology. It checks various design rules checkings(DRC) on the user design.

The main purpose of this is to find out errors in the design as early as possible.

eConfig DRCs are used at different stages of eAsic tool flow. It runs in front-end(FE): after Fit Device(Initial) and Floorplaning(Post-FP) steps, the name of executable is rdbeconfig. At these steps it uses data from RDB DB.

Also eConfig runs in back-end(BE): in Device Mapping(eConfig1), Configure Device(eConfig2) and Handoff(eConfig3) steps, the name of executable is econfig. Econfig uses data from OA DB.

| Description                                                                                                                                                                                                                                             | Туре          | Initial | Post-FP | eConfig<br>1 | eConfig<br>2 | eConfig<br>3 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|---------|--------------|--------------|--------------|
| Top level port connection check  Check that each top level port from the design is connected to a PAD or MGIO.                                                                                                                                          | Warning       | Х       | Х       | Х            | X            | X            |
| Top level port floating check  Check that each top level port is not floating.                                                                                                                                                                          | Error         | X       | Х       | X            | Х            | X            |
| Top level port connection check for intrinsic  Check if each top level port is not connected to intrinsic pin accept PAD or MGIO instances.                                                                                                             | Error         | X       | X       | X            | X            | X            |
| Multi-driven net and inout pin check  Check that there are no nets with multiple drivers and unexpected inout pins. Known exceptions are handled.                                                                                                       | Error         | X       | Х       | Х            | X            |              |
| PLL output check  For each PLL, check that outputs 6-7 are not used, unless all outputs 0-5 are all used. In other words, the design must use outputs 0-5 before using outputs 6-7.                                                                     | Error/Warning | X       | X       |              |              |              |
| Pin check by pattern  Special connectivity checks for pins listed in file check_pin_net.csv. For example, we check that pin eclkgate/CLKEN is not tied to ground. Various combinations of power/ground/signal checks are available.                     | Error         | X       | Х       | Х            | Х            | Х            |
| Top level port name check  Check that design top level port names are different from device top level port names and from shared test pin names.                                                                                                        | Error         | Х       | X       | X            | X            |              |
| MGIO top level port check  Check that top level pins of MGIO instances are connected to unique top level design ports.                                                                                                                                  | Error         | Х       | Х       | Х            | Х            | X            |
| Sequential cell unconnected pin check  Check if a sequential cell (edff, bram, regfile) data pins (I_D, O_Q) are all unconnected.                                                                                                                       | Warning       | Х       | X       | X            | X            | Х            |
| Clock gate check for BROM  For each BROM instance (bram/regfile with defparam INIT_ON), check that there is a clock gate on the clock source path. Both clock pins I_CLKA/I_CLKB are checked. Valid clock gate cells are eclkgate, eclkgenloc, eclkmux. | Error         | X       | X       | х            | х            | X            |

| IO and MGIO placement check                                                                                                                                                                                                                                                                                                       | Error       |   | Х |   |   |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---|---|---|---|---|
| Check that all IO and MGIO instances are placed and not overlapping. General placement check for all instances happens in eConfig.                                                                                                                                                                                                |             |   |   |   |   |   |
| Corner block check                                                                                                                                                                                                                                                                                                                | Fatal/Error | Х | Х |   |   |   |
| Check that corner block is instantiated in the design.                                                                                                                                                                                                                                                                            |             |   |   |   |   |   |
| PLL/MGIO power/ground pin check                                                                                                                                                                                                                                                                                                   | Error       |   | X | Χ | Χ | Х |
| Check that all power/ground pins of PLL and MGIO instances are bonded out in the package. Check power/ground domains for PLL instances.                                                                                                                                                                                           |             |   |   |   |   |   |
| Test pin check                                                                                                                                                                                                                                                                                                                    | Error       |   | Х | Χ | Χ | Χ |
| Check that all test pins are bonded out in the package.                                                                                                                                                                                                                                                                           |             |   |   |   |   |   |
| Check that VREF IO is not placed on a location with input test pin.                                                                                                                                                                                                                                                               |             |   |   |   |   |   |
| IO configured as xxxpwrpad or xxxvsspad can not be placed on a location with output test pin.                                                                                                                                                                                                                                     |             |   |   |   |   |   |
| Temperature diode check                                                                                                                                                                                                                                                                                                           | Error       | Х | Х | Χ | Χ | Χ |
| Check that top level ports of all enabled temperature diodes are bonded out                                                                                                                                                                                                                                                       |             |   |   |   |   |   |
| IO port connection check                                                                                                                                                                                                                                                                                                          | Error       | Х | Х | Х | Χ | Х |
| Check that PAD, PADP, PADN pins of IO cells are connected to top level ports. VREF and UNBOUNDED IOs are allowed not to be connected.                                                                                                                                                                                             |             |   |   |   |   |   |
| Dedicated test pin check                                                                                                                                                                                                                                                                                                          | Error       |   | Х | Х | Х | X |
| Check that no user pin is assigned to dedicated test pin locations. Dedicated locations include TEST_MODE, JTAG_MODE and other JTAG pins (if jtag option is enabled). Also, dedicated pins include IOs with valid defparam JTAG_FUNCTION ("user JTAG").                                                                           |             |   |   |   |   |   |
| ODT configuration check                                                                                                                                                                                                                                                                                                           | Error       | Х | Х | Х | Х | Х |
| Check that ODTEN signal value matches configuration of padng_odt instance. If padng_odt instance is offx then ODTEN must be 0. If padng_odt instance is not offx then ODTEN must be either 1 or a net.                                                                                                                            |             |   |   |   |   |   |
| Uided pin check                                                                                                                                                                                                                                                                                                                   | Error       |   | Х | Х | Χ | Х |
| Check that IOs with bsc type "uided" are not assigned to shared output test pin location                                                                                                                                                                                                                                          |             |   |   |   |   |   |
| Intrinsic net check                                                                                                                                                                                                                                                                                                               | Error       |   | Х | Х | Χ | Х |
| Check that intrinsic nets from the design match their counterparts on the physical device. In other words, one intrinsic net from the design cannot connect pins from different device intrinsic nets. However, an intrinsic pin in the design may be connected to a valid constant as defined in the corresponding pininfo file. |             |   |   |   |   |   |
| Mixed net check                                                                                                                                                                                                                                                                                                                   | Error       | Х | X |   |   |   |
| Check that each net connects only intrinsic or only routable pins. There are certain exceptions involving logical clock macros and test pins.                                                                                                                                                                                     |             |   |   |   |   |   |

| Placement check  Check that all instances are placed on correct physical sites and that they do not overlap (with exception of hecell/efa cells). Check packing of hecell/efa.  Routable net check  Check that routable nets do not have connections with intrinsic pins (with known exceptions)  Undriven pin check  Check that each routable input pin is connected to a net with driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check  Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN!= 0 and COMP_UPD != 0, check that all bits of CADD. I and CDAT. I are connected to a non-constant net. | X    | X<br>X | X X X | X X X | X<br>X |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|-------|-------|--------|
| that they do not overlap (with exception of hecell/efa cells). Check packing of hecell/efa.  Routable net check  Check that routable nets do not have connections with intrinsic pins (with known exceptions)  Undriven pin check  Check that each routable input pin is connected to a net with driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check  Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN!= 0 then COMP_UPD!= 0.  Also, if COMP_EN!= 0 and COMP_UPD!= 0, check that all bits                                                                                                                                                  | X    | X      | X     | X     | X      |
| Check that routable nets do not have connections with intrinsic pins (with known exceptions)  Undriven pin check  Check that each routable input pin is connected to a net with driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check  Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                | X    | X      | X     | X     | X      |
| Undriven pin check Check that each routable input pin is connected to a net with driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                   | X    | X      | X     |       |        |
| Check that each routable input pin is connected to a net with driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check  Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                  | X    | X      | X     |       |        |
| driver, and it is not connected to top level port (for non-padless designs). Check if output of edff is used.  VCCIO voltage check  Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |       | X     |        |
| Check that all IOs in a subbank have the same VCCIO voltage  VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0.  Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |        |       | Х     |        |
| VREF voltage check  Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      | X      | X     |       | X      |
| Check that all IOs in VREF subbank have the same VREF voltage  Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0.  Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      | X      | X     |       |        |
| Vreftune group check  Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |        |       | Х     | X      |
| Check that all IOs that require vreftune have pin VREFT connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |        |       |       |        |
| connected. Extract vreftune groups from the netlist and check that they match vreftune groups and connectivity on the device.  COMP_EN/COMP_UPD check  For each IO check that if COMP_EN != 0 then COMP_UPD != 0.  Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      | Х      | Х     | Х     | X      |
| For each IO check that if COMP_EN != 0 then COMP_UPD != 0. Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |        |       |       |        |
| Also, if COMP_EN != 0 and COMP_UPD != 0, check that all bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | al X | Х      | Х     | Х     | Х      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |        |       |       |        |
| Also if COMP_EN == 0 then COMP_UPD, CADD_I, CDAT_I all should be 0; this is fatal error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |        |       |       |        |
| If COMP_EN == 1 or COMP_EN == NET, then COMP_UPD should be connected to register. If no, this is error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |        |       |       |        |
| Also if COMP_UPD == 1 and COMP_EN == 0, issue a warning because of possible design problem.  if COMP_UPD == 1 and COMP_EN == 0 or NET then print error, because latches will be transparent all the time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |        |       |       |        |
| DDR DLL check Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Х    | Х      | Х     | Х     | X      |
| Check that for each active edlygenddr4s, corresponding dqsgen instance is also active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |        |       |       |        |
| LVDS ODTEN check Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Х    | Х      | Х     | Х     | X      |
| Check that ODTEN for output LVDS IOs is not 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |        |       |       |        |
| CLKDIV_PWRDN check Error/Warning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |       | Х     | X      |
| Check that the bits of defparam CLKDIV_PWRDN match with the used outputs of PLL. If a bit of CLKDIV_PWRDN is 0, corresponding PLL output must be used. If the bit of CLKDIV_PWRDN is 1, corresponding PLL output must not be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |        |       |       |        |
| Bsc configuration check for differential IO  Check that If an IO has odt configured as pdif, then corresponding bsc instance must be of "double" type pad_bscd_***d*.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |        |       |       | Х      |

|                                                                                                                                                                                                                                                                                                                                                                                            | _             |   |   |   |   | ., |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---|---|---|---|----|
| IDCODE/USERCODE/PNC check                                                                                                                                                                                                                                                                                                                                                                  | Error         |   |   |   |   | Х  |
| Check that IDCODE and USERCODE paramaters from the project settings match actual tie off connections on the corner block. Also check that PNC digit cells have types corresponding PNC parameter.                                                                                                                                                                                          |               |   |   |   |   |    |
| Instance and net name uniqueness  Check that all instance and net names are unique using case insensitive comparison. Formally Verilog allows an instance and a net to have the same name, and it also allows two objects to have the same name in different letter case. However, not all 3rd party tools support these situations.  By default this check prints warning but if variable | Error         | X | x | х |   |    |
| ETOOLS_NAME_CONFLICT_ERROR=1 then it prints errors.                                                                                                                                                                                                                                                                                                                                        |               |   |   |   |   |    |
| Intrinsic pins tieoff check  Unconnected intrinsic pins in design should be tieoffed constant net using pininfo information.                                                                                                                                                                                                                                                               | Error         | x | x | X |   |    |
| Combined pins nets check  Some pins in design should be connected to the same net.  Groups of such pins are defined in combined_ports.txt file                                                                                                                                                                                                                                             | Error         |   | x | x | х | x  |
| MGIO IDDQ pin check                                                                                                                                                                                                                                                                                                                                                                        |               |   |   |   |   |    |
| If MGIO is used, IDDQ must be tied to 0. If MGIO is not used, IDDQ must be tied to 1.                                                                                                                                                                                                                                                                                                      | Error         | X | X | X | X | X  |
| MGIO AREFENABLE pin check                                                                                                                                                                                                                                                                                                                                                                  |               |   |   |   |   |    |
| Pin AREFENABLE should not be tieoff for used MGIO.                                                                                                                                                                                                                                                                                                                                         | Error         | X | X | X | X | X  |
| InOut IO check                                                                                                                                                                                                                                                                                                                                                                             |               |   |   |   |   |    |
| Check RX/TX configurations of IO instances and compare them with IE/OE values and top ports directions.                                                                                                                                                                                                                                                                                    | Error         | X | X | X | X | X  |
| WKE check                                                                                                                                                                                                                                                                                                                                                                                  |               |   |   |   |   |    |
| Check that I_WKE(P N) pins are connected to any net. If pin I_WKE is not connected at all then tool prints error. If pin is not connected to constant net then tool prints warning.                                                                                                                                                                                                        | Error/Warning | X | X | X | X | X  |
| Check eclkgate and edff polarity                                                                                                                                                                                                                                                                                                                                                           |               |   |   |   |   |    |
| Check polarity of eclkgate and edff's in clock nets. Type eclkgaten_r is only driving pins edffn*/I_CLK. Type eclkgate_r is not driving any pin edffn*/I_CLK.                                                                                                                                                                                                                              | Error         | X | X |   |   |    |
| Check dcdl type upon used device                                                                                                                                                                                                                                                                                                                                                           |               |   |   |   |   |    |
| If the device type is not 'e', do not allow to use dcdl3 types in design.                                                                                                                                                                                                                                                                                                                  | Fatal         | X | X | X | X | X  |
| Check dcdl DFT_O pin                                                                                                                                                                                                                                                                                                                                                                       |               |   |   |   |   |    |
| DFT_O pin of dcdl type cell should not drive any logic cell except buffer.                                                                                                                                                                                                                                                                                                                 | Eroor/Fatal   | X | X | X | X | X  |
| Check dcdl defparam FV_MODEL                                                                                                                                                                                                                                                                                                                                                               |               |   |   |   |   |    |
| Print warning for every dcdl instance that has defparam FV_MODEL with value "SIMPLE".                                                                                                                                                                                                                                                                                                      | Warning       | X | X | X | X | X  |
|                                                                                                                                                                                                                                                                                                                                                                                            |               |   |   |   |   |    |

| Check dcdl connections mtx* and mrx* cell types  If dcdl drives mtx*, print an error. If mrx* drives dcdl, print an error.                                                                                                                | Error | X | X |   |   |   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|---|---|---|---|
| Check clock inverter types  Clock inverter types for design depend upon device version. eclkinvb_on/eclkinvb1b_on types can not be used for device version < 'f', eclkinv_on/eclkinv1b_on ones can not be used for device version >= 'f'. | Error |   |   | x |   |   |
| Check tx/rx/logical cell types  TX/RX/LOGICAL clock macros types should be compatible each other. They should be configured by the same sets of virtual pins: V_IOSUPPLY, V_RXVAR and V_TXVAR.                                            | Error |   |   |   | X | X |