



# Verdi Fundamental Training

*Based on Verdi 2010.01*

# SpringSoft Notifications

## Copyright

© 2009 SpringSoft, Inc. All rights reserved.

No part of this training may be reproduced in any form or by any means without written permission of SpringSoft, Inc.

## Trademarks

The product names used in this document are the trademarks or registered trademarks of their respective owners.

## Confidentiality

The information in this document is confidential and is covered by a license agreement between SpringSoft and your organization. Distribution and disclosure are restricted.

# Goals



- To help you understand complex designs more easily.
- To help you trace back to the root cause quickly when finding bugs.
- To do debugging and verification in one unified and friendly environment.

# Target Audience

- Architecture engineer
- Development engineer
- Verification engineer

# Prerequisites



- Basic HDL/HVL coding skills: Verilog, VHDL, SystemVerilog, SVA.
- Familiarity with standard simulators.

# Overview

- Technology Background
- Set Up the Environment
- Understand FSDB Dumping Tasks and Utilities
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM view
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Glossary

---

- RMB = Right Mouse Button
- MMB = Middle Mouse Button
- LMB = Left Mouse Button
- DC = Double-click
- D&D = Drag and Drop
- KDB = Knowledge Database
- FSDB = Fast Signal Database
- TFV = Temporal Flow View
- BA = Behavior Analysis

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Technology Background

## *Debug in the Design Flow*



Do you know how much time your teams spend debugging?

What else could you be doing with that time?



# Barriers to Efficient Debug

- Complex Designs

- Understanding is more difficult
- Complex behavior
  - Complex design cause and effect scenarios
  - Increases conditions to be verified
- Complex multi-tool, multi-team environments
  - Compounds methodology complexity

# Novas Solves the Tough Debug Issues

## Issues

Complex Environments

Complex Behavior

Complex Designs

*Increasing automation*

*Powerful comprehension and debug*



# Novas Technology



Comprehensive Debug System - More Than Simple Visualization

# Structural / Event Debug Process

Current process involves comparing events, code and structure across multiple windows to track possible issues

- Time consuming, error prone, complicated



# Automating Debug Critical Productivity Enhancement

Utilizing behavior based debug to automate time consuming aspects of debug process

- Time and structure in single view
  - Immediate visual of design behavior
- Automated cause / affect tracing
  - Understand problem areas quickly
  - Cuts your debug time over traditional methods



*EDN Magazine  
Innovation Award 2002  
Finalist*

# Topics

---

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Set Up the Environment*

- After completing this section, you should be able to...
  - Set up the Environment Before Running
    - Specify the Path and Environment Variables
      - Binary, License, Symbol Libraries
    - Use the Setup File – novas.rc
  - Specify Preferences
  - Understand FSDB Dumping Tasks and Utilities
    - Fast Signal Data Base (FSDB) Introduction
    - Link Novas Object Files for FSDB Dumping with Simulators
    - FSDB Utilities

# Specify the Path and Environment Variables

- Binary File

- `setenv NOVAS_INST_DIR <Path to Novas installation>`
- `set path = ($NOVAS_INST_DIR/bin $path)`

- License File

- `setenv NOVAS_LICENSE_FILE <license_file>:$NOVAS_LICENSE_FILE`
- Or alternatively use `LM_LICENSE_FILE`
  - The search priority will be lower than `NOVAS_LICENSE_FILE`

# Symbol Libraries Background

- Why use symbol libraries?
  - Provides mapping between source code and logic cell.
- Without the symbol mappings
  - Active fan-in cone, fan-in cone and fan-out cone schematics will **NOT** function properly.
  - Schematics will show **ONLY** squares instead of logic cells.

Unmapped  
fan-in cone



Mapped  
fan-in cone



# Using Symbol Libraries

- Create a symbol library using one of the following methods:
  - **syn2SymDB**: For Synopsys logical library file in ACSII format (.lib).
  - **map2SymDB**: For the prepared map file.
  - Check the document **Library Developer's Guide** from <verdi\_install>/doc/Symbol\_Library.pdf for detailed format.
- Set the symbol library environment variables

```
setenv NOVAS_LIBS "<LIB ROOT#1> <LIB ROOT#2> ..."  
setenv NOVAS_LIBPATHS "<Directory#1> <Directory#2> ..."
```
- Set the symbol library through the GUI.
  - Invoke **Tools → Preferences** command to open *Preferences* form.
  - Select the folder **Schematics → Symbol Library**.
  - Input the symbol library name in **Symbol Library Names** field.
  - Input the path in **Symbol Library Paths** field.
  - The setting will be saved into the *novas.rc* resource file.

# Use Setup File – novas.rc

- Contains:
  - Mapping information for pre-compiled designs.
    - Map a library logical name to a physical location
    - Mapping format
  - User preferences (set via **Tools → Preferences**).
- Specify path...
  - Using NOVAS\_RC environment variable.  
`setenv NOVAS_RC <path>/novas.rc`
  - Directly by -rcFile <filename> on the command line.
- Search Sequence
  1. -rcFile <filename> command line option (read/write pointer)
  2. NOVAS\_RC environment variable (read/write pointer)
  3. ./novas.rc
  4. \$HOME/novas.rc
  5. <Verdi install>/etc/novas.rc

# Specify Preferences

## Overview

- Open *Preferences* form by invoking **Tools → Preferences** from any window.
  - Changes to the form are saved in the *novas.rc* resource file.
  - Search for keywords in the **Find** field.



- Refer to the Appendix for Frequently Used Preferences.

# Fast Signal Data Base (FSDB)

## *Introduction*

- Compact binary file format which contains the simulation signal data.
- Open file format so other vendor tools can dump data, e.g. Verisity, Vera, Ikos, etc.
- Use system tasks for both VHDL and Verilog to dump values during simulation.

# Fast Signal Data Base (FSDB)

## Frequently Used System Tasks

- **fsdbDumpfile** - Specify FSDB file name, limit the FSDB file size
  - Uses the sliding window scheme to keep the last signal values in the FSDB file, and drops the old values if file size exceeds the limitation.
- **fsdbDumpvars** - Dump signal value changes of specified instances and depth.
  - Can also specify the FSDB file name, different FSDB file names can be specified in each fsdbDumpvars command.
- **fsdbDumpon/ fsdbDumpoff** - Turn on/off FSDB dumping.
  - Can specify FSDB file name to turn on/off specific FSDB file.
- **fsdbSwitchDumpFile** - Switch dumping to another FSDB file.
- **fsdbAutoSwitchDumpfile** - Limit FSDB file size and switch dumping to new FSDB file automatically.

**NOTE 1:** The above tasks are for VHDL simulators, add “\$” in the prefix for Verilog simulators.

**NOTE 2:** For more system tasks, refer to *Linking Novas Files with Simulators and Enabling FSDB Dumping* (<NOVAS\_INST\_DIR>/doc/linking\_dumping.pdf).

# Link Novas Object File for FSDB Dumping

