

# **Cross Probing to Synplicity and Exemplar**

Author: Yenni Totong

# Summary

Xilinx Alliance software version 3.3.06i (3.1i Service Pack 6) or later has been enhanced to include logical and timing cross probing to **Synplify/Synplify Pro** and **LeonardoSpectrum**. The **logical cross probing** feature enables the user to select instances or nets in warning or error messages in the Error Viewer to cross probe back to the synthesis tool schematic view. This is useful for debugging a design with logical DRC errors/warnings. The **timing cross probing** feature enables the user to select a path, nets or instances to cross probe from the timing report within Timing Analyzer back to the synthesis tool schematic view. This feature is useful for analyzing timing problems. These functionalities can be used with **Synplify / Synplify Pro version 6.0.0 or later** from Synplicity and with **LeonardoSpectrum version 2000.1b or later** from Exemplar Logic.

# Displaying the Navigation Report for Logical Cross Probing

A navigation report (NAV) file can be viewed in the new Error Viewer window now available in the Xilinx Alliance software. The NAV file is produced by the translate stage of the Flow Engine in Design Manager, or when the NGDBuild command is run from the command line. NGDBuild names the file <design name>\_ngdbuild.nav. The Navigation Report icon can be found in the Design Manager Report Browser. See Figure 1.





The Navigation Report icon is double clicked to launch the Error Viewer, which then displays the NAV file. The NAV file will be produced by NGDBuild even if the design produces no DRC errors or warning messages. In this case, the Error Viewer will display an empty screen.

Alternatively, the Error Viewer can be launched from the command line with the following command:

errview <design\_name>\_ngdbuild.nav

**NOTE:** The Error Viewer executable errview is located in the \$XILINX/bin/<platform> directory. The <platform> can be hp, nt, or sol.

<sup>© 2000</sup> Xilinx, Inc. All rights reserved. All Xilinx trademarks, registered trademarks, patents, and disclaimers are as listed at <a href="http://www.xilinx.com/legal.htm">http://www.xilinx.com/legal.htm</a>. All other trademarks and registered trademarks are the property of their respective owners. All specifications are subject to change without notice.

See Figure 2 for an example of a navigation report file.

| 🔮 errnav_ex_ngdbuild.nav - Xilinx Error Viewer                                                                                                                                      | ×  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>H</u> elp                                                                                                                                 |    |
|                                                                                                                                                                                     |    |
| clock net <u>'wr_n_c'</u> has non-clock connections (WARNING : 477)<br>logical net <u>'GND'</u> has no load (WARNING : 454)<br>logical net <u>'VCC'</u> has no load (WARNING : 454) |    |
| For Help, press F1                                                                                                                                                                  | // |

X406\_02\_083100



Nets that contain warnings or errors are highlighted in blue by default. These nets are active links that can be used to navigate to the Synplify / Synplify Pro or LeonardoSpectrum schematic viewer. With the proper settings, the user can click on the highlighted net name in the Error Viewer to navigate to the corresponding net in the synthesis tool's schematic viewer.

**Note:** The highlight color and the font in the Error Viewer can be changed from **File**  $\rightarrow$  **Preference** setting.

Displaying the Navigable Timing Report for Timing Cross Probing

A **navigable timing report (XML)** file is now available in the Xilinx Alliance software.Opening the XML file in Timing Analyzer will display hyperlink of paths and instances. The paths and instances can be clicked to cross probe to Synplify/Synplify Pro or LeonardoSpectrum.

The XML file can be produced from the **"trce"** command or from the **Timing Analyzer**. The Design Manager produces an XML file by default by executing "trce" command.

# Producing Navigable Timing Report (XML) File from "trce" Command

The "trce" command will produce an XML file if the "-xml" option is specified as follows:

trce errnav\_ex.ncd errnav\_ex.pcf -e 3 -o errnav\_ex.twr -xml
errnav\_ex\_trce.xml

If using Design Manager, the XML file will be produced at the end of Place-and-Route stage. See Figure 3.