- Setup tool environment variables:
  - setenv LM\_LICENSE\_FILE <simulator\_license\_file>
  - <Simulator>\_INST\_DIR
  - NOVAS\_INST\_DIR
  - Use LD\_LIBRARY\_PATH to specify the appropriate shared object files, and common library located in \${NOVAS\_INST\_DIR}/share/PLI/lib
    - setenv LD\_LIBRARY\_PATH  
\${NOVAS\_INST\_DIR}/share/PLI/<simulator>/<platform>:  
\${NOVAS\_INST\_DIR}/share/PLI/**lib**/<platform>
    - Supported simulators: **VCS / IUS / MODELSIM**
- Create working library and compile designs for simulation.
- Run and call FSDB dump functions on the simulator command prompt.

**NOTE:** For more simulator linking details, refer to the  
<NOVAS\_INST\_DIR>/doc/linking\_dumping.pdf file.

# FSDB Utilities

## *Process FSDB Files in Batch*

- **vfast**
  - Convert VCD files to FSDB files.
- **fsdb2vcd**
  - Convert FSDB files to VCD files.
- **fsdbextract**
  - Extract signals, scopes, time periods from existing FSDB files without re-simulating.
- **fsdbmerge**
  - Merge several FSDB files into one.
- **fsdbreport**
  - Generates a report of value changes for specified signals.

**NOTE:** Use <utility> -h for a list of all options or see the *Verdi Command Reference* for more information.

**NOTE:** Refer to the *Utilities* chapter of the *Verdi Command Reference* for the complete utility list.

# Summary

- In this section, you have learned...
  - How to set up the environment before running Verdi.
  - How to specify preferences.
  - How to understand FSDB dumping tasks and utilities.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Import Design*

- After completing this section, you should be able to...
  - Import Design on Command Line
    - From File
    - From Library
    - By Replaying a TCL Command File
  - Import Design from GUI
    - From File
    - From Library

# Import Design on Command Line

## From File

***verdi [Verdi options] [<your Verilog options>]***

- Reference source files on the command line (Verilog only).
- Verdi takes all the Verilog command line options.

***% verdi -f <file\_list> +define+GETTHEMOSTOUTOFTIME***

***% verdi <source\_file1> <source\_file2>...***

- Where file\_list is a file that contains the Verilog source files and any command line switches.

***% verdi -ssv -v lib.v +libext+.v -ssy -y /src/abc -y /src/def top.v***

- Where -ssv and -ssy are needed only once for design modules specified with the -v and -y and top.v is the design file.

# Import Design on Command Line

## *From Library*

- Compile once, load many times.
  - Saves load time and overall memory.
  - Necessary for mixed language or VHDL designs; optional for Verilog only language designs.
  - Pre-compile design into library: *vericom* for Verilog code, *vhdlcom* for VHDL code.
    - *vericom -lib <libName> block1.v block2.v block3.v*
    - *vhdlcom -lib <libName> block1.vhd block2.vhd block3.vhd*
  - Then import the compiled libraries and specify the top module.
    - *verdi -lib <libName> -top TopBlock*
- For example:
- *verdi -lib work -top system*

# Import Design on Command Line

## By Replaying a TCL Command File

- Every TCL command executed in Verdi has an equivalent TCL command saved in the ./verdiLog/verdi.cmd file.
  - This file may be copied and modified to automate frequent commands.
  - The new file may then be replayed on the Verdi command line using:  
**% verdi –play <file>.cmd**
- Example for how to modify a verdi.cmd file:



```
Terminal
Window Edit Options Help
SrcSourceCodeView
srcResizeWindow 106 60 813 825
debImport "-sv" "-f" "run.f" -autoalias
debLoadSimResult \
    /verdi/home/allen_shieh/DAC/demo_package_2007/Demo2007/novas.fsdb
wwCreateWindow
wwResizeWindow -win $_nWave2 30 202 960 332
wwResizeWindow -win $_nWave2 36 231 960 332
srcHBSel ect "tb_CPUsystem.i_CPU.i_CCU" -win $nTrace1
srcSetScope -win $nTrace1 "tb_CPUsystem.i_CPU.i_CCU" -delim "."
srcHBSel ect "tb_CPUsystem.i_CPU.i_PCU" -win $nTrace1
srcSetScope -win $nTrace1 "tb_CPUsystem.i_CPU.i_PCU" -delim "."
srcToggleFolder -win $nTrace1 -expand -line 78
srcSetOptions -win $nTrace1 -annotate on
srcSetOptions -win $nTrace1
debExit
```

Modify the path for run.f file if you  
didn't replay the file in the same path

Remove the last line before  
executing Verdi –play verdi.cmd

# Import Design from GUI

## From File

- Enter **verdi** on command line to launch Verdi.
- Use **File → Import Design** or **Import Design** icon  to import your design.
  - Select **From File** tab.
  - Specify language.
  - Specify run file or individual source files.
  - Supports mapping file to set a Virtual Top.
    - Refer to *Verdi Application Training* for the details of Virtual Top.
- Not recommended for VHDL.



# Import Design from GUI

## From Library

- Enter **verdi** on command line to launch Verdi.
- Use **File → Import Design** or **Import Design** icon  to import your design.
  - Select **From Library** tab.
  - Specify the library and the top module.
  - Supports mapping file to set a Virtual Top.
    - Refer to *Verdi Application Training* for the details of Virtual Top.



# Summary

- ➊ In this section, you have learned...
  - How to import designs on the command line
    - From file
    - From library
    - By replaying a TCL command file
  - How to import designs from the GUI
    - From file
    - From library

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Debug in Source Code View*

- After completing this section, you should be able to...
  - Open *nTrace* Window
  - Search and Collapse Hierarchy Browser
  - Traverse the Source Code
    - Find Operations
    - Use Bookmarks
    - Collapse Source Code
    - Tip to Show Implicit Port
    - Double-Click Module to Show All Instances
  - Operate on Signals
    - Trace Signals – Driver, Load, Connectivity, Fan-in, Fan-out
    - Enable Active Annotation
    - Perform Active Trace
  - Correlate Other Views

# Open *nTrace* Window

- After importing the design, Verdi invokes the *nTrace* Window automatically.  
% verdi -f run.f
- The *nTrace* window contains three re-sizeable sub-windows:



# Search and Collapse Hierarchy Browser

## Collapse All Scopes

- In the *hierarchy browser pane*, click the Right Mouse Button (RMB) to select the **Collapse All Scopes** command.
  - Collapses all open scopes.



# Search and Collapse Hierarchy Browser

## Search Scopes

- In the hierarchy browser pane, invoke **RMB** → **Show Navigation Editbox** to turn on the *Navigation Box*.
  - Search Scopes:
    - Type a wildcard string in the *Navigation Box*, and press **Enter**.
    - The hierarchy browser jumps to the first matched scope, click on **Next Node** icon to jump to the next match.
    - For example, type **CH\*** in the *Navigation Box*, **CHILD1**, **CHILD2**, and **CHILD3** will be matched.
  - Filter Scopes:
    - Type a wildcard string in the *Node Filter* field, only matched scopes will be shown



# Traverse Source Code

## *Find Operations (1/2)*

- Source → Find Signal/Instance/Instport is a fast way to find signals, instances, or instance ports in full design or selected scope.



- Find String on toolbar quickly locates a string in current scope.



# Traverse Source Code

## *Find Operations (2/2)*

- **Source → Find Scope** is a fast way to directly open a Verilog module or VHDL architecture if the design tree is deep.
  - Select scopes to list related instances.
  - Multiple selection is allowed.
    - Applies to Module/File/Function/Task types in **Scope Type** field.
    - The complete **Instance List** can be saved by clicking the **Save** button.
  - Only single selection is allowed in **Instance List** since it affects the **Go To** button.



# Traverse Source Code

## Use Bookmarks

- Add bookmarks:
  - Click on **Bookmark** icon on toolbar 
  - **Ctrl-F2** to toggle a bookmark on/off at the current line.
  - Supports unlimited bookmarks.
- Use **Source → Manage Bookmarks → Edit** command to get list of current bookmarks.
  - Enter strings in the **Name** field to name your bookmarks



```
:nTraceMain;1> system.i_cpu.i_ALUB ALUB (verilog/ALUB.v)
File Exploration View Source Trace Tools Window Help
system(blk)
  child1 (fsm_child1)
  child2 (fsm_child2)
  child3 (fsm_child3)
  i_cpu (CPU)
    i_ALUB (ALUB)
      3 primitives
        i_alu (arithlogic(a
          1_LCU (CCU)
            i_PCU (pcu(pcu))
              -- Loading package body functions.
```



# Traverse Source Code

## Collapse Source Code

- Collapse source code at user-specified lines.
- Enable **Automatic Source Code Folding** option on the **Source Code → Miscellaneous** page of the *Preferences* form.
  - Specify the number of levels to collapse.
- Use **View → Source Code Folder** or click the mark "+" or "-" to expand or collect the folded source code.



A screenshot of the Verdi interface showing collapsed source code lines. A tooltip says 'Click to collapse'. A circled line number 96 is highlighted with a red box, indicating it will be marked as red when collapsed. Another tooltip says 'Collapsed line number will be marked as red'.

```
<Verdi:nTraceMain:1> system.i_cpu.i_CCU CCU (CCU.v)
File Exploration View Source Trace Tools Window
system
  CHILD1 (fsm_child1)
  CHILD2
  CHILD3
  MASTEF _Hierarchy Tree by Level
    i_cpu (CPU)
      i_ALUB (ALUB)
        3 primitives
        i_alu (alu)
      i_CCU (CCU)
        2 lib cells2 primitives
        i_PCU (PCU)
      i_pram (pram)
    reg      inready, firstDataInRdy;
    wire    En_A, En_B, En_C, En_D;
    wire [1:0] Mux1_Sel, Mux2_Sel;
    wire    En_AB,En_AC,En_AD,En_BC,En_BD,En_CD;
    wire [1:0] Mux3_Sel;
    wire    FirstDataOutRdy;
    wire    StartFSM1, StartFSM2, StartFSM3;
  end
  and (n_C21, reset, C21) ;
  always @(n_C21 or n_C20 or MAP or next_MA)
    case ({n_C21, n_C20})
      0: MA = 8'h00;
      1: MA = MAP;
      2: MA = 8'h00;
      default: MA = next_MA;
    endcase
  // Incrementor for memory address
  always @(negedge clock or negedge reset)
    begin
      if (~reset)
    end
source file "alu.v"
```

# Traverse Source Code

## *Expand Implicit Port Instantiations in Tip*

- In the source code pane, put cursor on the implicit port (\*.).
  - A tip window opens to show the detailed port instantiations.
  - Supported in SystemVerilog designs.



The screenshot shows a Verilog source code editor window. The code is as follows:

```
1 begin
2   B = "A";
3 end
4
5 test m1 (*.);
6
7 endmodule
8 (.A(A),.C(C),.B(B),.D(D),
9 .E(E),.microrom(microrom),.maprom(maprom))
10
11 module test(input A,C,B,D,E,microrom,maprom);
12 logic A,B,E;
13 ALU_OP C;
14 MPROM_ENCODE D;
15 reg [21:0] microrom [255:0];
16
17 endmodule
```

A red arrow points to the implicit port instantiation `(\*.)` at line 5. A yellow box highlights the expanded port list at line 8, which includes `(.A(A),.C(C),.B(B),.D(D),.E(E),.microrom(microrom),.maprom(maprom))`.

# Traverse Source Code

*Double-click a Module Name to List all Instances*

- Double-click on a module name in the source code pane.
  - All instances will be listed in the message pane.
  - Double-click a line in the message pane to jump to the expected instance.

The screenshot shows the Verdi IDE interface. The title bar reads "Verdi <VerdinTraceMain:1> system.i\_cpul CPU (cpu.v)". The menu bar includes File, Exploration, View, Source, Trace, Tools, and Window. The toolbar has various icons for file operations. The left pane shows a hierarchical tree of modules: system, i\_cpul (CPU), i\_ALUB (ALUB), i\_CCU (CCU), i\_PCU (PCU), i\_cpul (CPU), i\_cpul (CPU), i\_cpul (CPU), and i\_pram (pram). A red arrow points from the text "Double Click" to the module name "CPU" in the source code pane. The source code pane contains the following Verilog code:

```
1 module CPU (clock, reset, VMA, R_W, data, addr);
2   inout [1:0] data;
3   output [7:0] addr;
4   input clock, reset;
5   output VMA, R_W;
6   wire S1, \IRE[0], \CHE[2], \alu_mode[1], \mux_sel[1], \VALU[6], \PC[2],
7   \TDB[2], \IRE[6], \VALU[2], \IXR[2], \bus_mode[1], \VALU[0],
8   \IXR[0], \PC[6], \PC[4], \TDB[6], \TDB[4], \CHE[4], \IRE[1],
9   \PC[1], \PC[0], \VALU[4], \IXR[4], C6, \TDB[0], \CHE[0],
10  carry_mode, \VALU[5], \IXR[5], error, \TDB[1], \CHE[1], \VALU[1],
11  \mux_sel[2], \PC[5], \alu_mode[2], \TDB[5], \bus_mode[2],
12  \IXR[1], \VALU[3], \bus_mode[0], \IXR[3], \PC[7], \TDB[7],
13  \alu_mode[0], \VALU[7], \IXR[7], \mux_sel[0], \PC[3], \TDB[3],
14  \CHE[3], C5;
```

The message pane at the bottom shows the output of the command "Instances of Module CPU":

```
1> Instances of Module CPU
system,v(33): CPU i_cpul(clock,reset,VMA,R_W,data,addr);
system,v(34): CPU i_cpul2(clock,reset,VMA,R_W,data,addr);
system,v(35): CPU i_cpul3(clock,reset,VMA,R_W,data,addr);
system,v(36): CPU i_cpul4(clock,reset,VMA,R_W,data,addr);
<Total: 4 Instance(s)>
```

A red box highlights the first four lines of the message pane, which correspond to the four instances of the CPU module listed in the tree view.

# Operate on Signals

## Trace Driver and Loads