| 📽 errnav_ex (ver1->rev3) - Xi                                        | linx Flow Engine                                               |                                           | <u>- 0 ×</u>                |
|----------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------|-----------------------------|
| <u>Elow View Setup Utilities He</u>                                  | elp                                                            |                                           |                             |
|                                                                      |                                                                |                                           |                             |
| XC4000XL Design Flow (                                               | [rev3]                                                         |                                           | Status: OK                  |
|                                                                      | •                                                              |                                           |                             |
| Translate                                                            | Мар                                                            | Place&Route                               | Configure                   |
| Completed                                                            | Completed                                                      | Completed                                 |                             |
|                                                                      |                                                                |                                           |                             |
| Placement: Completed<br>Routing: Completed -<br>Timing: Completed -  | 1 - No errors found.<br>- No errors found.<br>31 errors found. |                                           |                             |
| PAR done.                                                            |                                                                |                                           |                             |
|                                                                      |                                                                |                                           |                             |
| trce errnav_ex.ncd e<br>Release DS6.0 - Trac<br>Copyright (c) 1995-2 | errnav_ex.pcf -e 3 -o<br>ce D.25<br>2000 Xilinx, Inc. All      | errnav_ex.twr -xml er<br>rights reserved. | rrnav_ex_trce.xml           |
|                                                                      |                                                                |                                           |                             |
|                                                                      |                                                                |                                           |                             |
| For Help, press F1                                                   |                                                                | XC4                                       | 1013×L-3-PQ160 ermav_ex.ucf |

Figure 3: Flow Engine Running "trce" to Produce XML File

The "trce" command will be executed by Flow Engine if "Produce Post Layout Timing Report" option is checked in Design Manager. This is set by default. When the Place-and-Route stage completes, a Post Layout Timing Report with Timing Analyzer icon can be found in the Design Manager Report Browser. See Figure 4.



Figure 4: Report Browser Showing Navigable Timing Report

Double clicking the Post Layout Timing Report will open the XML file in Timing Analyzer and allows the user to do cross probing. See Figure 5.

#### Notes:

If there is no timing error in the design, there might not be a navigable path in the timing report.

| 💐 Xilinx Timing Analyzer                                                                                                  |                                                               |                                                                                |                                                         |                                                                | _ 🗆 🗵            |
|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------|------------------|
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>A</u> nalyze <u>W</u> indow <u>H</u> e                                          | elp                                                           |                                                                                |                                                         |                                                                |                  |
|                                                                                                                           | E O X II ? N?                                                 |                                                                                |                                                         |                                                                |                  |
| errnav_ex_trce.xml                                                                                                        |                                                               |                                                                                |                                                         |                                                                |                  |
| Timing Report Description     Timing Constraints     Constraint compliance     Data Sheet report:     Table of Timegroups | Timing Constraints<br>OFFSET = IN 10 nS BEFOR                 | E COMP "wr_n" ;                                                                |                                                         |                                                                |                  |
| Im Timing summary                                                                                                         | Timing constraint:<br>96 items analyzed,<br>Minimum allowable | OFFSET = IN 10 nS<br>15 timing errors c<br>offset is 14.685ns                  | BEFORE COMP                                             | "wr_n" ;                                                       | ·····            |
|                                                                                                                           | Slack: -4.685ns<br>3.040ns<br>10.000ns                        | path <u>address(0)</u> to<br>delay constraint wr<br>offset <u>address(0)</u> t | <u>data hold(2)</u><br>r_n to data_ho<br>to <u>wr n</u> | relative to<br>old(2) and                                      |                  |
|                                                                                                                           | Data path address(f<br>Path starting from<br>To               | <u>)) to data hold(2)</u> c<br>Comp: P21.PAD<br>Delay type                     | contains 4 le <sup>.</sup><br>Delay(ns)                 | vels of logic:<br>Physical Resource<br>Logical Resource(s)     |                  |
|                                                                                                                           | P21.I1                                                        | Tpid                                                                           | 1.560R                                                  | <u>address(0)</u><br><u>IPAD address(0)</u><br>address(0) ibuf |                  |
|                                                                                                                           | CLB_R14C8.F1<br>CLB_R14C8.X                                   | net (fanout=2)<br>Tilo                                                         | 4.040R<br>1.590R                                        | address(0) int<br><u>ld data</u>                               |                  |
|                                                                                                                           | CLB_R14C16.G2<br>CLB_R14C16.Y                                 | net (fanout=15)<br>Tilo                                                        | 4.747R<br>1.590R                                        | <u>ld data</u><br><u>nx93</u>                                  |                  |
|                                                                                                                           | P99.0<br>P99.0K                                               | net (fanout=1)<br>Took                                                         | 3.788R<br>0.410R                                        | <u>nx99</u><br><u>data hold(2)</u><br>reg data hold(2)         |                  |
|                                                                                                                           | Total (5.150ns logi<br>(29.1% logic)                          | ic, 12.575ns route)<br>70.9% route)                                            | 17.725ns                                                | (to wr_n_int)                                                  | _                |
|                                                                                                                           | •                                                             |                                                                                |                                                         |                                                                | ▎♪╱              |
| For Help, press F1                                                                                                        |                                                               |                                                                                |                                                         |                                                                | <none> //</none> |