- To quickly find all the **drivers** of a signal:
  - DC a signal.
  - Select signal and click on *Trace Driver* icon.
  - **Trace → Driver** or Right Mouse Button menu.
- To quickly find all the **loads** of a signal:
  - Select signal and click on *Trace Load* icon.
  - **Trace → Load** or Right Mouse Button menu.
- To quickly find all the **drivers and loads** of a signal:
  - **Trace → Connectivity** or Right Mouse Button menu.
  - Dropping a signal in the source window will trace the connectivity of the signal.
- By default, tracing will cross hierarchical boundaries.
  - Disable **Trace → Trace across Hierarchy** to keep within a hierarchy.



# Operate on Signals

# *Trace Results Report*

- **Trace → Save Trace Results** saves Driver/Load/Connectivity in a file for future review.
  - Record maximum 32 level trace results.

The screenshot shows the ModelSim interface with the following details:

- File Menu:** File, Exploration, View, Source, Trace, Tools, Window, Help.
- Toolbar:** Includes icons for simulation control (Run, Stop, Step), waveform, memory dump, and file operations.
- Hierarchy Tree:** Shows the structure of the design:
  - cpu (CPU)
  - |\_ L\_ALUB (ALUB)
    - |\_ 3 primitives
    - |\_ i\_alu (arithk)
  - |\_ L\_CCU (CCU)
  - |\_ L\_PCU (pcu\_pc)
  - |\_ i\_pram (pram2(pram))
- Trace List:** A list of trace items with their types and counts:
  - <DL> vhdl/system\_state.vhd(121): , dout => data (2 driver pass-through(s), 2 load pass-through)
  - <DL> verilog/TopModule.v(62): , .data(data)
  - system.i\_cpu : 1 driver pass-through(s), 1 load pass-through
  - \*<DL> vhdl/pram\_mixed.vhd(80): dout <= mem(to\_natural(addr)); (2 driver(s), 1 load(s))
  - \*<DL> vhdl/pram\_mixed.vhd(84): mem(to\_natural(addr)) := dout;
  - \*<DL> vhdl/pram\_mixed.vhd(89): dout <= (others => 'Z');
  - \*system.i\_pram : 2 driver(s), 1 load(s)
  - \*<DL> vhdl/PCU\_record.vhd(98): data <= (others => 'Z');
  - \*<DL> vhdl/PCU\_record.vhd(100): data <= n\_q0;
  - \*<DL> vhdl/PCU\_record.vhd(160): process (C1, pcu\_dout.one\_bit, data)
  - \*<DL> vhdl/PCU\_record.vhd(166): pcu\_din.eight\_bit <= data;
  - \*system.i\_cpu.i\_PCU : 2 driver(s), 2 load(s)
  - \*Total : 4 driver(s), 3 load(s), 3 driver pass-th



# Operate on Signals

## Trace Fan-in and Fan-out

- Select a signal in the source code pane and invoke the command **Trace → Fan-in or Trace → Fan-out** command.
  - Traces fan-in or fan-out registers.
  - Jumps to the first trace result in the source code pane.
  - Lists all traced results in the message pane
    - Jump to a different trace result in the source code pane by double-clicking in the message pane.



# Operate on Signals

## Enable Active Annotation

- Use the **File → Load Simulation Results** command to load FSDB file.
- Enable **Source → Active Annotation** (or hot key x) in nTrace.
  - Display simulation results on source.
  - Signal values/transitions are synchronized with cursor time.
  - Select signal(s) and go to next or previous transitions.
    - *Any Change, Rising or Falling*



# Operate on Signals

## Perform Active Trace

- Locate the active driver for a specific signal.
- Select one signal and invoke **RMB → Active Trace** or **Ctrl-t**.
  - The driving statement at the cursor time will be displayed.

The screenshot shows the Verdi IDE interface. On the left, there is a hierarchical project tree with nodes like i\_Busource, i\_CPUsystem, i\_CPU, i\_ALUB, i\_alu, i\_CCU, i\_PCU, and i\_pram. The main area displays VHDL code:

```
41 always @(select or a or b or cin)
42     ADD      55 55 0
43     begin
44     #1 case (select)
45         ADD:      {carry,out} = a + b + cin;
46             0      aa 55 55 0
47         SUB:      {carry,out} = a - b - 8'b1 + cin;
48             0      aa 55 55 0
49         SUB1:     {carry,out} = b - a - 8'b1 + cin;
50             0      aa 55 55 0
51         AND_OP:   {carry,out} = a & b;
52             0      aa 55 55
53         NOR_NP:   {carry,out} = a | b;
54             0      aa 55 55
55         XNOR_XP:  {carry,out} = a ^ b;
56             0      aa 55 55
57         XOR_XP:   {carry,out} = a ^^ b;
58             0      aa 55 55
59     end
60
61     if (!RESET)
62         1
63         AluBuf = 0;
64     else
65         AluBuf = #1 AluOut;
66             3      55->aa
67     end
68
69 end
```



# Correlate Other Views

## *nTrace to nSchema*

- Select object(s) (e.g. instance, signal, ...) in *nTrace*.
- D&D selected object(s) into *nSchema* to highlight it.



# Correlate Other Views

## *nTrace to nWave*

- Select object in *nTrace* Source Code Pane or Hierarchy Browser Pane, D&D to *nWave*
  - D&D signals will add signals into *nWave*.
  - D&D instances will add all I/O signals of that instance into *nWave*.



# Summary

- ➊ In this section, you have learned...
  - How to create *nTrace* window
  - How to search and collapse hierarchy browser
  - How to traverse the source code
  - How to operate on signals
  - How to correlate other views

# Lab

---

- Refer to the *Verdi User's Guide and Tutorial* document in <Verdi\_install>/doc/tutorial.pdf.
- Follow the steps in *nTrace Tutorial* chapter to practice the lab.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- **Debug in Waveform View**
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Debug in Waveform View*

- After completing this section, you should be able to...
  - Open *nWave* Window
  - Load Simulation Results
  - Add Signals
  - Organize and Operate on Signals
    - Group Operations
    - Bus Operation
    - Add Comments
    - Search for Values
    - Show Driver and Load Signals
    - Save and Restore Signals
  - Manipulate Waveform Display
    - Set Markers
    - Waveform Alias
    - Display Glitches
    - Event Sequences
    - Count Events
    - Display Grid
    - Select Stuck Signals
    - Sort Signals by Transition

# Open nWave Window

- In *nTrace*, invoke **Tools → New Waveform** or click on the **New Waveform** icon 
- On the Verdi command line, use the option **-ssf <filename>.fsdb**  
% verdi -f run.f -ssf gate.fsdb



# Load Simulation Results

- In *nWave*, use **File → Open** or toolbar icon  to load results.

- Load VCD files generated by `$dumpvars`.
  - VCD files are automatically converted to FSDB at load time.
  - gzipped VCD files are supported.
    - Supports file naming rules as “xxx.*vcd.gz*” or “xxx.*dump.gz*” only.
- Load FSDB Files generated by `$fsdbdumpvars`.
- Select one or more files to **Add** and open in the same waveform window.
  - Use **File → Set Active** to specify which file is active.
- Open several files in different *nWave* windows.
  - Use **Window → Change to Primary** to specify which window is active.



# Add Signals

## Get Signals from nWave

- Use Signal → Get Signals or toolbar icon 
- Directly from bus based on user-defined rules.
- Option to find signals in full scope.
- Option to display signals in order of selection not alphabetical.
- Signal type filter.

Use wildcard \* ,? to get all matched signals.



# Add Signals

## *Add Signals from Other Windows*

- D&D signals/instances from other windows to *nWave*.
  - All instance I/O.
  - Selected signal(s).
  - Signals in text region.
  - Schematic hierarchical blocks or logic gates
- Select signals and use **RMB → Add Signal(s) To Wave** in *nTrace*.
- Select objects and use **RMB → Add Select Set To Wave** in *nSchema*.
- After executing a trace command in *nSchema*, use **Trace → Add Result to Wave**.

# Organize Signals

## Create Group for Signals

- Select a group in signal window :
  - RMB → Group Operations → Add Group to add groups
  - RMB → Rename to modify the group name
- RMB → Go To <select group name> jumps to specified group.
- Expand / collapse group members by double-clicking.



# Organize Signals

## Group Operations

- Invoke **RMB** → **Group Operations** → **Insert Subgroup** to create sub-groups of selected groups
- Each group/sub-group can be renamed with **RMB** → **Rename**
- Invoke **View** → **Group Manager** to open the *Group Manager* form
  - Select a group in *Group Manager* form and click **New Subgroup** to add a new group under the selected group.
  - Click the **Move To** button to move the selected group/signals in *nWave* into the selected group in the *Group Manager*
  - Delete the selected group and subgroups



# Operate on Signals

## Create and Edit Buses

- Invoke **Signal → Edit Bus** or **RMB → Bus Operations → Edit Bus** in signal pane to edit selected bus.



- Create bus from selected signals.
  - Invoke **Signal → Create Bus** or **RMB → Bus Operations → Create Bus** in signal pane.
  - Add Logic 0 or Logic 1 as place holders.

# Operate on Signals

## Expand Buses

- Expand / Collapse bus by double-clicking.
- Select a bus in the *nWave* signal pane and invoke RMB → **Bus Operation** → **Expand Sub-bus** to open *Expand Bus* form.
  - Specify number of bits to divide the bus by.
  - Choose to display from LSB or MSB.



# Operate on Signals

## Add Comments to Signals

- Use **Signal → Comment → Insert** to insert a comment field at cursor position.
- Use **Signal → Comment → Add Square Box** or other sub-commands to add different types of comment boxes
  - Four comment box types are provided: **Square Box**, **Attached Square Box**, **Period Box** and **Arrow Period Box**.



# Operate on Signals

## Search for Values

- Use **Waveform → Set Search Value** to search signal values.
  - Search value accepts mnemonics, wild cards and transitions



- Use **Waveform → Set Search Constraint** to constrain search to a duration of time (set to  $\leq 0$  for glitches) or nth occurrence of a condition.



# Operate on Signals

## Show Driver and Load Signals

- Select a signal in *nWave* signal pane, invoke **RMB → Show Driver Signals** or **Show Load Signals** commands to trace driver or load.
  - Driver/load signals will be added in signal pane.
  - All pass through signals will be ignored.
  - The command is only valid when the design is also imported – not valid in standalone *nWave*.



# Operate on Signals

## Save and Restore Signals

- Use **File → Save Signal** to save all signals to a loadable file
  - Click **Option** button to specify signals attributes
  - Note: turn on **Do Not Save Bit Range of Natural Bus** option when debugging parameterized designs (with the same signal name but different bus range)



- In *nWave*, use **File → Restore Signal** to load the saved file
- On the command line, use **-sswr <file>.rc** to restore.

**NOTE:** If there is a FSDB file open in *nWave*, the **Restore Signal** command will not overwrite the loaded simulation results.

# Manipulate Waveform Display

## Set Markers

- Use **Waveform → Marker** to name and place markers.
- Multiple markers supported, markers can be saved and restored.
- Specify name, color, and line style for labels to differentiate markers.



# Manipulate Waveform Display

## Waveform Alias (1/3)

- Use **-autoalias** option on Verdi command line for automatic mnemonic recognition for 'defines and parameters.

```
% verdi -f run.f -autoalias
```

- Use **aliasextract** to extract an alias file from a compiled library. Default is extracted.alias.

```
% vericom -f run.f -lib work
```

```
% aliasextract -lib work
```

- Use **-aliasFile** option on Verdi command line to load an alias file.

```
% verdi -top system -aliasFile extracted.alias
```

# Manipulate Waveform Display

## Waveform Alias (2/3)

- Use **Waveform → Signal Value Radix → Edit Alias** to create/update an alias file and apply to a signal.
  - Apply color to any alias.
- Create a copy of a signal and use RMB in value column to **Remove Local Alias**.



# Manipulate Waveform Display

## Waveform Alias (3/3)

- Supports up to 20 aliases in a list.
  - Select **More Alias** in the first level to see the second level aliases
  - Select **More Alias** in the second level will bring up **Alias Editor**.
    - No number limitation in this form.



# Manipulate Waveform Display

## Display Glitches

- Use View → Display Glitch to identify glitch location.



- Use Waveform → Set Search Constraint to search for glitch events.
  - Set Value of <Search By> is stable for to  $\leq$  and enter 0 in the time field.

**NOTE:** Simulation results file must be generated with the following environment variable set::

```
setenv NOVAS_FSDB_ENV_MAX_GLITCH_NUM 0
```

# Manipulate Waveform Display

## *Event Sequence*

- Use **Tools → Event Sequence** to display order of events on selected signals in a single time step.
  - Sync time with cursor.
  - Drag and drop additional signals as needed.
  - Switch display between waveform and grid mode.



**NOTE:** Simulation results file must be generated with the following environment variable set:  
***setenv NOVAS\_FSDB\_ENV\_DUMP\_SEQ\_NUM on***

# Manipulate Waveform Display

## Count Events

- To get the statistics of event status during one time period.
  - Total number of Rising / Falling / Value changes
- In nWave, select signals and invoke **View → Signal Event Report**.
  - Specify the time range or enable the **Sync Delta** option.

| Signal Name                 | Signal Type | Rising# | Falling# | VCO# |        |
|-----------------------------|-------------|---------|----------|------|--------|
| /system/i_cpu/addr[7:0]     | Vod Wire    | 0       | 0        | 7    |        |
| /system/i_cpu/alu_mode[2:0] | Vod Wire    | 0       | 0        | 2    |        |
| /system/i_cpu/bus_mode[2:0] | Vod Wire    | 0       | 0        | 5    |        |
| /system/i_cpu/carry_mode    | Vod Wire    | 3       | 2        | 5    | Delete |

# Manipulate Waveform Display

## Display Grid

- In *nWave*, use **View → Grid Options** to open the *Grid Options* form.
  - Add grids based on the rising/falling edges of the selected signal.
  - Add grids based on user defined cycle in a specific time range.
  - Count number for grids.
    - Can specify starting number.
    - Counting will start on the first grid after the current cursor time.