Figure 5: XML File Displayed in Timing Analyzer

# Producing XML File from Timing Analyzer

Timing Analyzer can be executed by double-clicking its icon in Design Manager or from a command line as follows:

timingan <routed\_design>.ncd <design>.pcf

When the routed NCD and the PCF files are loaded, click on Analyze  $\rightarrow$  Against Auto Generated Design Constraints or other constraints to analyze. See Figure 6.



Figure 6: Creating Timing Report from Timing Analyzer

A timing report similar to Figure 5 will be displayed.

The timing report can be saved as .xml format for future viewing. To do this, click **File**  $\rightarrow$  **Save As** and select "XML Timing Report (\*\_trce.xml) as the type.

# Viewing a Previously Saved XML File

A previoustly saved XML file can be viewed in timing analyzer by typing the following command:

timingan <filename>\_trce.xml

or from Timing Analyzer menu:

```
File \rightarrow Open \rightarrow Timing Report
```

# Cross Probing with Synplify / Synplify Pro

This section describes setting up sequence, guidelines, and troubleshooting procedure for logical and timing cross probing between Xilinx and the Synplify / Synplify Pro schematic viewer.

### Setup

The following describes the settings needed to do cross probing with Synplify / Synplify Pro:

 The environment variable XIL\_ITC\_XVENDOR must be set to "synplicity". There is no default value for this variable. Setting this variable to "synplicity" specifies that Synplify / Synplify Pro is the target of the cross probing applications.

To set the environment variables, do the following:

#### **UNIX Platform:**

Type the following at the command line:

setenv XIL\_ITC\_XVENDOR synplicity

#### PC Platform:

Set the following in the **autoexec.bat** or system environment setting area and reboot the PC if using Windows98.

#### set XIL\_ITC\_XVENDOR=symplicity

- 1. Synthesize the design in Synplify / Synplify Pro.
- 2. Implement the design in the Xilinx implementation tools.

- After Translate (NGDBuild) has completed, "Logical Cross Probing" can be done.
- After Place-and-Route (PAR) has completed, "Timing Cross Probing" can be done.

### **Logical Cross Probing**

To cross probe from the Error Viewer to Synplify, do the following:

- 1. Open the design project in Synplify / Synplify Pro.
- 2. OPTIONAL: Select HDL Analyst  $\rightarrow$  RTL and select the hierarchical or flattened view.
- 3. Select HDL Analyst  $\rightarrow$  Technology and select the hierarchical or flattened view.
- Select HDL Analyst → External Cross Probing Engaged. This enables external cross probing.
- Invoke the Error Viewer from Design Manager, or from the command line as described in Displaying the Navigation Report for Logical Cross Probing, page 1. The error viewer window will show DRC warnings and/or errors from NGDBuild with the net names highlighted as shown in Figure 7.

| 🔮 errnav_ex_ngdbuild.nav - Xilinx Error Viewer 📃 🗖                                                                                                                                  | ×       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>H</u> elp                                                                                                                                 |         |
|                                                                                                                                                                                     |         |
| clock net <u>'wr_n_c'</u> has non-clock connections (WARNING : 477)<br>logical net <u>'GND'</u> has no load (WARNING : 454)<br>logical net <u>'VCC'</u> has no load (WARNING : 454) |         |
| For Help, press F1                                                                                                                                                                  | 11      |
| X406_03                                                                                                                                                                             | _083100 |

Figure 7: Navigation Report from Synplify Synthesized Design

6. Click on a net name in the Error Viewer window. The corresponding net should be highlighted in the Technology View window, as shown in Figure 8, page 7.



Figure 8: Highlighted in the List and the Schematic Window: Net wr\_n\_c

# **Timing Cross Probing**