# Manipulate Waveform Display

## Select Stuck Signals

- Use Left Mouse Button/Middle Mouse Button to set **Cursor/Marker** time respectively.
- Invoke the **Signal → Select → Stuck Signals with Cursor/Marker** command.
  - Signals with no transition within Cursor/Marker time will be selected.
  - User can press Delete key to remove these selected signals.



# Manipulate Waveform Display

## *Sort Signals by Transition*

- Select a Signal Group in *nWave*, invoke **View → Sort Signals by First Transition** command to sort signals based on the first transition.
  - The initial unknown value will be ignored.



# Summary

- In this section, you have learned...
  - How to open *nWave*
  - How to load simulation results
  - How to organize and operate on signals
  - How to manipulate the waveform display

# Lab

---

- Refer to the *Verdi User's Guide and Tutorial* document in <Verdi\_install>/doc/tutorial.pdf.
- Follow the steps in the *nWave Tutorial* chapter to practice the lab.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- **Debug in Schematic View**
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Debug in Schematic View*

- After completing this section, you should be able to...
  - Open *nSchema*
    - Create Different Schematic Window Types
  - Correlate Other Views
  - Manipulate Viewing
    - Enable Detail RTL – Window or Instance
    - Hide Extraneous Buses
    - Colorize Hierarchies
  - Trace Signals
    - Fan-in/Fan-out/Two Points/Two Signals

## Open *nSchema*

- Select an instance in the *nTrace* hierarchy browser and click on **New Schematic** icon. 
- **D&D** an instance from the hierarchy browser or a Verilog module or VHDL architecture from the *nTrace* source code pane to **New Schematic** icon. 
- Execute **Tools → New Schematic → Current Scope** in *nTrace*.

# Open nSchema

## Different Schematic Window Types

- **Full Hierarchical Window** – Shows complete objects in specific scope. Default schematic view.
- **Browser Window** – Shows partial schematic in specific scope.
- **Flatten Window** – Shows partial schematic in flatten view, i.e. schematics cross all scopes.



**Full Hierarchical Window**

**Browser Window**

**Flatten  
Window**

# Open nSchema

## Full Hierarchical Window

- View, traverse and understand design hierarchy graphically.
- **DC** a symbol port to push into the lower level and highlight the associated net.
- **DC** on a net to highlight all instances which connect to it.
- Trace commands will highlight a variety of different objects in current window.
- Search commands:
  - **Schematic → Find Signal/Instance/Instport.**
  - **Schematic → Find In Current Scope.**



# Open nSchema

## Browser Window

- Focus on specified instances or nets for debugging.



- DC on symbol port to push in, pop up or expand logic.
- Use Delete key or  to remove object(s).
- Undo / redo edits.
- No trace commands in this view.

# Open nSchema

## Flatten Window

- Focus on a specified primitive or net for debugging.



- DC on instance pin or D&D from other windows to add objects.
- Use <Delete> or

# Open nSchema

## *View Detail Source Code for RTL Blocks*

- DC on a bottom level RTL Block to show its corresponding source code.



## Correlate Other Views

## *Drag & Drop between nSchema and Other Windows*

- Select objects (instance, signal, ...) in *nTrace*.
  - D&D selected objects into *nSchema* to highlight them.



# Manipulate Viewing

## *Miscellaneous Viewing Commands*

- **View → Preselect**
  - Highlight signals/blocks when the cursor moves over them.
- **View → InstPort Name**
  - Turn on/off port names of instances.
- **View → IO Port Name, Instance Name, Net Name**
  - Turn on/off pin, instance, local net names.
- **View → High Contrast**
  - Display all schematic in dark blue except the selected objects which are highlighted in white.
- **Tools → Preferences → Schematics → Display Options → Viewing**
  - Change default viewing attributes when opening new *nSchema* windows.

# Manipulate Viewing

*View Detail RTL on a Window Basis*

- Invoke **View → Detail RTL** to show Boolean equivalent of function symbols.
  - Effective in the current window only.



# Manipulate Viewing

## *View Detail RTL on Instance Basis*

- On RTL block, invoke RMB → **Display Detail RTL Block**.
  - New window with details will open.



# Manipulate Viewing

## *Hide Extraneous Bus in Flatten Window*

- Remove extraneous bus connections to display a cleaner schematic for bus signals.
  - Enable **Tools → Options → Hide Extraneous Bus**.
  - This option is only available in flattened schematic windows.



# Manipulate Viewing

## *Colorize Different Hierarchies in Flatten Window*

- Enable **Automatically Color Instances in Flatten Window** option on the **Schematics → Display Options → Schematic** folder of the **Preferences** form (invoked with **Tools → Preferences**).
- In flatten schematic window, invoke **Schematic → Color Instances by Scope** to change default scope colors.



# Trace Signals

## Trace Fan-in Cone / Fan-out Cone

- Invoke Tools → New Schematic → Fan-in Cone / Fan-out Cone
  - Generate new schematic window to show all the fan-in or fan-out logic.
  - Trace net to register / tri-state output or design boundary.
- Fan-In Cone** 
  - Shows all the logic affecting the selected net.
  - Useful to trace drivers in depth to find the cause of error.
- Fan-Out Cone**
  - Shows all the loading logic.
  - Useful to see global signal distribution (e.g. clock, reset, etc.).
- Trace fan-in/out more then one level.
  - Specify the level number in the **Fan-In/Out Level** field on the **Trace** page under the **Schematics** folder of the *Preferences* form (invoked with Tools → Preferences).



# Trace Signals

*Expand the schematic*

- Double-click on the instance pin to expand one level
  - The hierarchical connector will be added if tracing through hierarchies



# Trace Signals

## Trace Load/Driver/Connectivity

- Select a pin, invoke **Trace → Driver/Load/Connectivity** to trace one level



# Trace Signals

## Trace for Fan-out

- Select an instance or pin, invoke **Trace → Fan-out Cone**
  - Trace to storage elements
  - Useful to see global signal distribution (e.g. clock, reset, etc.).
  - Specify the level number in the **Fan-In/Out Level** field on **Schematics** → **Trace** folder of the *Preferences* form (invoked with **Tools → Preferences**).



# Trace Signals

## Trace for Fan-in

- Select an instance or pin, invoke **Trace → Fan-in Cone**
  - Trace to storage elements
  - Useful to trace drivers in depth to find the cause of error.
  - Specify the trace level in the *Preferences* form



# Trace Signals

## Trace by Level

- Select an instance or pin, invoke **Trace → By Level**
  - Specify the Trace Mode (e.g. Driver, Load, Fan-in...etc)
  - Specify Level and other constrains



# Trace Signals

## Trace All Paths Between Two Points (1/2)

- Invoke **Trace → Two Points** and select **Instance Port Based** option to trace between ports.
  - Specify start/end points by entering the port names or D&D from *nSchema* or *nTrace*.
  - Options to stop or pass through Flip Flops.
  - Filters to pass/bypass specific components.



Specify Bypass/Pass components.



Create a new schematic for result

# Trace Signals

## *Trace All Paths Between Two Points (2/2)*



# Trace Signals

## Trace All Paths Between Two Signals

- In *Trace Two Points* form, select **Signal Based** option in **Choose Trace Mode** section.
  - Drag and drop signals from *nSchema* (or other views) to **From** and **To** fields.
  - Enable **Filter** option and then click **Filter** button to set pass/bypass signals.
- Trace paths between signals will also show the instances which are connected to the signal in *nSchema*.



# Trace Signals

## *Limit Tracing Scope for Performance*

- In *Trace Two Points* form, enable **Filter** option and click **Filter** button.
- In *Trace Two Points Filter* form, select **Limited Scope** option and then select from the following options to limit tracing in specific scopes.
  - **Limit Trace to Paths in Lowest Scope Level:** Automatically set the lowest scope based on your two points/signals.
    - For example, when tracing from signal **A.B.C.D.in** to **A.B.E.F.out**, Verdi will only trace paths under **A.B** and its sub-scopes.
  - **Limit Trace to Paths in Scope:** Specify a scope to limit the trace to.
    - For when you want to focus on a specific scope.



# Summary

- In this section, you have learned...
  - How to create different schematic windows.
  - How to manipulate viewing.
  - How to trace signals.
  - How to correlate other views.

# Lab

---

- Refer to the *Verdi User's Guide and Tutorial* document in <Verdi\_install>/doc/tutorial.pdf.
- Follow the steps in the *nSchema Tutorial* chapter to practice the lab.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- **Debug in FSM View**
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Objectives

## *Debug in FSM View*

- After completing this section, you should be able to...
  - Open the *nState* Window
  - Manipulate FSM View
    - View Actions & Find States
    - Display FSM Properties
    - Create Partial FSM
    - Use State Animation
  - Analyze State Machines
  - Correlate Other Views

# Open *nState*

- DC on the state symbol to invoke *nState*.



- Verdi automatically identifies FSM code for 1-process, 2-process, or 3-process with conventional encoding of the state variables.

**NOTE:** Remember to enable **FSM Recognition** option on the **RTL** page under the **Schematics** folder of the *Preferences* form (invoked with **Tools → Preferences**) otherwise not all FSM will be extracted.

# Manipulate FSM View

## *View Actions & Find States*

- View → State Action
- View → Transition Condition
- View → Transition Action
- FSM → Find State



# Manipulate FSM View

## Display FSM Properties

- Invoke **FSM → Machine Properties** to access the FSM properties.
- Invoke **FSM → Object Properties** to access state and transition properties.



# Manipulate FSM View

## Create Partial FSM

- Select states in *nState* and invoke window from **Tools → Partial FSM**.
- Expand adjacent states.
  - DC on states.
  - Select a state and invoke **RMB → Expand**.
- D&D to the partial FSM window to add states.



# Manipulate FSM View

## *State Animation (1/2)*

- Load simulation results.
- Enable **FSM → State Animation**.
- Use **Previous State / Next State** toolbar icons to step through the states.
- Use **FSM → Edit Search Sequence** to create a sequence of states to search on.

# Manipulate FSM View

## State Animation (2/2)



# Analyze State Machines

- Use **FSM → Analysis Report** to display analysis report.
  - Details of FSM interpretation.
  - State coverage report.
  - Transition coverage report.
- **Save to File** to save the report.



# Correlate Other Views

- D&D the state or junction into *nTrace*.



The screenshot shows the nTrace tool interface. The title bar reads "<Debussy>nTrace:1> system.MASTER fsm\_master (master.v)". The menu bar includes File, View, Source, Trace, Tools, Window, and Help. A toolbar below has icons for file operations. A status bar says "Selected: (6) ST9 First". The left pane shows a tree view of source files: system, CHILD1 (fsm\_child1), CHILD2 (fsm\_child2), CHILD3 (fsm\_child3), and MASTER (fsm\_master). The right pane is a code editor with the following VHDL-like code:

```
File View Source Trace Tools Window Help
Selected: (6) ST9 First
system
CHILD1 (fsm_child1)
  N FSM1_COMB
  N FSM1_SEQ
CHILD2 (fsm_child2)
  N FSM2_COMB
  N FSM2_SEQ
CHILD3 (fsm_child3)
  N FSM3_COMB
  N FSM3_SEQ
MASTER (fsm_master)
  N MASTER_FSM_COM
  N MASTER_FSM_SEQ
Selected: (6) ST9 First
else
  NextStateMasterFSM = ST0;
end
ST7 : NextStateMasterFSM = ST8;
ST8 : begin
  StartFSM2 = 1;
  NextStateMasterFSM = ST9;
end
ST9 : begin
  if (FirstDataInRdy)
    begin
      StartFSM1 = 1;
      NextStateMasterFSM = ST10;
    end
  else
    NextStateMasterFSM = ST12;
end
ST10 : begin
  StartFSM3 = 1;
  FirstDataOutRdy = 1;
  NextStateMasterFSM = ST11;
end
ST11 : begin
  StartFSM2 = 1;
  NextStateMasterFSM = ST9;
end
source file "child1.v"
source file "child2.v"
source file "child3.v"
source file "master.v"
source file "system.v"
Linking... 0 error(s), 0 warning(s)
Total 0 error(s), 0 warning(s)
```

A large blue arrow points from the "ST9" state in the Debussy diagram to the "ST9" state in the nTrace code editor.

# Summary

- In this section, you have learned...
  - How to open the state machine window.
  - How to manipulate the view and find states.
  - How to display FSM properties and analyze the FSM.
  - How to create a partial FSM.
  - How to use state animation.
  - How to correlate other views.

# Lab

---

- Refer to the *Verdi User's Guide and Tutorial* document in <Verdi\_install>/doc/tutorial.pdf.
- Follow the steps in the *nState Tutorial* chapter to practice the lab.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- **Debug in Temporal Flow View**
- Appendix: Frequently Used Preferences

# Objectives

## *Debug in Temporal Flow View*

- After completing this section, you should be able to...
  - Understand what is Temporal Flow View
  - Open a Temporal Flow View (TFV) Window
    - Cycle Based
    - Transition Based
  - Operate in the TFV
  - Correlate Other Views

# What is Temporal Flow View?

## Behavior Analysis Engine

- From the KDB & FSDB, Verdi builds an internal model of actual design behavior using synthesis & formal technology
  - Unroll function over time
  - Differentiate data from control signals
- Uses simulation results
  - Determine clocking
  - Prune inactive elements



# What is Temporal Flow View?

## Automatic Cause & Effect Tracing

- Complete, easy to use environment
- Easy visualization of behavior with time and structure



# What is Temporal Flow View?

## *Key Applications of Temporal Flow View Debugging*

- Understand design behavior and locate the **root cause of a wrong value**
- **Trace memory content NOT in FSDB and locate memory write**



- Locate the root cause of **unknown (X) values**
- **Locate the cause of different results between two simulation runs**



# Open a Temporal Flow View Window