To cross probe from the Timing Report in Timing Analyzer to Synplify/Synplify Pro, do the following:

- 1. Open the design project in Synplify / Synplify Pro.
- 2. OPTIONAL: Select HDL Analyst  $\rightarrow$  RTL and select the hierarchical or flattened view.
- 3. Select HDL Analyst  $\rightarrow$  Technology and select the hierarchical or flattened view.
- 4. Select HDL Analyst  $\rightarrow$  External Cross Probing Engaged. This enables external cross probing.
- Display the XML file as described in Displaying the Navigable Timing Report for Timing Cross Probing, page 2. The timing report in the Timing Analyzer window will show navigable paths and instances as shown in Figure 9

| Timing constraint:<br>96 items analyzed<br>Minimum allowable | Default OFFSET IN E<br>l, 0 timing errors de<br>e offset is 9.722ns | EFORE analys<br>stected.<br>s. | is for clock "wr_n_c"                                                     |       |
|--------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------|-------|
| Report: 9.722r                                               | ns offset <u>address(2)</u>                                         | before <u>wr n</u>             |                                                                           | -<br> |
| Data path address(                                           | 2) to data hold(9)                                                  | ontains 4 le                   | wels of logic:                                                            |       |
| To                                                           | Delay type                                                          | Delay(ns)                      | Physical Resource<br>Logical Resource(s)                                  |       |
| B2.I                                                         | Tiopi                                                               | 0.989R                         | address(2)<br>address(2).PAD<br>address ibut[2]                           |       |
| CLB_R10C1.S1.G1<br>CLB_R10C1.S1.Y                            | net (fanout=2)<br>Tilo                                              | 3.348R<br>0.738R               | address (2)<br>loop15 data hold 2(15)                                     |       |
| CLB_R6C1.S0.F2<br>CLB_R6C1.S0.X                              | net (fanout=16)<br>Tilo                                             | 2.005R<br>0.738R               | <u>G 53</u><br><u>loop9 data hold 8(9)</u><br>G 63                        |       |
| M2.0<br>M2.CLK                                               | net (fanout=1)<br>Tioock                                            | 1.909R<br>1.292R               | <u>loop9 data hold 8(9)</u><br><u>data hold(9)</u><br><u>data hold[9]</u> |       |
| Total (3.757ns log<br>(34.1% logic                           | gic, 7.262ns route)<br>c, 65.9% route)                              | 11.019ns                       | (to wr_n_c)                                                               |       |
| •                                                            |                                                                     |                                | •                                                                         | C     |

Figure 9: Path Selected to Cross Probe to Synplify Schematic Window

- 6. Click on any path or instance once to enable cross probing for Timing Analyzer.
- 7. Click on the path or instance to cross probe. The corresponding path or instance should be highlighted in the Technology View window, as shown in Figure 10.



Figure 10: Selected Path Highlighted in Synplify Technology View

8. To isolate the schematic to show only the selected path, right click on the Technology View window and select **Filter Schematic**. The filtered path is shown in Figure 11.



Figure 11: Filtered Path in Synplify Technology View

### Locating Nets and Instances in the Schematic View

The following are guidelines on how to locate a net/path/instance in Synplify/Synplify PRO:

1. Most instances/nets/paths can cross probe only to the Technology View.

In Synplify/Synplify Pro, net and instance names are altered in synthesis during technology mapping. This causes the names in the RTL View to differ from the names in the Technology View. On the other hand, Xilinx's Implementation tools get the net/instance names from the EDIF netlist which are identical to the names in the Technology View. Since the logical and timing cross probing work only when the names matches; often time, it is not possible to cross probe from NAV file or XML file to the RTL View.

2. Locating GND and  $V_{CC}$  nets.

When Synplify/Synplify Pro instantiates GND and V<sub>CC</sub> components, technology view will show "0" and "1" connected to these component, respectively. However, in the EDIF netlist, the nets connected to GND and V<sub>CC</sub> components are named "GND" and "V<sub>CC</sub>". Because of this naming mismatch ("0" vs. "GND" and "1" vs. "V<sub>CC</sub>"), warnings related to "GND" and "V<sub>CC</sub>" nets can not be cross probed to the Technology View. An example of such warnings are:

Logical net 'GND' has no load (WARNING: 454) Logical net 'VCC' has no load (WARNING: 454)

- 3. If y the corresponding net cannot be located from the NAV file or path/instance from the XML file in the Technology View schematic, click on the "+" sign next to "Net" and scroll down to see if any net is highlighted. If there is a highlighted net, search for the net in other sheets. If no net is highlighted, proceed to the Troubleshooting section below.
- 4. To view only the components connected by the selected net, right click on the schematic window and select **Select Net Instances**. Right click again and select **Filter Schematic**.
- 5. To cross probe from Technology View to HDL source code, double click on an instance that drives or is driven by the net. The HDL editor window will open and highlight the code that produced the logic.
- 6. The user can also cross probe from the HDL source code to the RTL View. Highlight the corresponding process in the HDL editor and click on the RTL View window. The

corresponding components will be highlighted. If the user clicks on the Technology View window, the corresponding components should be highlighted as well.

### Troubleshooting

When the navigation report (NAV) file or the navigable timing report (XML) file does not cross probe to Synplify / Synplify Pro, there is usually a communication failure between the two applications.

The Error Viewer will prompt the following warning when the communication failed:

```
WARNING: InterToolCommunication: 14 - In trying to start the Synplicity Cross Probing system, the following was returned:
```

```
"couldn't open socket: connection refused"
```

```
Synplicity Cross Probing will not be enabled.
```

The Timing Analyzer will show the same message in its console window. To view the console window, click on View  $\rightarrow$  Console, then mark the "Show Command Status" checkbox.

The following section describes possible causes and troubleshooting steps when the Error Viewer fails to communicate with Synplify / Synplify Pro.

#### **Incorrect Setup Sequence**

When using external cross probing, Synplify / Synplify Pro sets itself up to be the server. This requires that the Synplify / Synplify Pro schematic viewer be opened and the **External Cross Probing Engaged** enabled before the Error Viewer or the Timing Analyzer window is opened. If this sequence is altered, communication between the two applications will not occur. To correct this, simply exit from the Error Viewer or Timing Analyzer window. Make sure the Synplify / Synplify Pro schematic viewer is opened and the External Cross Probing Engaged option is checked. Then, reopen the NAV file in the Error Viewer for logical cross probing or the XML file in Timing Analyzer for timing cross probing.

#### **Conflict on the Port Used for Cross Probing**

The environment variables XIL\_ITC\_XVENDOR\_PORT and XPROBE\_PORTID are used to control the cross probing port between the Error Viewer and Synplify / Synplify Pro. These two variables should be set to the same number. When XIL\_ITC\_XVENDOR is set to "synplicity", the default value of the variables is "8000". Leave this variable at the default value unless there is a conflict.

The connection may be refused because the port is being used by another application, such as a license server. The two variables can be set to use another port. To correct this, close Synplify / Synplify Pro and the Error Viewer, then set the two variables to use another port. Once the port environment variables are reset, reopen both applications.

See the following two examples for resetting the port connection:

#### UNIX Platform:

Type the following commands at the command prompt:

setenv XIL\_ITC\_XVENDOR\_PORT <port\_number>

setenv XPROBE\_PORTID <port\_number>

#### **PC Platform:**

Set the following **autoexec.bat** or system environment setting area. Reboot the PC if using Windows98.

set XIL\_ITC\_XVENDOR\_PORT=<port\_number>

set XPROBE\_PORTID=<port\_number>

The *<port\_number>* is any available TCP/IP port on the local system. A valid port number is a four or five digit integer ranging from 1700 to 65000. Examples of valid values are "8000", "3465", and "15999".

#### Xprobe\_server Not Terminated Properly

When enabling external cross probing, Synplify/Synplify Pro launches a process called "xprobe\_server". Occassionally, this process is not terminated properly upon exiting Synplify/Synplify Pro. As a result, the next attempt of external cross probing will not work, although there was no warning about communication failure. To correct this, terminate or kill the old "xprobe\_server" process as follows:

#### **UNIX Platform:**

- Type "ps" or "top". See whether "xprobe\_server" is listed as running process.
- Note the PID number.
- Type the following commands at the command prompt to kill the process:

kill -9 <xprobe\_server's PID#>

#### **PC Platform:**

- Press Ctrl-Alt-Del
- Select Xprobe\_server task
- Click "End Task"

After terminating the "xprobe\_server" process, repeat cross probing sequence from the start.

# Cross Probing with Leonardo-Spectrum