- In *nWave* or *nTrace*, select a signal and invoke RMB → **Create Temporal Flow View**
  - Specify tracing by cycle or transition.
  - Trace incrementally – *Default* and *Recommended*.
    - If **Disable Incremental Mode** and **Analyze Specified Scope First** are turned on, specify the working scope, the time and the signal to trace. Analysis will be completed for everything under working scope.



# Open a Temporal Flow View Window

## Cycle Based

- Structure and time in single view.
- Dynamic analysis finds the active path when tracing.
- Each structure corresponds to one statement.



# Open a Temporal Flow View Window

## Transition Based

-  distinguishes transition based tracing from cycle-based tracing in the Temporal Flow View.



# Operate in the TFV

## Trace This Value

- Use **Trace → Trace This Value** to automatically trace back the data path.
- Use **View → Active Data Nodes Only** or **View → Active Nodes Only** to simplify the view and display active nodes only.
- DC to perform Active Trace.



# Operate in the TFV

## Show Marker for Control with Transition

- Show the output nodes with transition in the tracing path.
  - Enable the **Display Marker for Control with Transition** option on **Temporal Flow View → View → Display** folder of the *Preferences* form (invoked with **Tools → Preferences**).
  - A yellow exclamation point is placed over output nodes.



# Correlate Other Views

## Automatically Display Source Code

- Enable Show Source Code Automatically icon  or use View → Show Source Code Automatically to view corresponding source code for a selected node.



The screenshot shows the Verdi TraceText view window. The title bar reads '<Verdi:nTraceText:10> system.i\_cpu.i\_ALUB ALUB (CPU.v)'. The menu bar includes File, View, Source, Trace, Window, and Help. The toolbar contains icons for back, forward, search, and other functions. The main area displays assembly-like source code. Line 639 is highlighted in blue and shows the instruction 'ND2 U250 (.A(CH[0]), .B(n737), .Z(61) );'. The status bar at the bottom says 'Selected: system.i\_cpu.i\_ALUB.S1#550'.

```
633 IV U244 (.A(bus_mode[2]), .Z(n735) );
634 AN3P U245 (.A(n780), .B(n775), .C(n777), .Z(n782) );
635 AN3P U246 (.A(n780), .B(n777), .C(bus_mode[1]), .Z(n779) );
636 AN3P U247 (.A(n775), .B(n736), .C(bus_mode[0]), .Z(n778) );
637 AN3P U248 (.A(n777), .B(n736), .C(bus_mode[1]), .Z(n776) );
638 IVP U249 (.A(clock), .Z(n792) );
639 ND2 U250 (.A(CH[0]), .B(n737), .Z(61) );
640 NR2 U251 (.A(n738), .B(n739), .Z(error_out) );
641 ND2 U252 (.A(n740), .B(n741), .Z(\X0[7]) );
642 ND2 U253 (.A(n742), .B(n743), .Z(\X0[6]) );
643 ND2 U254 (.A(n744), .B(n745), .Z(\X0[5]) );
644 ND2 U255 (.A(n746), .B(n747), .Z(\X0[4]) );
645 ND2 U256 (.A(n748), .B(n749), .Z(\X0[3]) );
646 ND2 U257 (.A(n750), .B(n751), .Z(\X0[2]) );
```

# Correlate Other Views

## Show Traced Signals in nWave

- To show traced signals in waveform view:
  - Select a signal.
  - Use **Tools → Show All Traced Signals on nWave**.



# Correlate Other Views

## Show Fan-in Signals in nSchema

- To view a signal's fan-in in nSchema:
  - Select the signal.
  - Use Tools → Show Fan-ins on nSchema → Active Only.



# Summary

- In this section, you have learned...
  - How to create the Temporal Flow View (TFV) window.
  - How to operate in the TFV.
  - How to correlate other views.

# Lab

---

- Refer to the *Verdi User's Guide and Tutorial* document in <Verdi\_install>/doc/tutorial.pdf.
- Follow the steps in the *Temporal Flow View Tutorial* chapter to practice the lab.

# Topics

- Technology Background
- Set Up the Environment
- Import Design
- Debug in Source Code View
- Debug in Waveform View
- Debug in Schematic View
- Debug in FSM View
- Debug in Temporal Flow View
- Appendix: Frequently Used Preferences

# Frequently Used Preferences

## *Enable the TCL Command Entry Form*

- In the *Preferences* form, select the **General** folder in the browser.
  - Toggle on **Enable TCL Command Entry Form** option.
    - Input TCL commands in the Command Entry form.
    - When you do any action in Verdi, all TCL commands will be logged here.



# Frequently Used Preferences

## Source Code Related

- In the *Preferences* form, select the **Source Code** folder in the browser
  - Select pages under the folder, for example **Color**, **Design Tree**, etc., to customize the appearance and fonts for the hierarchy browser and source code panes.



# Frequently Used Preferences

## *Source Code Related – Specify Default Editor*

- In the *Preferences* form, select the **Editor** folder to select your preferred editor which is invoked with the toolbar icon 



# Frequently Used Preferences

## *Source Code Related – Enable Active Trace/Folding Source Code*

- In the *Preferences* form, select the **Miscellaneous** page under the **Source Code** folder.



# Frequently Used Preferences

## Waveform Related

- In the *Preferences* form, select the **Waveform** folder to customize waveform display.
  - **General** page: Display input/output signals in different colors, synchronize file browser, etc.
  - **View Options** folder: Enable highlight signal, radix display, value and signal alignment.
  - **Value System** page: Change appearance based on values and strengths.
  - **Color / Font / Pattern** folder: Change appearance of windows and signal types.
  - **Default Value** folder: Change signal height and file filter.
  - **Extended VCD** page: Change appearance based on values and strengths.



# Frequently Used Preferences

## Waveform Related – Read Value Change on Demand

- In the *Preferences* form, select the **Read Value Change On Demand For Drawing** option on the **General** page under the **Waveform** folder to reduce memory usage by reading only when signal changes value.



# Frequently Used Preferences

## Waveform Related - Partial Display Hierarchical Signal Name

- Turn on the **Hierarchical Name** option and **Partial Display by Level** sub-option on **Waveform → View Options** page of *Preferences* form.
  - Specify the hierarchy level for **Head** and **Tail**.
    - Example: set **Head=1** and **Tail=1**, the signal becomes:  
`/system/.../add_23/A[8:0]`
    - Flexible for user to focus level and avoid long hierarchy names.



# Frequently Used Preferences

## Schematic Related – Customize Color and Font

- In the *Preferences* form, select the **Color/Font** page under the **Schematics** folder to customize the appearance globally.



# Frequently Used Preferences

## Schematic Related – Customize Viewing Attributes

- In the *Preferences* form, select the **Viewing** page under the **Schematics** folder to change viewing attributes in all windows.



# Frequently Used Preferences

## Schematic Related – Partial P&R

- In the **Preferences** form, select the **Schematic** page under the **Schematics** folder, turn on **Partial P&R** for improving the drawing performance
  - Incrementally performing Place & Route. Helpful for huge gate-level netlist



# Frequently Used Preferences

## FSM Related

- In the *Preferences* form, select the **Color** page under the **FSM** folder to customize the appearance globally.