This section describes setting up sequence, guidelines, and troubleshooting procedure for cross probing between Xilinx and LeonardoSpectrum schematic viewer.

### Setup

The following describes the settings needed to do cross probing with LeonardoSpectrum:

1. The environment variable XIL\_ITC\_XVENDOR must be set to "exemplar". There is no default value for this variable. Setting this variable to "exemplar" specifies that LeonardoSpectrum is the target of the navigation report messages from the error viewer application.

To set the environment variables, do the following:

#### **UNIX Platform:**

Type the following command at the command prompt:

setenv XIL\_ITC\_XVENDOR exemplar

### PC Platform:

Set the following in the **autoexec.bat** or system environment setting area and reboot the PC if using Windows98.

#### set XIL\_ITC\_XVENDOR=exemplar

- 2. Synthesize the design in LeonardoSpectrum.
- 3. Set the TCL variable comm\_socket, which is used to control the TCP/IP port in Exemplar. This variable must be set to "16000" in LeonardoSpectrum.

To set comm\_socket, enter the following at the LeonardoSpectrum TCL command line:

set comm\_socket 16000

**Note:** If using LeonardoSpectrum level 1 or level 2, create a text file with .tcl extension and type the command above into the file (TCL script). To run the TCL script, click **File**  $\rightarrow$  **Run Script...,** select the TCL script, and click **Open**. This will set the comm\_socket variable.

The **comm\_socket** setting will be saved in the LeonardoSpectrum project (LSP) file when the project is saved. The value will be restored when the project is reopened.

To unset **comm\_socket**, enter the following:

unset comm\_socket 16000

To check **comm\_socket** value, enter the following:

puts \$comm\_socket

- 4. Save the design project, File  $\rightarrow$  Save Project As.
- 5. Implement the design in the Xilinx implementation tools.

After Translate (NGDBuild) has completed, "Logical Cross Probing" can be done.

After Place-and-Route (PAR) has completed, "Timing Cross Probing" can be done.

**Note:** With LeonardoSpectrum, only logical cross probing or timing cross probing can be done, but not both at one time.

#### Logical Cross Probing

To cross probe from the Error Viewer to LeonardoSpectrum, do the following:

 Invoke the Error Viewer from Design Manager or from the command prompt as described in **Displaying the Navigation Report for Logical Cross Probing**, page 1. The Error Viewer window will show DRC warnings and/or errors from NGDBuild with the net names highlighted, as shown in Figure 12.

| 🕐 e          | rrnav        | _ex_n         | gdbuild.nav - Xilinx Error Viewer           | _ 🗆 🗵         |
|--------------|--------------|---------------|---------------------------------------------|---------------|
| <u>F</u> ile | <u>E</u> dit | ⊻iew          | <u>H</u> elp                                |               |
| õ            |              | ł             | <u>?</u>                                    |               |
| þlo          | ock r        | net <u>'w</u> | r n int' has non-clock connections (WARNING | : 477)        |
| Ľ            |              |               |                                             |               |
|              |              |               |                                             |               |
|              |              |               |                                             |               |
|              |              |               |                                             |               |
|              |              |               |                                             |               |
|              |              |               |                                             |               |
|              |              |               |                                             | X406 05 08310 |

Figure 12: Navigation Report from LeonardoSpectrum Synthesized Design

- 2. Open the design project (LSP) file in LeonardoSpectrum.
- 3. Make sure the TCL variable comm\_socket is set. See "Setup" section.
- Select Tools → Connect to External Tool. The following message appears if the connection was successful:

xmplr\_send\_msg \$xmplr\_socket "Connected to LeonardoSpectrum"

If the connection failed, the following message will appear:

couldn't open socket: connection refused

See Troubleshooting, page 16, if the socket fails to open and no connection is made.

5. OPTIONAL: Select Tools  $\rightarrow$  View RTL Schematic.

- 6. Select **Tools**  $\rightarrow$  **View Gate Level Schematic**.
- 7. Click on a net in the Error Viewer window. The corresponding net should be highlighted in the Gate Level Schematic window as shown in Figure 13, page 13.



Figure 13: Highlighted in the Schematic Window: Net wr\_n\_int

# **Timing Cross Probing**

To cross probe from the Timing Report in Timing Analyzer to LeonardoSpectrum, do the following:

 Display the XML file as described in Displaying the Navigable Timing Report for Timing Cross Probing, page 2. The timing report in the Timing Analyzer window will show navigable paths and instances as shown in Figure 2

| Timing constraint:<br>96 items analyzed<br>Minimum allowable | OFFSET = IN 10 nS<br>1, 15 timing errors o<br>e offset is 14.685ns                   | BEFORE COMP<br>letected.<br>s.                          | "wr_n" ;                                         | ▲<br>_ |
|--------------------------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------|--------|
| Slack: -4.685ns<br>3.040ns<br>10.000ns                       | s path <u>address(0)</u> to<br>s delay constraint wi<br>s offset <u>address(0)</u> 1 | <u>data hold(2)</u><br>r_n to data_ho<br>to <u>wr n</u> | relative to<br>old(2) and                        |        |
| Data path address(                                           | (0) to data hold(2)                                                                  | contains 4 lev                                          | vels of logic:                                   |        |
| Path starting from<br>To                                     | n Comp: P21.PAD<br>Delay type                                                        | Delay(ns)                                               | Physical Resource<br>Logical Resource(s)         |        |
| P21.I1                                                       | Tpid                                                                                 | 1.560R                                                  | address(0)<br>IPAD address(0)<br>address(0) ibuf |        |
| CLB_R14C8.F1<br>CLB_R14C8.X                                  | net (fanout=2)<br>Tilo                                                               | 4.040R<br>1.590R                                        | address(0) int<br><u>ld data</u><br>ix267        |        |
| CLB_R14C16.G2<br>CLB_R14C16.Y                                | net (fanout=15)<br>Tilo                                                              | 4.747R<br>1.590R                                        | <u>ld data</u><br><u>nx93</u><br>ix281           |        |
| P99.0<br>P99.0K                                              | net (fanout=1)<br>Took                                                               | 3.788R<br>0.410R                                        | nx99<br>data hold(2)<br>req data hold(2)         |        |
| Total (5.150ns log<br>(29.1% logic                           | gic, 12.575ns route)<br>c, 70.9% route)                                              | 17.725ns                                                | (to wr_n_int)                                    | •      |

Figure 14: Path Selected to Cross Probe to LeonardoSpectrum Schematic Window

- 2. Click on a path or an instance once. This will enable cross probing for Timing Analyzer.
- 3. Open the design project (LSP) file in LeonardoSpectrum.
- 4. Make sure the TCL variable comm\_socket is set. See "Setup" section.
- 5. Select **Tools**  $\rightarrow$  **Connect to External Tool**. The following message appears if the connection was successful:

xmplr\_send\_msg \$xmplr\_socket "Connected to LeonardoSpectrum"

If the connection failed, the following message will appear:

couldn't open socket: connection refused

See **Troubleshooting**, page 16, if the socket fails to open and no connection is made.

- 6. OPTIONAL: Select Tools  $\rightarrow$  View RTL Schematic.
- 7. Select Tools  $\rightarrow$  View Gate Level Schematic.
- Click on a path or an instance in the timing report to cross probe. he corresponding net should be highlighted in the Gate Level Schematic window as shown in Figure 13, page 13. See the Locating Nets and Instances in the Schematic View section if the path is not highlited.



Figure 15: Selected Path Highlighted in LeonardoSpectrum Gate Level Schematic

9. To isolate the schematic to show only the selected path, right click on the **Gate Level View** window and select **View Trace Schematic**. The filtered path is shown in Figure 11.



Figure 16: Filtered Path in LeonardoSpectrum Gate Level Schematic

# Locating Nets and Instances in the Schematic View

The following are guidelines on how to locate a net/path/instance in LeonardoSpectrum:

- 1. Make sure LeonardoSpectrum version 2000.1b and later is used. The earlier version of LeonardoSpectrum can not communicate the information needed to do timing cross probing with Xilinx.
- 2. Most instances/nets/paths can cross probe only to the Gate Level Schematic.

In LeonardoSpectrum, net and instance names are altered in synthesis during technology mapping. This causes the names in the RTL Schematic to differ from the names in the Gate Level Schematic. On the other hand, Xilinx Implementation tools get the net/instance names from the EDIF netlist which are identical to the names in the Gate Level Schematic. Since the logical and timing cross probing work only when the names matches; often time, it is not possible to cross probe from a NAV file or an XML file to the RTL Schematic.

- Cross probe from the Gate Level Schematic to HDL source code by right clicking on a component that drives or is driven by the net, and select Trace to HDL Source. The HDL Editor window displays. The code that produced the logic will be highlighted.
- 4. To view only the components connected by the selected net, right click on the Gate Level Schematic window and select **View Trace Schematic**

### Troubleshooting

When the navigation report (NAV) file or the navigable timing report (XML) file does not cross probe to LeonardoSpectrum, there is usually a communication failure between the two applications.

#### **Incorrect Setup Sequence**

The following message appears in the LeonardoSpectrum information window:

Attempting to connect to host: 127.0.0.1 on port:16000 couldn't open socket: connection refused

When connecting to the external tool, LeonardoSpectrum expects the external tool to be the server. This requires the external tool, in this case the Error Viewer or Timing Analyzer to initialize the cross probing before **Connect to External Tool** is enabled. See **Logical Cross Probing** or **Timing Cross Probing** section for the correct sequence. If the sequence is altered, the communication between the two applications will not occur.

To correct this for logical cross probing, do the following:

- 1. Close and reopen the Error Viewer.
- 2. Select the **Tools**  $\rightarrow$  **Reconnect to External** tool from the LeonardoSpectrum menu.
- 3. Continue from Step 5 of Logical Cross Probing section.

To correct this for **timing cross probing**, do the following:

- 1. Close and reopen the Timing Analyzer.
- 2. Open the XML file in the Timing Analyzer window
- 3. Click on a path/instance to initialize timing cross probing.
- 4. Select the **Tools** → **Reconnect to External** tool from the LeonardoSpectrum menu.
- 5. Continue from Step 6 of Timing Cross Probing section.

#### Comm\_socket Is Not Set

The following message appear in LeonardoSpectrum information window:

```
xmplr_socket_init
can't read "comm socket": no such variable
```

The environment variable XIL\_ITC\_XVENDOR\_PORT and TCL command set comm\_socket are used to control the cross probing port between the Error Viewer and LeonardoSpectrum. These variables and commands should be set to the same number. When XIL\_ITC\_XVENDOR is set to "exemplar", the default value of XIL\_ITC\_XVENDOR\_PORT is "16000". However, there is no default value for comm\_socket. To correct this, set the comm\_socket as described in Setup section.

#### **Conflict on the Port Used for Cross Probing**

The connection may be refused because the default port "16000" is being used by other application, such as a license server. XIL\_ITC\_XVENDOR\_PORT and comm\_socket can be st to another port.

To correct this, do the following:

- 1. Close the Error Viewer or Timing Analyzer window.
- 2. Set **XIL\_ITC\_XVENDOR\_PORT** to use another port:

#### **UNIX Platform:**

Type the following command at the command prompt:

#### setenv XIL\_ITC\_XVENDOR\_PORT <port\_number>

PC Platform:

Set the following in **autoexec.bat** or the system environment setting area and reboot PC if using Windows98.

set XIL\_ITC\_XVENDOR\_PORT=<port\_number>

The *<port\_number>* is any available TCP/IP port on the local system. A valid port number is a four or five digit integer ranging from 1700 to 65000. Examples of valid values are "8000", "3465", and "15999".

 Follow the sequence in the Logical Cross Probing or Timing Cross Probing section, but set comm\_socket to match XIL\_ITC\_XVENDOR\_PORT in LeonardoSpectrum's TCL prompt:

set comm\_socket <port\_number>

**Known Issues** 

Below is the list of the current known issues for the Error Viewer.

- 1. When the cursor is pointing to the highlighted net in the Error Viewer, it does not change to a link selector cursor.
- 2. After clicking the highlighted net in the Error Viewer, the highlight does not change color to indicate that it has been selected.
- 3. Using an environment variable to control the Error Navigation setting is inconvenient for Windows98 platform users. A switch or UCF control will be added in a future software release.

New known issues will be logged in the Xilinx Answer Database accessible from <u>http://support.xilinx.com.</u> Cross probing related issues can be searched using "cross probing" keywords.

# Revision History

The following table shows the revision history for this document.

| Date     | Version | Revision                                                  |  |  |
|----------|---------|-----------------------------------------------------------|--|--|
| 09/01/00 | 1.0     | Initial Xilinx release.                                   |  |  |
| 12/01/00 | 2.0     | Title changed, includes logical and timing cross probing. |  |  |