



# **Actel**

## **User's Manual**

**Version 5.8d**

**Published: 10/Mar/04**

The world's most popular HDL simulator

ModelSim is produced by Model Technology™, a Mentor Graphics Corporation company. Copying, duplication, or other reproduction is prohibited without the written consent of Model Technology.

The information in this manual is subject to change without notice and does not represent a commitment on the part of Model Technology. The program described in this manual is furnished under a license agreement and may not be used or copied except in accordance with the terms of the agreement. The online documentation provided with this product may be printed by the end-user. The number of copies that may be printed is limited to the number of licenses purchased.

ModelSim is a registered trademark and Signal Spy, TraceX, ChaseX, and Model Technology are trademarks of Mentor Graphics Corporation. PostScript is a registered trademark of Adobe Systems Incorporated. UNIX is a registered trademark of AT&T in the USA and other countries. FLEXIm is a trademark of Macrovision, Inc. IBM, AT, and PC are registered trademarks, AIX and RISC System/6000 are trademarks of International Business Machines Corporation. Windows, Microsoft, and MS-DOS are registered trademarks of Microsoft Corporation. OSF/Motif is a trademark of the Open Software Foundation, Inc. in the USA and other countries. SPARC is a registered trademark and SPARCstation is a trademark of SPARC International, Inc. Sun Microsystems is a registered trademark, and Sun, SunOS and OpenWindows are trademarks of Sun Microsystems, Inc. All other trademarks and registered trademarks are the properties of their respective holders.

Copyright © 1990-2004, Model Technology, a Mentor Graphics Corporation company. All rights reserved. Confidential. Online documentation may be printed by licensed customers of Model Technology and Mentor Graphics for internal business purposes only.

### **ModelSim support**

Support for ModelSim is available from your FPGA vendor. See the About ModelSim dialog box (accessed via the Help menu) for contact information.

# Table of Contents

---

## 1 - Introduction (UM-13)

|                                             |       |
|---------------------------------------------|-------|
| <a href="#">ModelSim modes of operation</a> | UM-14 |
| <a href="#">Command-line mode</a>           | UM-14 |
| <a href="#">Batch mode</a>                  | UM-15 |
| <a href="#">Standards supported</a>         | UM-16 |
| <a href="#">Assumptions</a>                 | UM-16 |
| <a href="#">Sections in this document</a>   | UM-17 |
| <a href="#">What is an "Item"</a>           | UM-19 |
| <a href="#">Text conventions</a>            | UM-19 |

## 2 - Projects (UM-21)

|                                                                 |       |
|-----------------------------------------------------------------|-------|
| <a href="#">Introduction</a>                                    | UM-22 |
| <a href="#">Project conversion between versions</a>             | UM-23 |
| <a href="#">Getting started with projects</a>                   | UM-24 |
| <a href="#">Step 1 — Creating a new project</a>                 | UM-24 |
| <a href="#">Step 2 — Adding items to the project</a>            | UM-25 |
| <a href="#">Step 3 — Compiling the files</a>                    | UM-28 |
| <a href="#">Step 4 — Simulating a design</a>                    | UM-29 |
| <a href="#">Other basic project operations</a>                  | UM-29 |
| <a href="#">The Project tab</a>                                 | UM-30 |
| <a href="#">Project tab context menu</a>                        | UM-31 |
| <a href="#">Changing compile order</a>                          | UM-32 |
| <a href="#">Grouping files</a>                                  | UM-33 |
| <a href="#">Creating a Simulation Configuration</a>             | UM-34 |
| <a href="#">Organizing projects with folders</a>                | UM-36 |
| <a href="#">Specifying file properties and project settings</a> | UM-38 |
| <a href="#">Project settings</a>                                | UM-39 |
| <a href="#">Accessing projects from the command line</a>        | UM-41 |

## 3 - Design libraries (UM-43)

|                                                                   |       |
|-------------------------------------------------------------------|-------|
| <a href="#">Design library overview</a>                           | UM-44 |
| <a href="#">Working with design libraries</a>                     | UM-46 |
| <a href="#">Managing library contents</a>                         | UM-47 |
| <a href="#">Assigning a logical name to a design library</a>      | UM-49 |
| <a href="#">Moving a library</a>                                  | UM-50 |
| <a href="#">Setting up libraries for group use</a>                | UM-50 |
| <a href="#">Specifying the resource libraries</a>                 | UM-51 |
| <a href="#">Default binding rules for VHDL resource libraries</a> | UM-51 |
| <a href="#">Predefined libraries</a>                              | UM-52 |

|                                                       |       |
|-------------------------------------------------------|-------|
| Alternate IEEE libraries supplied . . . . .           | UM-52 |
| Regenerating your design libraries . . . . .          | UM-52 |
| Referencing source files with location maps . . . . . | UM-54 |
| Using location mapping . . . . .                      | UM-54 |
| Pathname syntax . . . . .                             | UM-55 |
| How location mapping works . . . . .                  | UM-55 |
| Mapping with Tcl variables . . . . .                  | UM-55 |
| Importing FPGA libraries . . . . .                    | UM-56 |

## 4 - VHDL simulation (UM-57)

|                                                                    |       |
|--------------------------------------------------------------------|-------|
| Compiling VHDL designs . . . . .                                   | UM-59 |
| Invoking the VHDL compiler . . . . .                               | UM-59 |
| Dependency checking . . . . .                                      | UM-59 |
| Range and index checking . . . . .                                 | UM-60 |
| Differences between language versions . . . . .                    | UM-60 |
| Simulating VHDL designs . . . . .                                  | UM-63 |
| Simulator resolution limit . . . . .                               | UM-63 |
| Delta delays . . . . .                                             | UM-64 |
| Syntax for file declaration . . . . .                              | UM-66 |
| Using STD_INPUT and STD_OUTPUT within ModelSim . . . . .           | UM-67 |
| TextIO implementation issues . . . . .                             | UM-68 |
| Reading and writing hexadecimal numbers . . . . .                  | UM-69 |
| Dangling pointers . . . . .                                        | UM-69 |
| The ENDLINE function . . . . .                                     | UM-69 |
| The ENDFILE function . . . . .                                     | UM-69 |
| Using alternative input/output files . . . . .                     | UM-70 |
| Flushing the TEXTIO buffer . . . . .                               | UM-70 |
| Providing stimulus . . . . .                                       | UM-70 |
| VITAL specification and source code . . . . .                      | UM-71 |
| VITAL packages . . . . .                                           | UM-71 |
| ModelSim VITAL compliance . . . . .                                | UM-71 |
| VITAL compliance checking . . . . .                                | UM-71 |
| Compiling and simulating with accelerated VITAL packages . . . . . | UM-72 |
| Util package . . . . .                                             | UM-73 |
| get_resolution . . . . .                                           | UM-73 |
| init_signal_driver() . . . . .                                     | UM-74 |
| init_signal_spy() . . . . .                                        | UM-74 |
| signal_force() . . . . .                                           | UM-74 |
| signal_release() . . . . .                                         | UM-74 |
| to_real() . . . . .                                                | UM-75 |
| to_time() . . . . .                                                | UM-76 |
| Modeling memory . . . . .                                          | UM-77 |
| Affecting performance by cancelling scheduled events . . . . .     | UM-80 |
| Converting an integer into a bit_vector . . . . .                  | UM-81 |

## 5 - Verilog simulation (UM-83)

|                                           |        |
|-------------------------------------------|--------|
| Introduction                              | UM-84  |
| Compilation                               | UM-85  |
| Incremental compilation                   | UM-86  |
| Library usage                             | UM-88  |
| Verilog-XL compatible compiler arguments  | UM-90  |
| Verilog-XL `uselib compiler directive     | UM-91  |
| Verilog configurations                    | UM-92  |
| Simulation                                | UM-93  |
| Simulator resolution limit                | UM-94  |
| Event ordering in Verilog designs         | UM-96  |
| Negative timing check limits              | UM-100 |
| Verilog-XL compatible simulator arguments | UM-103 |
| Delay modes                               | UM-104 |
| System tasks                              | UM-106 |
| IEEE Std 1364 system tasks                | UM-106 |
| Verilog-XL compatible system tasks        | UM-109 |
| ModelSim Verilog system tasks             | UM-111 |
| Compiler directives                       | UM-112 |
| IEEE Std 1364 compiler directives         | UM-112 |
| Verilog-XL compatible compiler directives | UM-113 |

## 6 - Verilog PLI / VPI (UM-115)

|                                                |        |
|------------------------------------------------|--------|
| Introduction                                   | UM-116 |
| Registering PLI applications                   | UM-117 |
| Registering VPI applications                   | UM-119 |
| Compiling and linking PLI/VPI C applications   | UM-121 |
| Compiling and linking PLI/VPI C++ applications | UM-122 |
| Specifying the PLI/VPI file to load            | UM-123 |
| PLI example                                    | UM-124 |
| VPI example                                    | UM-125 |
| The PLI callback reason argument               | UM-126 |
| The sizetf callback function                   | UM-128 |
| PLI object handles                             | UM-129 |
| Third party PLI applications                   | UM-130 |
| Support for VHDL objects                       | UM-131 |
| IEEE Std 1364 ACC routines                     | UM-132 |
| IEEE Std 1364 TF routines                      | UM-134 |
| Verilog-XL compatible routines                 | UM-136 |
| PLI/VPI tracing                                | UM-137 |

## 7 - WLF files (datasets) and virtuals (UM-141)

|                                                                |        |
|----------------------------------------------------------------|--------|
| <a href="#">WLF files (datasets)</a>                           | UM-142 |
| <a href="#">Saving a simulation to a WLF file</a>              | UM-143 |
| <a href="#">Opening datasets</a>                               | UM-144 |
| <a href="#">Viewing dataset structure</a>                      | UM-145 |
| <a href="#">Managing multiple datasets</a>                     | UM-146 |
| <a href="#">Saving at intervals with Dataset Snapshot</a>      | UM-148 |
| <a href="#">Virtual Objects (User-defined buses, and more)</a> | UM-150 |
| <a href="#">Virtual signals</a>                                | UM-150 |
| <a href="#">Virtual functions</a>                              | UM-151 |
| <a href="#">Virtual regions</a>                                | UM-152 |
| <a href="#">Virtual types</a>                                  | UM-152 |
| <a href="#">Dataset, WLF file, and virtual commands</a>        | UM-153 |

## 8 - Graphic interface (UM-155)

|                                                              |        |
|--------------------------------------------------------------|--------|
| <a href="#">Window overview</a>                              | UM-156 |
| <a href="#">Common window features</a>                       | UM-157 |
| <a href="#">Quick access toolbars</a>                        | UM-158 |
| <a href="#">Columnar information display</a>                 | UM-159 |
| <a href="#">Docking and undocking panes</a>                  | UM-159 |
| <a href="#">Drag and drop</a>                                | UM-160 |
| <a href="#">Automatic window updating</a>                    | UM-160 |
| <a href="#">Finding names</a>                                | UM-161 |
| <a href="#">Sorting items</a>                                | UM-161 |
| <a href="#">Saving window layout</a>                         | UM-161 |
| <a href="#">Context menus</a>                                | UM-161 |
| <a href="#">Menu tear off</a>                                | UM-161 |
| <a href="#">Tree window hierarchical view</a>                | UM-162 |
| <a href="#">Main window</a>                                  | UM-163 |
| <a href="#">Workspace</a>                                    | UM-164 |
| <a href="#">Transcript</a>                                   | UM-165 |
| <a href="#">The Main window menu bar</a>                     | UM-166 |
| <a href="#">The Main window status bar</a>                   | UM-170 |
| <a href="#">Mouse and keyboard shortcuts</a>                 | UM-170 |
| <a href="#">Dataflow window</a>                              | UM-171 |
| <a href="#">Items you can view</a>                           | UM-171 |
| <a href="#">Adding items to the window</a>                   | UM-172 |
| <a href="#">Links to other windows</a>                       | UM-172 |
| <a href="#">Dataflow window menu bar</a>                     | UM-173 |
| <a href="#">Exploring the connectivity of your design</a>    | UM-175 |
| <a href="#">Zooming and panning</a>                          | UM-177 |
| <a href="#">Tracing events (causality)</a>                   | UM-178 |
| <a href="#">Tracing the source of an unknown (X)</a>         | UM-179 |
| <a href="#">Finding items by name in the Dataflow window</a> | UM-180 |
| <a href="#">Saving the display</a>                           | UM-181 |
| <a href="#">Configuring page setup</a>                       | UM-183 |

|                                                                   |        |
|-------------------------------------------------------------------|--------|
| Symbol mapping . . . . .                                          | UM-184 |
| Configuring window options . . . . .                              | UM-185 |
| List window . . . . .                                             | UM-187 |
| Items you can view . . . . .                                      | UM-187 |
| Adding items to the List window . . . . .                         | UM-188 |
| The List window menu bar . . . . .                                | UM-189 |
| The List window context menu . . . . .                            | UM-190 |
| Editing and formatting items in the List window . . . . .         | UM-191 |
| Combining items in the List window . . . . .                      | UM-193 |
| Setting List window display properties . . . . .                  | UM-194 |
| Configuring a List trigger with the Expression Builder . . . . .  | UM-197 |
| Sampling signals at a clock change . . . . .                      | UM-197 |
| Finding items by name in the List window . . . . .                | UM-198 |
| Setting time markers in the List window . . . . .                 | UM-199 |
| Saving List window data to a file . . . . .                       | UM-200 |
| List window keyboard shortcuts . . . . .                          | UM-200 |
| Memory window . . . . .                                           | UM-201 |
| Memories you can view . . . . .                                   | UM-201 |
| The Memory window menu bar . . . . .                              | UM-202 |
| Viewing memory contents . . . . .                                 | UM-203 |
| Modifying the memory window display . . . . .                     | UM-204 |
| Navigating to memory locations within a memory instance . . . . . | UM-206 |
| Initializing memories . . . . .                                   | UM-208 |
| Process window . . . . .                                          | UM-213 |
| Understanding process status . . . . .                            | UM-213 |
| Links to other windows . . . . .                                  | UM-213 |
| The Process window menu bar . . . . .                             | UM-214 |
| Signals window . . . . .                                          | UM-215 |
| Items you can view . . . . .                                      | UM-215 |
| The Signals window menu bar . . . . .                             | UM-216 |
| Filtering the signal list . . . . .                               | UM-218 |
| Finding items in the Signals window . . . . .                     | UM-219 |
| Forcing signal and net values . . . . .                           | UM-220 |
| Adding items to the Wave and List windows or a WLF file . . . . . | UM-221 |
| Setting signal breakpoints in HDL designs . . . . .               | UM-222 |
| Defining clock signals in HDL designs . . . . .                   | UM-222 |
| Source window . . . . .                                           | UM-224 |
| The Source window menu bar . . . . .                              | UM-225 |
| Setting file-line breakpoints . . . . .                           | UM-228 |
| Checking item values and descriptions . . . . .                   | UM-228 |
| Finding and replacing in the Source window . . . . .              | UM-228 |
| Setting tab stops in the Source window . . . . .                  | UM-229 |
| Structure window . . . . .                                        | UM-230 |
| Items you can view . . . . .                                      | UM-230 |
| Structure window menu bar . . . . .                               | UM-231 |
| Structure window context menu . . . . .                           | UM-232 |
| Finding items in the Structure window . . . . .                   | UM-232 |
| Variables window . . . . .                                        | UM-233 |

|                                                                |        |
|----------------------------------------------------------------|--------|
| The Variables window menu bar . . . . .                        | UM-234 |
| Finding items in the Variables window . . . . .                | UM-235 |
| Wave window . . . . .                                          | UM-236 |
| Pathname pane . . . . .                                        | UM-236 |
| Value pane . . . . .                                           | UM-237 |
| Waveform pane . . . . .                                        | UM-237 |
| Cursor panes . . . . .                                         | UM-237 |
| Items you can view . . . . .                                   | UM-237 |
| Adding items in the Wave window . . . . .                      | UM-238 |
| Saving the Wave window format . . . . .                        | UM-239 |
| The Wave window menu bar . . . . .                             | UM-239 |
| Using dividers . . . . .                                       | UM-242 |
| Splitting Wave window panes . . . . .                          | UM-243 |
| Combining items in the Wave window . . . . .                   | UM-244 |
| Displaying drivers of the selected waveform . . . . .          | UM-246 |
| Editing and formatting items in the Wave window . . . . .      | UM-246 |
| Setting Wave window display properties . . . . .               | UM-251 |
| Setting signal breakpoints . . . . .                           | UM-253 |
| Finding items by name or value in the Wave window . . . . .    | UM-254 |
| Using time cursors in the Wave window . . . . .                | UM-255 |
| Examining waveform values . . . . .                            | UM-257 |
| Zooming - changing the waveform display range . . . . .        | UM-257 |
| Saving zoom range and scroll position with bookmarks . . . . . | UM-258 |
| Wave window mouse and keyboard shortcuts . . . . .             | UM-260 |
| Saving waveforms . . . . .                                     | UM-260 |
| Compiling with the graphic interface . . . . .                 | UM-265 |
| Locating source errors during compilation . . . . .            | UM-266 |
| Setting default compile options . . . . .                      | UM-267 |
| Simulating with the graphic interface . . . . .                | UM-272 |
| Design tab . . . . .                                           | UM-272 |
| VHDL tab . . . . .                                             | UM-274 |
| Verilog tab . . . . .                                          | UM-276 |
| Libraries tab . . . . .                                        | UM-277 |
| SDF tab . . . . .                                              | UM-278 |
| Options tab . . . . .                                          | UM-280 |
| Setting default simulation options . . . . .                   | UM-281 |
| Creating and managing breakpoints . . . . .                    | UM-284 |
| Signal breakpoints . . . . .                                   | UM-284 |
| File-line breakpoints . . . . .                                | UM-284 |
| Breakpoints dialog . . . . .                                   | UM-285 |
| Miscellaneous tools and add-ons . . . . .                      | UM-288 |
| The GUI Expression Builder . . . . .                           | UM-288 |
| HDL language templates . . . . .                               | UM-290 |

## 9 - Signal Spy (UM-293)

|                              |        |
|------------------------------|--------|
| Introduction . . . . .       | UM-294 |
| init_signal_driver . . . . . | UM-295 |

|                                |        |
|--------------------------------|--------|
| init_signal_spy . . . . .      | UM-298 |
| signal_force . . . . .         | UM-300 |
| signal_release . . . . .       | UM-302 |
| \$init_signal_driver . . . . . | UM-304 |
| \$init_signal_spy . . . . .    | UM-307 |
| \$signal_force . . . . .       | UM-309 |
| \$signal_release . . . . .     | UM-311 |

## 10 - Standard Delay Format (SDF) Timing Annotation (UM-313)

|                                                                      |        |
|----------------------------------------------------------------------|--------|
| Specifying SDF files for simulation . . . . .                        | UM-314 |
| Instance specification . . . . .                                     | UM-314 |
| SDF specification with the GUI . . . . .                             | UM-315 |
| Errors and warnings . . . . .                                        | UM-315 |
| VHDL VITAL SDF . . . . .                                             | UM-316 |
| SDF to VHDL generic matching . . . . .                               | UM-316 |
| Resolving errors . . . . .                                           | UM-317 |
| Verilog SDF . . . . .                                                | UM-318 |
| The \$sdf_annotate system task . . . . .                             | UM-318 |
| SDF to Verilog construct matching . . . . .                          | UM-319 |
| Optional edge specifications . . . . .                               | UM-322 |
| Optional conditions . . . . .                                        | UM-323 |
| Rounded timing values . . . . .                                      | UM-323 |
| SDF for mixed VHDL and Verilog designs . . . . .                     | UM-324 |
| Interconnect delays . . . . .                                        | UM-325 |
| Disabling timing checks . . . . .                                    | UM-325 |
| Troubleshooting . . . . .                                            | UM-326 |
| Mistaking a component or module name for an instance label . . . . . | UM-327 |
| Forgetting to specify the instance . . . . .                         | UM-327 |

## 11 - Value Change Dump (VCD) Files (UM-329)

|                                                                  |        |
|------------------------------------------------------------------|--------|
| Creating a VCD file . . . . .                                    | UM-330 |
| Flow for four-state VCD file . . . . .                           | UM-330 |
| Flow for extended VCD file . . . . .                             | UM-330 |
| Case sensitivity . . . . .                                       | UM-330 |
| Using extended VCD as stimulus . . . . .                         | UM-331 |
| Simulating with input values from a VCD file . . . . .           | UM-331 |
| Replacing instances with output values from a VCD file . . . . . | UM-332 |
| ModelSim VCD commands and VCD tasks . . . . .                    | UM-334 |
| Compressing files with VCD tasks . . . . .                       | UM-335 |
| A VCD file from source to output . . . . .                       | UM-336 |
| VCD simulator commands . . . . .                                 | UM-336 |
| VCD output . . . . .                                             | UM-337 |

|                                                 |        |
|-------------------------------------------------|--------|
| Capturing port driver data . . . . .            | UM-340 |
| Supported TSSI states . . . . .                 | UM-340 |
| Strength values . . . . .                       | UM-341 |
| Port identifier code . . . . .                  | UM-341 |
| Example VCD output from vcd dumpports . . . . . | UM-342 |

## 12 - Tcl and macros (DO files) (UM-345)

|                                                               |        |
|---------------------------------------------------------------|--------|
| Tcl features within ModelSim . . . . .                        | UM-346 |
| Tcl References . . . . .                                      | UM-346 |
| Tcl commands . . . . .                                        | UM-347 |
| Tcl command syntax . . . . .                                  | UM-348 |
| if command syntax . . . . .                                   | UM-350 |
| set command syntax . . . . .                                  | UM-351 |
| Command substitution . . . . .                                | UM-351 |
| Command separator . . . . .                                   | UM-352 |
| Multiple-line commands . . . . .                              | UM-352 |
| Evaluation order . . . . .                                    | UM-352 |
| Tcl relational expression evaluation . . . . .                | UM-352 |
| Variable substitution . . . . .                               | UM-353 |
| System commands . . . . .                                     | UM-353 |
| List processing . . . . .                                     | UM-354 |
| ModelSim Tcl commands . . . . .                               | UM-354 |
| ModelSim Tcl time commands . . . . .                          | UM-355 |
| Conversions . . . . .                                         | UM-355 |
| Relations . . . . .                                           | UM-355 |
| Arithmetic . . . . .                                          | UM-356 |
| Tcl examples . . . . .                                        | UM-357 |
| Macros (DO files) . . . . .                                   | UM-359 |
| Using Parameters with DO files . . . . .                      | UM-359 |
| Making macro parameters optional . . . . .                    | UM-360 |
| Useful commands for handling breakpoints and errors . . . . . | UM-361 |

## A - ModelSim variables (UM-363)

|                                                             |        |
|-------------------------------------------------------------|--------|
| Variable settings report . . . . .                          | UM-364 |
| Personal preferences . . . . .                              | UM-364 |
| Returning to the original ModelSim defaults . . . . .       | UM-365 |
| Environment variables . . . . .                             | UM-365 |
| Creating environment variables in Windows . . . . .         | UM-367 |
| Referencing environment variables within ModelSim . . . . . | UM-368 |
| Removing temp files (VSOUT) . . . . .                       | UM-368 |
| Preference variables located in INI files . . . . .         | UM-369 |
| [Library] library path variables . . . . .                  | UM-369 |
| [vlog] Verilog compiler control variables . . . . .         | UM-370 |
| [vcom] VHDL compiler control variables . . . . .            | UM-370 |

|                                                       |        |
|-------------------------------------------------------|--------|
| [vsim] simulator control variables . . . . .          | UM-372 |
| Commonly used INI variables . . . . .                 | UM-378 |
| Preference variables located in Tcl files . . . . .   | UM-381 |
| Setting variables from the GUI . . . . .              | UM-381 |
| More preferences . . . . .                            | UM-382 |
| Variable precedence . . . . .                         | UM-383 |
| Simulator state variables . . . . .                   | UM-384 |
| Referencing simulator state variables . . . . .       | UM-384 |
| Special considerations for the now variable . . . . . | UM-385 |

## B - ModelSim shortcuts (UM-387)

|                                                               |        |
|---------------------------------------------------------------|--------|
| Command shortcuts . . . . .                                   | UM-387 |
| Main and Source window mouse and keyboard shortcuts . . . . . | UM-389 |
| List window keyboard shortcuts . . . . .                      | UM-391 |
| Wave window mouse and keyboard shortcuts . . . . .            | UM-392 |
| Right mouse button . . . . .                                  | UM-393 |

## C - ModelSim messages (UM-395)

|                                             |        |
|---------------------------------------------|--------|
| ModelSim message system . . . . .           | UM-396 |
| Message format . . . . .                    | UM-396 |
| Getting more information . . . . .          | UM-396 |
| Suppressing warning messages . . . . .      | UM-397 |
| Suppressing VCOM warning messages . . . . . | UM-397 |
| Suppressing VLOG warning messages . . . . . | UM-397 |
| Suppressing VSIM warning messages . . . . . | UM-397 |
| Exit codes . . . . .                        | UM-398 |
| Miscellaneous messages . . . . .            | UM-400 |
| Empty port name warning . . . . .           | UM-400 |
| Lock message . . . . .                      | UM-400 |
| Metavalue detected warning . . . . .        | UM-400 |
| Sensitivity list warning . . . . .          | UM-401 |
| Tcl Initialization error 2 . . . . .        | UM-401 |
| Too few port connections . . . . .          | UM-402 |
| VSIM license lost . . . . .                 | UM-403 |

## D - System initialization (UM-405)

|                                                         |        |
|---------------------------------------------------------|--------|
| Files accessed during startup . . . . .                 | UM-406 |
| Environment variables accessed during startup . . . . . | UM-407 |
| Initialization sequence . . . . .                       | UM-408 |

## Index (UM-411)



# 1 - Introduction

---

## Chapter contents

|                                             |       |
|---------------------------------------------|-------|
| <a href="#">ModelSim modes of operation</a> | UM-14 |
| <a href="#">Command-line mode</a>           | UM-14 |
| <a href="#">Batch mode</a>                  | UM-15 |
| <a href="#">Standards supported</a>         | UM-16 |
| <a href="#">Assumptions</a>                 | UM-16 |
| <a href="#">Sections in this document</a>   | UM-17 |
| <a href="#">What is an "Item"</a>           | UM-19 |
| <a href="#">Text conventions</a>            | UM-19 |

This documentation was written for ModelSim for Microsoft Windows.

## ModelSim modes of operation

Many users run ModelSim interactively—pushing buttons and/or pulling down menus in a series of windows in the GUI (graphic user interface). But there are really three modes of ModelSim operation, the characteristics of which are outlined in the following table.:

| ModelSim use mode   | Characteristics                                                                                                 | How ModelSim is invoked                                                                                                      |
|---------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| <b>GUI</b>          | interactive; has graphical windows, push-buttons, menus, and a command line in the transcript.<br>Default mode. | via a desktop icon or from the OS command shell prompt. Example:<br><br>OS> vsim                                             |
| <b>Command-line</b> | interactive command line; no GUI.                                                                               | with <b>-c</b> argument at the OS command prompt. Example:<br><br>OS> vsim -c                                                |
| <b>Batch</b>        | non-interactive batch script; no windows or interactive command line.                                           | at OS command shell prompt using redirection of standard input. Example:<br><br>C:\modeltech> vsim vfiles.v <infile >outfile |

The ModelSim User's Manual focuses primarily on the GUI mode of operation. However, this section provides an introduction to the Command-line and Batch modes.

### Command-line mode

In command-line mode ModelSim executes any startup command specified by the [Startup](#) (UM-376) variable in the *modelsim.ini* file. If **vsim** (CR-213) is invoked with the **-do** <"**command\_string**"> option, a DO file (macro) is called. A DO file executed in this manner will override any startup command in the *modelsim.ini* file.

During simulation a transcript file is created containing any messages to stdout. A transcript file created in command-line mode may be used as a DO file if you invoke the [transcript on](#) command (CR-145) after the design loads (see the example below). The [transcript on](#) command writes all of the commands you invoke to the transcript file. For example, the following series of commands results in a transcript file that can be used for command input if *top* is re-simulated (remove the **quit -f** command from the transcript file if you want to remain in the simulator).

```
vsim -c top
library and design loading messages... then execute:
```

```
transcript on
force clk 1 50, 0 100 -repeat 100
run 500
run @5000
quit -f
```

Rename transcript files that you intend to use as DO files. They will be overwritten the next time you run **vsim** if you don't rename them. Also, simulator messages are already commented out, but any messages generated from your design (and subsequently written to the transcript file) will cause the simulator to pause. A transcript file that contains only valid simulator commands will work fine; comment out anything else with a "#".

Stand-alone tools pick up project settings in command-line mode if they are invoked in the project's root directory. If invoked outside the project directory, stand-alone tools pick up project settings only if you set the **MODELSIM** environment variable to the path to the project file (*<Project\_Root\_Dir>/<Project\_Name>.mpf*).

## Batch mode

Batch mode is an operational mode that provides neither an interactive command line nor interactive windows. In a Windows environment, **vsim** is run from a Windows command prompt and standard input and output are re-directed from and to files.

Here is an example of a batch mode simulation using redirection of std input and output:

```
c:\modeltech\vsim counter < yourfile > outfile
```

where "yourfile" is a script containing various ModelSim commands.

## Standards supported

ModelSim VHDL implements the VHDL language as defined by IEEE Standards 1076-1987, 1076-1993, and 1076-2002. ModelSim also supports the 1164-1993 *Standard Multivalue Logic System for VHDL Interoperability*, and the 1076.2-1996 *Standard VHDL Mathematical Packages* standards. Any design developed with ModelSim will be compatible with any other VHDL system that is compliant with the 1076 specs.

ModelSim Verilog implements the Verilog language as defined by the IEEE Std 1364-1995 and 1364-2001. ModelSim Verilog also supports a partial implementation of System Verilog 3.1, Accellera's Extensions to Verilog® (see `<install_dir>/modeltech/docs/technotes/svlog.note` for implementation details). The Open Verilog International *Verilog LRM version 2.0* is also applicable to a large extent. Both PLI (Programming Language Interface) and VCD (Value Change Dump) are supported for ModelSim PE and SE users.

In addition, all products support SDF 1.0 through 3.0, VITAL 2.2b, VITAL'95 – IEEE 1076.4-1995, and VITAL 2000 – IEEE 1076.4-2000.

## Assumptions

We assume that you are familiar with the use of your operating system and its graphic interface.

We also assume that you have a working knowledge of VHDL and/or Verilog. Although ModelSim is an excellent tool to use while learning HDL concepts and practices, this document is not written to support that goal.

Finally, we assume that you have worked the appropriate lessons in the *ModelSim Tutorial* and are familiar with the basic functionality of ModelSim. The *ModelSim Tutorial* is available from the ModelSim **Help** menu.

# Sections in this document

In addition to this introduction, you will find the following major sections in this document:

## [2 - Projects \(UM-21\)](#)

This chapter discusses ModelSim "projects", a container for design files and their associated simulation properties.

## [3 - Design libraries \(UM-43\)](#)

To simulate an HDL design using ModelSim, you need to know how to create, compile, maintain, and delete design libraries as described in this chapter.

## [4 - VHDL simulation \(UM-57\)](#)

This chapter is an overview of compilation and simulation for VHDL within the ModelSim environment.

## [5 - Verilog simulation \(UM-83\)](#)

This chapter is an overview of compilation and simulation for Verilog within the ModelSim environment.

## [6 - Verilog PLI / VPI \(UM-115\)](#)

This chapter describes the ModelSim implementation of the Verilog PLI and VPI.

## [7 - WLF files \(datasets\) and virtuals \(UM-141\)](#)

This chapter describes datasets and virtuals - both methods for viewing and organizing simulation data in ModelSim.

## [8 - Graphic interface \(UM-155\)](#)

This chapter describes the graphic interface available while operating ModelSim. ModelSim's graphic interface is designed to provide consistency throughout all operating system environments.

## [9 - Signal Spy \(UM-293\)](#)

This chapter describes Signal Spy, a set of VHDL procedures and Verilog system tasks that let you monitor, drive, force, or release an item from anywhere in the hierarchy of a VHDL or mixed design.

## [10 - Standard Delay Format \(SDF\) Timing Annotation \(UM-313\)](#)

This chapter discusses ModelSim's implementation of SDF (Standard Delay Format) timing annotation. Included are sections on VITAL SDF and Verilog SDF, plus troubleshooting.

## [11 - Value Change Dump \(VCD\) Files \(UM-329\)](#)

This chapter explains Model Technology's Verilog VCD implementation for ModelSim. The VCD usage is extended to include VHDL designs.

## [12 - Tcl and macros \(DO files\) \(UM-345\)](#)

This chapter provides an overview of Tcl (tool command language) as used with ModelSim.

[\*\*A - ModelSim variables\*\*](#) (UM-363)

This appendix describes environment, system, and preference variables used in ModelSim.

[\*\*B - ModelSim shortcuts\*\*](#) (UM-387)

This appendix describes ModelSim keyboard and mouse shortcuts.

[\*\*C - ModelSim messages\*\*](#) (UM-395)

This appendix describes ModelSim error and warning messages.

[\*\*D - System initialization\*\*](#) (UM-405)

This appendix describes what happens during ModelSim startup.

## What is an "Item"

Because ModelSim works with VHDL Verilog, an “item” refers to any valid design element in VHDLVerilog. The word “item” is used whenever a specific language reference is not needed. Depending on the context, “item” can refer to any of the following:

|                |                                                                                                                      |
|----------------|----------------------------------------------------------------------------------------------------------------------|
| <b>VHDL</b>    | block statement, component instantiation, constant, generate statement, generic, package, signal, alias, or variable |
| <b>Verilog</b> | function, module instantiation, named fork, named begin, net, task, register, or variable                            |

## Text conventions

Text conventions used in this manual include:

|                     |                                                                                                                                                          |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>italic text</i>  | provides emphasis and sets off filenames, pathnames, and design unit names                                                                               |
| <b>bold text</b>    | indicates commands, command options, menu choices, package and library logical names, as well as variables, dialog box selections, and language keywords |
| monospace type      | monospace type is used for program and command examples                                                                                                  |
| The right angle (>) | is used to connect menu choices when traversing menus as in: <b>File &gt; Quit</b>                                                                       |
| UPPER CASE          | denotes file types used by ModelSim (e.g., DO, WLF,INI, MPF, PDF, etc.)                                                                                  |



# 2 - Projects

---

## Chapter contents

|                                                           |       |
|-----------------------------------------------------------|-------|
| Introduction . . . . .                                    | UM-22 |
| What are projects? . . . . .                              | UM-22 |
| What are the benefits of projects? . . . . .              | UM-22 |
| Project conversion between versions . . . . .             | UM-23 |
| Getting started with projects . . . . .                   | UM-24 |
| Step 1 — Creating a new project . . . . .                 | UM-24 |
| Step 2 — Adding items to the project . . . . .            | UM-25 |
| Step 3 — Compiling the files . . . . .                    | UM-25 |
| Step 4 — Simulating a design . . . . .                    | UM-25 |
| Other basic project operations . . . . .                  | UM-29 |
| The Project tab . . . . .                                 | UM-30 |
| Sorting the list . . . . .                                | UM-30 |
| Project tab context menu . . . . .                        | UM-31 |
| Changing compile order . . . . .                          | UM-32 |
| Auto-generating compile order . . . . .                   | UM-32 |
| Grouping files . . . . .                                  | UM-33 |
| Creating a Simulation Configuration . . . . .             | UM-34 |
| Organizing projects with folders . . . . .                | UM-36 |
| Specifying file properties and project settings . . . . . | UM-38 |
| File compilation properties . . . . .                     | UM-38 |
| Project settings . . . . .                                | UM-39 |
| Accessing projects from the command line . . . . .        | UM-41 |

This chapter discusses ModelSim projects. Projects simplify the process of compiling and simulating a design and are a great tool for getting started with ModelSim.

# Introduction

## What are projects?

Projects are collection entities for HDL designs under specification or test. At a minimum, projects have a root directory, a work library, and "metadata" which are stored in a `.mpf` file located in a project's root directory. The metadata include compiler switch settings, compile order, and file mappings. Projects may also include:

- HDL source files or references to source files
- other files such as READMEs or other project documentation
- local libraries
- references to global libraries
- Simulation Configurations (see "[Creating a Simulation Configuration](#)" (UM-34))
- Folders (see "[Organizing projects with folders](#)" (UM-36))

 **Important:** Project metadata are updated and stored *only* for actions taken within the project itself. For example, if you have a file in a project, and you compile that file from the command line rather than using the project menu commands, the project will not update to reflect any new compile settings.

## What are the benefits of projects?

Projects offer benefits to both new and advanced users. Projects

- simplify interaction with ModelSim; you don't need to understand the intricacies of compiler switches and library mappings
- eliminate the need to remember a conceptual model of the design; the compile order is maintained for you in the project.
- remove the necessity to re-establish compiler switches and settings at each session; these are stored in the project metadata as are mappings to HDL source files
- allow users to share libraries without copying files to a local directory; you can establish references to source files that are stored remotely or locally
- allow you to change individual parameters across multiple files; in previous versions you could only set parameters one file at a time
- enable "what-if" analysis; you can copy a project, manipulate the settings, and rerun it to observe the new results
- reload the initial settings from the project `.mpf` file every time the project is opened

## Project conversion between versions

Projects are generally not backwards compatible for either number or letter releases. When you open a project created in an earlier version (e.g., you're using 5.6 and you open a project created in 5.5), you'll see a message warning that the project will be converted to the newer version. You have the option of continuing with the conversion or cancelling the operation.

As stated in the warning message, a backup of the original project is created before the conversion occurs. The backup file is named *<project name>.mpf.bak* and is created in the same directory in which the original project is located.

- ▶ **Note:** Due to the significant changes, projects created in versions prior to 5.5 cannot be converted automatically. If you created a project in an earlier version, you will need to recreate it in versions later than 5.5. With the new interface even the most complex project should take less than 15 minutes to recreate. Follow the instructions in the ensuing pages to recreate your project.

## Getting started with projects

This section describes the four basic steps to working with a project.

### [Step 1 — Creating a new project](#) (UM-24)

This creates a .mpf file and a working library.

### [Step 2 — Adding items to the project](#) (UM-25)

Projects can reference or include HDL source files, folders for organization, simulations, and any other files you want to associate with the project. You can copy files into the project directory or simply create mappings to files in other locations.

### [Step 3 — Compiling the files](#) (UM-28)

This checks syntax and semantics and creates the pseudo machine code ModelSim uses for simulation.

### [Step 4 — Simulating a design](#) (UM-29)

This specifies the design unit you want to simulate and opens a structure tab in the Main window workspace.

## Step 1 — Creating a new project

Select **File > New > Project** (Main window) to create a new project. This opens the **Create Project** dialog.



The dialog includes these options:

- **Project Name**

The name of the new project.

- **Project Location**

The directory in which the .mpf file will be created.

- **Default Library Name**

The name of the working library. See "[Working library versus resource libraries](#)" (UM-44) for more details on work libraries. You can generally leave the **Default Library Name** set to "work." The name you specify will be used to create a working library subdirectory within the Project Location.

After selecting OK, you will see a blank Project tab in the workspace area of the Main window and the **Add Items to the Project** dialog.



The name of the current project is shown at the bottom left corner of the Main window.

## Step 2 — Adding items to the project

The **Add Items to the Project** dialog includes these options:

- **Create New File**

Create a new VHDL, Verilog, Tcl, or text file using the Source window. See below for details.

- **Add Existing File**

Add an existing file. See below for details.

- **Create Simulation**

Create a Simulation Configuration that specifies source files and simulator options. See "[Creating a Simulation Configuration](#)" (UM-34) for details.

- **Create New Folder**

Create an organization folder. See "[Organizing projects with folders](#)" (UM-36) for details.

### Create New File

The **Create New File** command lets you create a new VHDL, Verilog, Tcl, or text file using the Source window. You can also access this command by selecting **File > Add to Project > New File** (Main window) or right-clicking in the Project tab and selecting **Add to Project > New File**.



The **Create Project File** dialog includes these options:

- **File Name**  
The name of the new file.
- **Add file as type**  
The type of the new file. Select VHDL, Verilog, TCL, or text.
- **Folder**  
The organization folder in which you want the new file placed. You must first create folders in order to access them here. See "[Organizing projects with folders](#)" (UM-36) for details.

When you select OK, the file is listed in the Project tab of the Main window workspace.

### Add Existing File

You can also access this command by selecting **File > Add to Project > Existing File** (Main window) or by right-clicking in the Project tab and selecting **Add to Project > Existing File**.



The **Add file to Project** dialog includes these options:

- **File Name**

The name of the file to add. You can add multiple files at one time.

- **Add file as type**

The type of the file. "Default" assigns type based on the file extension (e.g., .v is type Verilog).

- **Folder**

The organization folder in which you want the file placed. You must first create folders in order to access them here. See "[Organizing projects with folders](#)" (UM-36) for details.

- **Reference from current location/Copy to project directory**

Choose whether to reference the file from its current location or to copy it into the project directory.

When you select OK, the file(s) is listed in the Project tab of the Main window workspace.

### Step 3 — Compiling the files

The question marks next to the files in the Project tab denote either the files haven't been compiled into the project or the source has changed since the last compile. To compile the files, select **Compile > Compile All** (Main window) or right click in the Project tab and select **Compile > Compile All**.



Once compilation is finished, click the Library tab, expand library *work* by clicking the "+", and you will see the compiled design units.



## Step 4 — Simulating a design

To simulate one of the designs, either double-click the name or right-click the name and select Simulate. A new tab named *sim* appears that shows the structure of the active simulation.



At this point you are ready to run the simulation and analyze your results. You often do this by adding signals to the Wave window and running the simulation for a given period of time. See the *ModelSim Tutorial* for examples.

## Other basic project operations

### ***Open an existing project***

If you previously exited ModelSim with a project open, ModelSim automatically will open that same project upon startup. You can open a different project by selecting **File > Open > Project** (Main window).

### ***Close a project***

Select **File > Close > Project** (Main window) or right-click in the Project tab and select **Close Project**. This closes the Project tab but leaves the Library tab open in the workspace. Note that you cannot close a project while a simulation is in progress.

### ***Delete a project***

Select **File > Delete > Project** (Main window). You cannot delete a project while it is open.

## The Project tab

The Project tab contains information about the items in your project. By default the tab is divided into five columns.



**Name** – The name of a file or object.

**Status** – Identifies whether a source file has been successfully compiled. Applies only to VHDL or Verilog files. A question mark means the file hasn't been compiled or the source file has changed since the last successful compile; an X means the compile failed; a check mark means the compile succeeded; a checkmark with a yellow triangle behind it means the file compiled but there were warnings generated.

**Type** – The file type as determined by registered file types on Windows or the type you specify when you add the file to the project.

**Order** – The order in which the file will be compiled when you execute a Compile All command.

**Modified** – The date and time of the last modification to the file.

You can hide or show columns by right-clicking on a column title and selecting or deselecting entries.

## Sorting the list

You can sort the list by any of the five columns. Click on a column heading to sort by that column; click the heading again to invert the sort order. An arrow in the column heading indicates which field the list is sorted by and whether the sort order is descending (down arrow) or ascending (up arrow).

## Project tab context menu

Like the other workspace tabs, the Project tab has a context menu that you access by clicking your right mouse button anywhere in the tab. The context menu has the following commands:

|                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Edit                | open the selected file in an editor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Execute             | execute the selected Verilog, VHDL, WLF, or DO file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Compile             | <p>provides these options:</p> <p>Compile Selected – compile the selected file(s); note that if you select a folder and select <b>Compile Selected</b>, it will compile all files in the folder and any sub-folders</p> <p>Compile All – compile all source files included in the project</p> <p>Compile Out-of-Date – compile source files that have been modified since the last compile</p> <p>Compile Order – set compile order for all files in the project; see "<a href="#">Changing compile order</a>" (UM-32) for more details.</p> <p>Compile Report – show the compilation history of the selected file</p> <p>Compile Summary – show the compilation history of the entire project</p> <p>Compile Properties – view/change project compiler settings for the selected source file(s)</p> |
| Simulate            | load the design unit(s) and associated simulation options from the selected Simulation Configuration; see " <a href="#">Creating a Simulation Configuration</a> " (UM-34) for more details                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Add to Project      | <p>provides these options:</p> <p>New File – add a new file to the project</p> <p>Existing File – add an existing file to the project</p> <p>Simulation Configuration – create a new Simulation Configuration; see "<a href="#">Creating a Simulation Configuration</a>" (UM-34) for more details</p> <p>Folder – add an organization folder to the project; see "<a href="#">Organizing projects with folders</a>" (UM-36) for more details</p>                                                                                                                                                                                                                                                                                                                                                     |
| Remove from Project | remove the selected item from the project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Close Project       | close the active project                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Properties          | view/change compiler settings for the selected source file(s)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Project Settings    | change settings for the project; see " <a href="#">Project settings</a> " (UM-39)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## Changing compile order

When you compile all files in a project, ModelSim by default compiles the files in the order in which they were added to the project. You have two alternatives for changing the default compile order: 1) select and compile each file individually; 2) specify a custom compile order.

To specify a custom compile order, follow these steps:

- 1 Select **Compile > Compile Order** (Main window) or select it from the context menu in the Project tab.



- 2 Drag the files into the correct order or use the up and down arrow buttons. Note that you can select multiple files and drag them simultaneously.

### Auto-generating compile order

Auto Generate is supported for HDL-only designs. The **Auto Generate** button in the Compile Order dialog (see above) "determines" the correct compile order by making multiple passes over the files. It starts compiling from the top; if a file fails to compile due to dependencies, it moves that file to the bottom and then recompiles it after compiling the rest of the files. It continues in this manner until all files compile successfully or until a file(s) can't be compiled for reasons other than dependency.

Files can be displayed in the Project tab in alphabetical or compile order (using the **Sort by Alphabetical Order** or **Sort by Compile Order** commands on the context menu). Keep in mind that the order you see in the Project tab is not necessarily the order in which the files will be compiled.

## Grouping files

You can group two or more files in the Compile Order dialog so they are sent to the compiler at the same time. For example, you might have one file with a bunch of Verilog define statements and a second file that is a Verilog module. You would want to compile these two files together.

To group files, follow these steps:

- 1 Select the files you want to group.



- 2 Click the Group button.



To ungroup files, select the group and click the Ungroup button.



## Creating a Simulation Configuration

A Simulation Configuration associates a design unit(s) and its simulation options. For example, say you routinely load a particular design and you have to specify the simulator resolution, generics, and SDF timing files. Ordinarily you would have to specify those options each time you load the design. With a Simulation Configuration, you would specify the design and those options and then save the configuration with a name (e.g., *top\_config*). The name is then listed in the Project tab and you can double-click it to load the design along with its options.

To create a Simulation Configuration, follow these steps:

- 1 Select **File > Add to Project > Simulation Configuration** (Main window) or select it from the context menu in the Project tab.



- 2 Specify a name in the **Simulation Configuration Name** field.
- 3 Specify the folder in which you want to place the configuration (see "[Organizing projects with folders](#)" (UM-36)).
- 4 Select one or more design unit(s). Use the Control and/or Shift keys to select more than one design unit. The design unit names appear in the **Simulate** field when you select them.

- 5 Use the other tabs in the dialog to specify any required simulation options. All of the options in this dialog are described under "Simulating with the graphic interface" (UM-272).

Click OK and the simulation configuration is added to the Project tab.



Double-click the Simulation Configuration item to load it.

## Organizing projects with folders

The more files you add to a project, the harder it can be to locate the item you need. You can add "folders" to the project to organize your files. These folders are akin to directories in that you can have multiple levels of folders and sub-folders. However, no actual directories are created via the file system—the folders are present only within the project file.

### Adding a folder

To add a folder to your project, select **File > Add to Project > Folder** or right-click in the Project tab and select **Add to Project > Folder**.



Specify the Folder Name, the location for the folder, and click OK. The folder will be displayed in the Project tab.



You use the folders when you add new objects to the project. For example, when you add a file, you can select which folder to place it in.



If you want to move a file into a folder later on, you can do so using the Properties dialog for the file (right-click on the file and select Properties from the context menu).



On Windows platforms, you can also just drag-and-drop a file into a folder.

## Specifying file properties and project settings

You can set two types of properties in a project: file properties and project settings. File properties affect individual files; project settings affect the entire project.

### File compilation properties

The VHDL and Verilog compilers (**vcom** and **vlog**, respectively) have numerous options that affect how a design is compiled and subsequently simulated. You can customize the settings on individual files or a group of files.

**Important:** Any changes you make to the compile properties outside of the project, whether from the command line, the GUI, or the *modelsim.ini* file, *will not* affect the properties of files already in the project.

To customize specific files, select the file(s) in the Project tab, right click on the file names, and select **Properties**. The resulting dialog varies depending on the number and type of files you have selected. If you select a single VHDL, Verilog file, you'll see the General tab and the VHDL or Verilog tab, respectively. On the General tab, you'll see file properties such as Type, Location, and Size. If you select multiple files, the file properties on the General tab are not listed. Finally, if you select both a VHDL file and a Verilog file, you'll see all four tabs but no file information on the General tab.



The General tab includes these options:

- **Do Not Compile**  
Determines whether the file is excluded from the compile.
- **Compile to library**  
Specifies to which library you want to compile the file; defaults to the working library.
- **Place in Folder**  
Specifies the folder in which to place the selected file(s). See "[Organizing projects with folders](#)" (UM-36) for details on folders.

- **File Properties**

A variety of information about the selected file (e.g, type, size, path). Displays only if a single file is selected in the Project tab.

The definitions of the options on the VHDL and Verilog tabs can be found in the section "[Setting default compile options](#)" (UM-267).

When setting options on a group of files, keep in mind the following:

- If two or more files have different settings for the same option, the checkbox in the dialog will be "grayed out." If you change the option, you cannot change it back to a "multi- state setting" without cancelling out of the dialog. Once you click OK, ModelSim will set the option the same for all selected files.
- If you select a combination of VHDL and Verilog files, the options you set on the VHDL and Verilog tabs apply only to those file types.

## Project settings

To modify project settings, right-click anywhere within the Project tab and select **Project Settings**.



The **Project Settings** dialog includes these options:

- **Display compiler output**

Prints verbose compile output to the Transcript. By default verbose output is produced in the Compile Report only.

- **Save compile report**

Saves verbose compile output to disk. You can access the report by right-clicking a file and selecting **Compile > Compile Report**.

- **Location map**

Specifies whether physical paths for the project files should be saved as soft paths if they are present in the location map. See "[Referencing source files with location maps](#)" (UM-54) for more details on using location maps.

- **Double-click Behavior**

Specifies the action to take when you double-click a type of file. If you select Custom, you can specify a Tcl command in the text box below the file type.

You can use *%f* for filename substitution. For example, if you wanted double click on a Tcl file to open the file with Notepad, you would insert the following in the text box:

```
notepad %f
```

ModelSim will substitute the *%f* with the filename that was clicked on, then execute the string.

## Accessing projects from the command line

Generally, projects are used from within the ModelSim GUI. However, standalone tools will use the project file if they are invoked in the project's root directory. If you want to invoke outside the project directory, set the **MODELSIM** environment variable with the path to the project file (<Project\_Root\_Dir>/<Project\_Name>.mpf).

You can also use the **project** command (CR-122) from the command line to perform common operations on projects.



# 3 - Design libraries

---

## Chapter contents

|                                                        |       |
|--------------------------------------------------------|-------|
| Design library overview . . . . .                      | UM-44 |
| Design unit information . . . . .                      | UM-44 |
| Working library versus resource libraries . . . . .    | UM-44 |
| Archives . . . . .                                     | UM-45 |
| Working with design libraries . . . . .                | UM-46 |
| Creating a library . . . . .                           | UM-46 |
| Managing library contents . . . . .                    | UM-47 |
| Assigning a logical name to a design library . . . . . | UM-49 |
| Moving a library . . . . .                             | UM-50 |
| Setting up libraries for group use . . . . .           | UM-50 |
| Specifying the resource libraries . . . . .            | UM-51 |
| Verilog resource libraries . . . . .                   | UM-51 |
| VHDL resource libraries . . . . .                      | UM-51 |
| Predefined libraries . . . . .                         | UM-52 |
| Alternate IEEE libraries supplied . . . . .            | UM-52 |
| Regenerating your design libraries . . . . .           | UM-52 |
| Referencing source files with location maps . . . . .  | UM-54 |
| Importing FPGA libraries . . . . .                     | UM-56 |

VHDL contains *libraries*, which are objects that contain compiled design units; libraries are given names so they may be referenced. Verilog designs simulated within ModelSim are compiled into libraries as well.

## Design library overview

A *design library* is a directory or archive that serves as a repository for compiled design units. The design units contained in a design library consist of VHDL entities, packages, architectures, and configurations; and Verilog modules and UDPs (user-defined primitives). The design units are classified as follows:

- **Primary design units**

Consist of entities, package declarations, configuration declarations, modules, and UDPs. Primary design units within a given library must have unique names.

- **Secondary design units**

Consist of architecture bodies and package bodies. Secondary design units are associated with a primary design unit. Architectures by the same name can exist if they are associated with different entities or modules.

## Design unit information

The information stored for each design unit in a design library is:

- retargetable, executable code
- debugging information
- dependency information

## Working library versus resource libraries

Design libraries can be used in two ways: 1) as a local working library that contains the compiled version of your design; 2) as a resource library. The contents of your working library will change as you update your design and recompile. A resource library is typically static and serves as a parts source for your design. You can create your own resource libraries, or they may be supplied by another design team or a third party (e.g., a silicon vendor).

Only one library can be the working library. In contrast any number of libraries can be resource libraries during a compilation. You specify which resource libraries will be used when the design is compiled, and there are rules to specify in which order they are searched (see "[Specifying the resource libraries](#)" (UM-51)).

A common example of using both a working library and a resource library is one where your gate-level design and testbench are compiled into the working library, and the design references gate-level models in a separate resource library.

The library named **work** has special attributes within ModelSim; it is predefined in the compiler and need not be declared explicitly (i.e. **library work**). It is also the library name used by the compiler as the default destination of compiled design units (i.e., it doesn't need to be mapped). In other words the **work** library is the default *working* library.

## Archives

By default, design libraries are stored in a directory structure with a sub-directory for each design unit in the library. Alternatively, you can configure a design library to use archives. In this case each design unit is stored in its own archive file. To create an archive, use the **-archive** argument to the **vlib** command (CR-203).

Generally you would do this only in the rare case that you hit the reference count limit on I-nodes due to the ".." entries in the lower-level directories. An example of an error message that is produced when this limit is hit is:

```
mkdir: cannot create directory `65534': Too many links
```

Archives may also have limited value to customers seeking disk space savings.

Note that GMAKE won't work with these archives on the IBM platform.

## Working with design libraries

The implementation of a design library is not defined within standard VHDL or Verilog. Within ModelSim, design libraries are implemented as directories and can have any legal name allowed by the operating system, with one exception; extended identifiers are not supported for library names.

### Creating a library

When you create a project (see "[Getting started with projects](#)" (UM-24)), ModelSim automatically creates a working design library. If you don't create a project, you need to create a working design library before you run the compiler. This can be done from either the command line or from the ModelSim graphic interface.

From the ModelSim prompt or a DOS prompt, use this **vlib** command (CR-203):

```
vlib <directory_pathname>
```

To create a new library with the ModelSim graphic interface, select **File > New > Library** (Main window).



The **Create a New Library** dialog box includes these options:

- **Create a new library and a logical mapping to it**  
Type the new library name into the **Library Name** field. This creates a library sub-directory in your current working directory, initially mapped to itself. Once created, the mapped library is easily remapped to a different library.
- **Create a map to an existing library**  
Type the new library name into the **Library Name** field, then type into the **Library Maps to** field or **Browse** to select a library name for the mapping.
- **Library Name**  
Type the logical name of the new library into this field.

- **Library Physical Name**

Type the physical name of the new library into this field. ModelSim will create a directory with this name.

- **Library Maps to**

Type or **Browse** for a mapping for the specified library. This field is visible and can be changed only when the **Create a map to an existing library** option is selected.

When you click **OK**, ModelSim creates the specified library directory and writes a specially-formatted file named *\_info* into that directory. The *\_info* file must remain in the directory to distinguish it as a ModelSim library.

The new map entry is written to the *modelsim.ini* file in the [Library] section. See "[\[Library\] library path variables](#)" (UM-369) for more information.

► **Note:** Remember that a design library is a special kind of directory; the only way to create a library is to use the ModelSim GUI or the **vlib** command (CR-203). Do not create libraries using DOS or Windows commands.

## Managing library contents

Library contents can be viewed, deleted, recompiled, edited and so on using either the graphic interface or command line.

The Library tab in the Main window workspace provides access to design units (configurations, modules, packages, entities, and architectures) in a library. The listing is organized hierarchically, and the unit types are identified both by icon (entity (E), module (M), and so forth) and the Type column.



The Library tab has a context menu that you access by clicking your right mouse button in the Library tab.

The context menu includes the following commands:

- **Simulate**

Loads the selected design unit and opens structure and Files tabs in the workspace. Related command line command is [vsim](#) (CR-213).

- **Edit**

Opens the selected design unit in the Source window, or if a library is selected, opens the Edit Library Mapping dialog (see "[Library mappings with the GUI](#)" (UM-49)).

- **Refresh**

Rebuilds the library image of the selected library without using source code. Related command line command is [vcom](#) (CR-167) or [vlog](#) (CR-204) with the **-refresh** argument.

- **Recompile**

Recompiles the selected design unit. Related command line command is [vcom](#) (CR-167) or [vlog](#) (CR-204).

- **Update**

Updates the display of available libraries and design units.

- **Delete**

Deletes the selected design unit. Related command line command is [vdel](#) (CR-174).

Deleting a package, configuration, or entity will remove the design unit from the library. If you delete an entity that has one or more architectures, the entity and all its associated architectures will be deleted.

You can also delete an architecture without deleting its associated entity. Expand the entity, right-click the desired architecture name, and select Delete. You are prompted for confirmation before any design unit is actually deleted.

- **New**

Create a new library.

- **Properties**

Displays various properties (e.g., Name, Type, Source, etc.) of the selected design unit or library.

## Assigning a logical name to a design library

VHDL uses logical library names that can be mapped to ModelSim library directories. By default, ModelSim can find libraries in your current directory (assuming they have the right name), but for it to find libraries located elsewhere, you need to map a logical library name to the pathname of the library.

You can use the GUI, a command, or a project to assign a logical name to a design library.

### ***Library mappings with the GUI***

To associate a logical name with a library, select the library in the workspace, right-click and select **Edit** from the context menu. This brings up a dialog box that allows you to edit the mapping.



The dialog box includes these options:

- **Library Mapping Name**  
The logical name of the library.
- **Library Pathname**  
The pathname to the library.

### ***Library mapping from the command line***

You can issue a command to set the mapping between a logical library name and a directory; its form is:

```
vmap <logical_name> <directory_pathname>
```

You may invoke this command from either a DOS prompt or from the command line within ModelSim.

The **vmap** (CR-212) command adds the mapping to the library section of the *modelsim.ini* file. You can also modify *modelsim.ini* manually by adding a mapping line. To do this, use a text editor and add a line under the [Library] section heading using the syntax:

```
<logical_name> = <directory_pathname>
```

More than one logical name can be mapped to a single directory. For example, suppose the *modelsim.ini* file in the current working directory contains following lines:

```
[Library]
work = /usr/rick/design
my_asic = /usr/rick/design
```

This would allow you to use either the logical name **work** or **my\_asic** in a **library** or **use** clause to refer to the same design library.

The **vmap** command (CR-212) can also be used to display the mapping of a logical library name to a directory. To do this, enter the shortened form of the command:

```
vmap <logical_name>
```

### ***Library search rules***

The system searches for the mapping of a logical name in the following order:

- First the system looks for a *modelsim.ini* file.
- If the system doesn't find a *modelsim.ini* file, or if the specified logical name does not exist in the *modelsim.ini* file, the system searches the current working directory for a subdirectory that matches the logical name.

An error is generated by the compiler if you specify a logical name that does not resolve to an existing directory.

## **Moving a library**

*Individual* design units in a design library cannot be moved. An *entire* design library can be moved, however, by using standard operating system commands for moving a directory or an archive.

## **Setting up libraries for group use**

By adding an “others” clause to your *modelsim.ini* file, you can have a hierarchy of library mappings. If the ModelSim tools don’t find a mapping in the *modelsim.ini* file, then they will search the library section of the initialization file specified by the “others” clause. For example:

```
[library]
asic_lib = /cae/asic_lib
work = my_work
others = /usr/modeltech/modelsim.ini
```

# Specifying the resource libraries

## Verilog resource libraries

ModelSim supports and encourages separate compilation of distinct portions of a Verilog design. The **vlog** (CR-204) compiler is used to compile one or more source files into a specified library. The library thus contains pre-compiled modules and UDPs that are referenced by the simulator as it loads the design. See "[Library usage](#)" (UM-88).

**▲ Important:** Resource libraries are specified differently for Verilog and VHDL. For Verilog you use either the **-L** or **-Lf** argument to **vlog** (CR-204).

## VHDL resource libraries

Within a VHDL source file, you use the VHDL **library** clause to specify logical names of one or more resource libraries to be referenced in the subsequent design unit. The scope of a **library** clause includes the text region that starts immediately after the **library** clause and extends to the end of the declarative region of the associated design unit. *It does not extend to the next design unit in the file.*

Note that the **library** clause is not used to specify the working library into which the design unit is placed after compilation. The **vcom** command (CR-167) adds compiled design units to the current working library. By default, this is the library named **work**. To change the current working library, you can use **vcom -work** and specify the name of the desired target library.

## Default binding rules for VHDL resource libraries

A common question related to VHDL resource libraries is how ModelSim handles default binding for components. ModelSim addresses default binding at compile time. When looking for an entity to bind with, ModelSim searches the currently visible libraries for an entity with the same name as the component. ModelSim does this because IEEE 1076-1987 contained a flaw that made it almost impossible for an entity to be directly visible if it had the same name as the component. In short, if a component was declared in an architecture, any like-named entity above that declaration would be hidden because component/entity names cannot be overloaded. As a result we implemented the following rules for determining default binding:

- If a directly visible entity has the same name as the component, use it.
- If the component is declared in a package, search the library that contained the package for an entity with the same name.

If neither of these methods is successful, ModelSim will also do the following:

- Search the work library.
- Search all other libraries that are currently visible by means of the **library** clause.

Note that these second two searches are an extension to the 1076 standard.

## Predefined libraries

Certain resource libraries are predefined in standard VHDL. The library named **std** contains the packages **standard** and **textio**, which should not be modified. The contents of these packages and other aspects of the predefined language environment are documented in the *IEEE Standard VHDL Language Reference Manual, Std 1076*. See also, "[Using the TextIO package](#)" (UM-66).

A VHDL **use** clause can be specified to select particular declarations in a library or package that are to be visible within a design unit during compilation. A **use** clause references the compiled version of the package—not the source.

By default, every VHDL design unit is assumed to contain the following declarations:

```
LIBRARY std, work;
USE std.standard.all
```

To specify that all declarations in a library or package can be referenced, add the suffix *.all* to the library/package name. For example, the **use** clause above specifies that all declarations in the package *standard*, in the design library named *std*, are to be visible to the VHDL design unit immediately following the **use** clause. Other libraries or packages are not visible unless they are explicitly specified using a **library** or **use** clause.

Another predefined library is **work**, the library where a design unit is stored after it is compiled as described earlier. There is no limit to the number of libraries that can be referenced, but only one library is modified during compilation.

## Alternate IEEE libraries supplied

The installation directory may contain two or more versions of the IEEE library:

- *ieeepure*  
Contains only IEEE approved packages (accelerated for ModelSim).
- *ieee*  
Contains precompiled Synopsys and IEEE arithmetic packages which have been accelerated by Model Technology including *math\_complex*, *math\_real*, *numeric\_bit*, *numeric\_std*, *std\_logic\_1164*, *std\_logic\_misc*, *std\_logic\_textio*, *std\_logic\_arith*, *std\_logic\_signed*, *std\_logic\_unsigned*, *vital\_primitives*, and *vital\_timing*.

You can select which library to use by changing the mapping in the *modelsim.ini* file. The *modelsim.ini* file in the installation directory defaults to the *ieee* library.

## Regenerating your design libraries

Depending on your current ModelSim version, you may need to regenerate your design libraries before running a simulation. Check the installation README file to see if your libraries require an update. You can regenerate your design libraries using the **Refresh** command from the Library tab context menu (see "[Managing library contents](#)" (UM-47)), or by using the **-refresh** argument to **vcom** (CR-167) and **vlog** (CR-204).

From the command line, you would use **vcom** with the **-refresh** option to update VHDL design units in a library, and **vlog** with the **-refresh** option to update Verilog design units. By default, the **work** library is updated; use **-work <library>** to update a different library. For example, if you have a library named *mylib* that contains both VHDL and Verilog design units:

```
vcom -work mylib -refresh  
vlog -work mylib -refresh
```

An important feature of **-refresh** is that it rebuilds the library image without using source code. This means that models delivered as compiled libraries without source code can be rebuilt for a specific release of ModelSim (4.6 and later only). In general, this works for moving forwards or backwards on a release. Moving backwards on a release may not work if the models used compiler switches or directives that do not exist in the older release.

- ▶ **Note:** You don't need to regenerate the *std*, *ieee*, *vital22b*, and *verilog* libraries. Also, you cannot use the **-refresh** option to update libraries that were built before the 4.6 release.

## Referencing source files with location maps

Pathnames to source files are recorded in libraries by storing the working directory from which the compile is invoked and the pathname to the file as specified in the invocation of the compiler. The pathname may be either a complete pathname or a relative pathname.

ModelSim tools that reference source files from the library locate a source file as follows:

- If the pathname stored in the library is complete, then this is the path used to reference the file.
- If the pathname is relative, then the tool looks for the file relative to the current working directory. If this file does not exist, then the path relative to the working directory stored in the library is used.

This method of referencing source files generally works fine if the libraries are created and used on a single system. However, when multiple systems access a library across a network, the physical pathnames are not always the same and the source file reference rules do not always work.

## Using location mapping

Location maps are used to replace prefixes of physical pathnames in the library with environment variables. The location map defines a mapping between physical pathname prefixes and environment variables.

ModelSim tools open the location map file on invocation if the [MGC\\_LOCATION\\_MAP](#) (UM-365) environment variable is set. If MGC\_LOCATION\_MAP is not set, ModelSim will look for a file named "*mgc\_location\_map*" in the following locations, in order:

- the current directory
- your home directory
- the directory containing the ModelSim binaries
- the ModelSim installation directory

### ***Use these two steps to map your files:***

- 1 Set the environment variable MGC\_LOCATION\_MAP to the path to your location map file.
- 2 Specify the mappings from physical pathnames to logical pathnames:

```
$SRC
/home/vhdl/src
/usr/vhdl/src

$IEEE
/usr/modeltech/ieee
```

## Pathname syntax

The logical pathnames must begin with \$ and the physical pathnames must begin with /. The logical pathname is followed by one or more equivalent physical pathnames. Physical pathnames are equivalent if they refer to the same physical directory (they just have different pathnames on different systems).

## How location mapping works

When a pathname is stored, an attempt is made to map the physical pathname to a path relative to a logical pathname. This is done by searching the location map file for the first physical pathname that is a prefix to the pathname in question. The logical pathname is then substituted for the prefix. For example, "/usr/vhdl/src/test.vhd" is mapped to "\$SRC/test.vhd". If a mapping can be made to a logical pathname, then this is the pathname that is saved. The path to a source file entry for a design unit in a library is a good example of a typical mapping.

For mapping from a logical pathname back to the physical pathname, ModelSim expects an environment variable to be set for each logical pathname (with the same name).

ModelSim reads the location map file when a tool is invoked. If the environment variables corresponding to logical pathnames have not been set in your shell, ModelSim sets the variables to the first physical pathname following the logical pathname in the location map. For example, if you don't set the SRC environment variable, ModelSim will automatically set it to "/home/vhdl/src".

## Mapping with Tcl variables

Two Tcl variables may also be used to specify alternative source-file paths; SourceDir and SourceMap. See "[Preference variables located in Tcl files](#)" (UM-381) for more information on Tcl preference variables.

## Importing FPGA libraries

ModelSim includes an import wizard for referencing and using vendor FPGA libraries. The wizard scans for and enforces dependencies in the libraries and determines the correct mappings and target directories.

▲ **Important:** The FPGA libraries you import must be pre-compiled. Most FPGA vendors supply pre-compiled libraries configured for use with ModelSim.

To import an FPGA library, select **File > Import > Library** (Main window).



Follow the instructions in the wizard to complete the import.

# 4 - VHDL simulation

---

## Chapter contents

|                                                                    |       |
|--------------------------------------------------------------------|-------|
| Compiling VHDL designs . . . . .                                   | UM-59 |
| Creating a design library . . . . .                                | UM-59 |
| Invoking the VHDL compiler . . . . .                               | UM-59 |
| Dependency checking . . . . .                                      | UM-59 |
| Range and index checking . . . . .                                 | UM-60 |
| Differences between language versions . . . . .                    | UM-60 |
| Simulating VHDL designs . . . . .                                  | UM-63 |
| Simulator resolution limit . . . . .                               | UM-63 |
| Delta delays . . . . .                                             | UM-64 |
| Using the TextIO package . . . . .                                 | UM-66 |
| Syntax for file declaration . . . . .                              | UM-66 |
| Using STD_INPUT and STD_OUTPUT within ModelSim . . . . .           | UM-67 |
| TextIO implementation issues . . . . .                             | UM-68 |
| Writing strings and aggregates . . . . .                           | UM-68 |
| Reading and writing hexadecimal numbers . . . . .                  | UM-69 |
| Dangling pointers . . . . .                                        | UM-69 |
| The ENDLINE function . . . . .                                     | UM-69 |
| The ENDFILE function . . . . .                                     | UM-69 |
| Using alternative input/output files . . . . .                     | UM-70 |
| Providing stimulus . . . . .                                       | UM-70 |
| VITAL specification and source code . . . . .                      | UM-71 |
| VITAL packages . . . . .                                           | UM-71 |
| ModelSim VITAL compliance . . . . .                                | UM-71 |
| VITAL compliance checking . . . . .                                | UM-71 |
| Compiling and simulating with accelerated VITAL packages . . . . . | UM-72 |
| Compiling and simulating with accelerated VITAL packages . . . . . | UM-72 |
| Util package . . . . .                                             | UM-73 |
| get_resolution . . . . .                                           | UM-73 |
| init_signal_driver() . . . . .                                     | UM-74 |
| init_signal_spy() . . . . .                                        | UM-74 |
| signal_force() . . . . .                                           | UM-74 |
| signal_release() . . . . .                                         | UM-74 |
| to_real() . . . . .                                                | UM-75 |
| to_time() . . . . .                                                | UM-76 |
| Affecting performance by cancelling scheduled events . . . . .     | UM-80 |
| Converting an integer into a bit_vector . . . . .                  | UM-81 |

This chapter provides an overview of compilation and simulation for VHDL; using the TextIO package with ModelSim; ModelSim's implementation of the VITAL (VHDL

Initiative Towards ASIC Libraries) specification for ASIC modeling; and documentation on ModelSim's special built-in utilities package.

The TextIO package is defined within the *VHDL Language Reference Manual, IEEE Std 1076*; it allows human-readable text input from a declared source within a VHDL file during simulation.

# Compiling VHDL designs

## Creating a design library

Before you can compile your design, you must create a library in which to store the compilation results. Use **vlib** (CR-203) to create a new library. For example:

```
vlib work
```

This creates a library named **work**. By default, compilation results are stored in the **work** library.

The **work** library is actually a subdirectory named *work*. This subdirectory contains a special file named *\_info*. Do not create libraries using MS Windows or DOS commands – always use the **vlib** command (CR-203).

See "[Design libraries](#)" (UM-43) for additional information on working with libraries.

## Invoking the VHDL compiler

ModelSim compiles one or more VHDL design units with a single invocation of **vcom** (CR-167), the VHDL compiler. The design units are compiled in the order that they appear on the command line. For VHDL, the order of compilation is important – you must compile any entities or configurations before an architecture that references them.

You can simulate a design containing units written with 1076 -1987, 1076 -1993, and 1076-2002 versions of VHDL. To do so you will need to compile units from each VHDL version separately. The **vcom** (CR-167) command compiles using 1076 -2002 rules by default; use the **-87** or **-93** argument to **vcom** (CR-167) to compile units written with version 1076-1987 or 1076 -1993, respectively. You can also change the default by modifying the VHDL93 variable in the *modelsim.ini* file (see "[Preference variables located in INI files](#)" (UM-369) for more information).

## Dependency checking

Dependent design units must be reanalyzed when the design units they depend on are changed in the library. **vcom** (CR-167) determines whether or not the compilation results have changed. For example, if you keep an entity and its architectures in the same source file and you modify only an architecture and recompile the source file, the entity compilation results will remain unchanged and you will not have to recompile design units that depend on the entity.

## Range and index checking

A range check verifies that a scalar value defined with a range subtype is always assigned a value within its range. An index check verifies that whenever an array subscript expression is evaluated, the subscript will be within the array's range.

Range and index checks are performed by default when you compile your design. You can disable range checks (potentially offering a performance advantage) and index checks using arguments to the **vcom** (CR-167) command. Or, you can use the **NoRangeCheck** and **NoIndexCheck** variables in the *modelsim.ini* file to specify whether or not they are performed. See "[Preference variables located in INI files](#)" (UM-369).

Range checks in ModelSim are slightly more restrictive than those specified by the VHDL LRM. ModelSim requires any assignment to a signal to also be in range whereas the LRM requires only that range checks be done whenever a signal is updated. Most assignments to signals update the signal anyway, and the more restrictive requirement allows ModelSim to generate better error messages.

## Differences between language versions

There are three versions of the IEEE VHDL 1076 standard: VHDL-1987, VHDL-1993, and VHDL-2002. The default language version for ModelSim is VHDL-2002. If your code was written according to the '87 or '93 version, you may need to update your code or instruct ModelSim to use the earlier versions' rules.

To select a specific language version, do one of the following:

- Select the appropriate version from the compiler options menu in the GUI
- Invoke **vcom** (CR-167) using the argument -87, -93, or -2002
- Set the VHDL93 variable in the [vcom] section of the *modelsim.ini* file. Appropriate values for VHDL93 are:
  - 0, 87, or 1987 for VHDL-1987
  - 1, 93, or 1993 for VHDL-1993
  - 2, 02, or 2002 for VHDL-2002

The following is a list of language incompatibilities that may cause problems when compiling a design.

- The only major problem between VHDL-93 and VHDL-2002 is the addition of the keyword "PROTECTED". VHDL-93 programs which use this as an identifier should choose a different name.

All other incompatibilities are between VHDL-87 and VHDL-93.

- VITAL and SDF

It is important to use the correct language version for VITAL. VITAL2000 must be compiled with VHDL-93 or VHDL-2002. VITAL95 must be compiled with VHDL-87. A typical error message that indicates the need to compile under language version VHDL-87 is:

```
"VITALPathDelay DefaultDelay parameter must be locally static"
```

- Purity of NOW

In VHDL-93 the function "now" is impure. Consequently, any function that invokes "now" must also be declared to be impure. Such calls to "now" occur in VITAL. A typical error message:

```
"Cannot call impure function 'now' from inside pure function '<name>'"
```

- Files

File syntax and usage changed between VHDL-87 and VHDL-93. In many cases vcom issues a warning and continues:

```
"Using 1076-1987 syntax for file declaration."
```

In addition, when files are passed as parameters, the following warning message is produced:

```
"Subprogram parameter name is declared using VHDL 1987 syntax."
```

This message often involves calls to endfile(<name>) where <name> is a file parameter.

- Files and packages

Each package header and body should be compiled with the same language version. Common problems in this area involve files as parameters and the size of type CHARACTER. For example, consider a package header and body with a procedure that has a file parameter:

```
procedure proc1 ( out_file : out std.textio.text) ...
```

If you compile the package header with VHDL-87 and the body with VHDL-93 or VHDL-2002, you will get an error message such as:

```
"** Error: mixed_package_b.vhd(4): Parameter kinds do not conform between declarations in package header and body: 'out_file'."
```

- Direction of concatenation

To solve some technical problems, the rules for direction and bounds of concatenation were changed from VHDL-87 to VHDL-93. You won't see any difference in simple variable/signal assignments such as:

```
v1 := a & b;
```

But if you (1) have a function that takes an unconstrained array as a parameter, (2) pass a concatenation expression as a formal argument to this parameter, and (3) the body of the function makes assumptions about the direction or bounds of the parameter, then you will get unexpected results. This may be a problem in environments that assume all arrays have "downto" direction.

- xnor

"xnor" is a reserved word in VHDL-93. If you declare an xnor function in VHDL-87 (without quotes) and compile it under VHDL-2002, you will get an error message like the following:

```
** Error: xnor.vhd(3): near "xnor": expecting: STRING IDENTIFIER
```

- FOREIGN attribute

In VHDL-93 package STANDARD declares an attribute 'FOREIGN'. If you declare your own attribute with that name in another package, then ModelSim issues a warning such as the following:

```
-- Compiling package foopack

** Warning: foreign.vhd(9): (vcom-1140) VHDL-1993 added a definition of the
attribute foreign to package std.standard. The attribute is also defined in
package 'standard'. Using the definition from package 'standard'.
```

- Size of CHARACTER type

In VHDL-87 type CHARACTER has 128 values; in VHDL-93 it has 256 values. Code which depends on this size will behave incorrectly. This situation occurs most commonly in test suites that check VHDL functionality. It's unlikely to occur in practical designs. A typical instance is the replacement of warning message:

```
"range nul downto del is null"

by

"range nul downto 'ÿ' is null" -- range is nul downto y(umlaut)
```

- bit string literals

In VHDL-87 bit string literals are of type bit\_vector. In VHDL-93 they can also be of type STRING or STD\_LOGIC\_VECTOR. This implies that some expressions that are unambiguous in VHDL-87 now become ambiguous in VHDL-93. A typical error message is:

```
** Error: bit_string_literal.vhd(5): Subprogram '=' is ambiguous. Suitable
definitions exist in packages 'std_logic_1164' and 'standard'.
```

- In VHDL-87 when using individual subelement association in an association list, associating individual subelements with NULL is discouraged. In VHDL-93 such association is forbidden. A typical message is:

```
"Formal '<name>' must not be associated with OPEN when subelements are
associated individually."
```

## Simulating VHDL designs

After compiling the design units, you can simulate your designs with **vsim** (CR-213). This section discusses simulation from the Windows/DOS command line. You can also use a project to simulate (see "Getting started with projects" (UM-24)) or the **Simulate** dialog box (see "Simulating with the graphic interface" (UM-272)).

For VHDL invoke **vsim** (CR-213) with the name of the configuration, or entity/architecture pair. Note that if you specify a configuration you may not specify an architecture.

This example invokes **vsim** (CR-213) on the entity **my\_asic** and the architecture **structure**:

```
vsim my_asic structure
```

**vsim** (CR-213) is capable of annotating a design using VITAL compliant models with timing data from an SDF file. You can specify the min:typ:max delay by invoking **vsim** with the **-sdfmin**, **-sdftyp**, or **-sdfmax** option. Using the SDF file *f1.sdf* in the current work directory, the following invocation of **vsim** annotates maximum timing values for the design unit *my\_asic*:

```
vsim -sdfmax /my_asic=f1.sdf my_asic
```

By default, the timing checks within VITAL models are enabled. They can be disabled with the **+notimingchecks** option. For example:

```
vsim +notimingchecks topmod
```

## Simulator resolution limit

The simulator internally represents time as a 64-bit integer in units equivalent to the smallest unit of simulation time, also known as the simulator resolution limit. The default resolution limit is set to the value specified by the **Resolution** (UM-375) variable in the *modelsim.ini* file. You can view the current resolution by invoking the **report** command (CR-128) with the **simulator state** option.

### Overriding the resolution

You can override ModelSim's default resolution by specifying the **-t** option on the command line or by selecting a different Simulator Resolution in the **Simulate** dialog box. Available resolutions are: 1x, 10x, or 100x of fs, ps, ns, us, ms, or sec.

For example this command chooses 10 ps resolution:

```
vsim -t 10ps topmod
```

Clearly you need to be careful when doing this type of operation. If the resolution set by **-t** is larger than a delay value in your design, the delay values in that design unit are rounded to the closest multiple of the resolution. In the example above, a delay of 4 ps would be rounded to 0 ps.

### Choosing the resolution

You should choose the coarsest resolution limit possible that does not result in undesired rounding of your delays. The time precision should not be unnecessarily small because it will limit the maximum simulation time limit, and it will degrade performance in some cases.

## Delta delays

Event-based simulators such as ModelSim may process many events at a given simulation time. Multiple signals may need updating, statements that are sensitive to these signals must be executed, and any new events that result from these statements must then be queued and executed as well. The steps taken to evaluate the design without advancing simulation time are referred to as "delta times" or just "deltas."

The diagram below represents the process for VHDL designs. This process continues until the end of simulation time.



This mechanism in event-based simulators may cause unexpected results. Consider the following code snippet:

```

clk2 <= clk;

process (rst, clk)
begin
  if(rst = '0')then
    s0 <= '0';
  elsif(clk'event and clk='1') then
    s0 <= inp;
  end if;
end process;

process (rst, clk2)
begin
  if(rst = '0')then
    s1 <= '0';
  elsif(clk2'event and clk2='1') then
    s1 <= s0;
  end if;
end process;
  
```

In this example you have two synchronous processes, one triggered with *clk* and the other with *clk2*. To your surprise, the signals change in the *clk2* process on the same edge as they are set in the *clk* process. As a result, the value of *inp* appears at *s1* rather than *s0*.

Here is what's happening. During simulation an event on *clk* occurs (from the testbench). From this event ModelSim performs the "*clk2 <= clk*" assignment and the process which is sensitive to *clk*. Before advancing the simulation time, ModelSim finds that the process sensitive to *clk2* can also be run. Since there are no delays present, the effect is that the value of *inp* appears at *s1* in the same simulation cycle.

In order to get the expected results, you must do one of the following:

- Insert a delay at every output
- Make certain to use the same clock
- Insert a delta delay

To insert a delta delay, you would modify the code like this:

```
process (rst, clk)
begin
    if(rst = '0')then
        s0 <= '0';
    elsif(clk'event and clk='1') then
        s0 <= inp;
        s0_delayed <= s0;
    end if;
end process;

process (rst, clk2)
begin
    if(rst = '0')then
        s1 <= '0';
    elsif(clk2'event and clk2='1') then
        s1 <= s0_delayed;
    end if;
end process;
```

The best way to debug delta delay problems is observe your signals in the List window. There you can see how values change at each delta time.

### **Detecting infinite zero-delay loops**

If a large number of deltas occur without advancing time, it is usually a symptom of an infinite zero-delay loop in the design. In order to detect the presence of these loops, ModelSim defines a limit, the "iteration limit", on the number of successive deltas that can occur. When ModelSim reaches the iteration limit, it issues a warning message.

The iteration limit default value is 1000. If you receive an iteration limit warning, first increase the iteration limit and try to continue simulation. You can set the iteration limit from the **Simulate > Simulation Options** menu, by modifying the *modelsim.ini* file, or by setting a Tcl variable called **IterationLimit** (UM-374). See "["Preference variables located in INI files"](#) (UM-369) for more information on modifying the *modelsim.ini* file.

If the problem persists, look for zero-delay loops. Run the simulation and look at the source code when the error occurs. Use the step button to step through the code and see which signals or variables are continuously oscillating. Two common causes are a loop that has no exit, or a series of gates with zero delay where the outputs are connected back to the inputs.

## Using the TextIO package

To access the routines in TextIO, include the following statement in your VHDL source code:

```
USE std.textio.all;
```

A simple example using the package TextIO is:

```
USE std.textio.all;
ENTITY simple_textio IS
END;

ARCHITECTURE simple_behavior OF simple_textio IS
BEGIN
PROCESS
  VARIABLE i: INTEGER:= 42;
  VARIABLE LLL: LINE;
BEGIN
  WRITE (LLL, i);
  WRITELINE (OUTPUT, LLL);
  WAIT;
END PROCESS;
END simple_behavior;
```

### Syntax for file declaration

The VHDL'87 syntax for a file declaration is:

```
file identifier : subtype_indication is [ mode ] file_logical_name ;
```

where "file\_logical\_name" must be a string expression.

In newer versions of the 1076 spec, syntax for a file declaration is:

```
file identifier_list : subtype_indication [ file_open_information ] ;
```

where "file\_open\_information" is:

```
[open file_open_kind_expression] is file_logical_name
```

You can specify a full or relative path as the file\_logical\_name; for example (VHDL'87):

Normally if a file is declared within an architecture, process, or package, the file is opened when you start the simulator and is closed when you exit from it. If a file is declared in a subprogram, the file is opened when the subprogram is called and closed when execution RETURNS from the subprogram. Alternatively, the opening of files can be delayed until the first read or write by setting the **DelayFileOpen** variable in the *modelsim.ini* file. Also, the number of concurrently open files can be controlled by the **ConcurrentFileLimit** variable. These variables help you manage a large number of files during simulation. See *Appendix A - ModelSim variables* for more details.

## Using STD\_INPUT and STD\_OUTPUT within ModelSim

The standard VHDL'87 TextIO package contains the following file declarations:

```
file input: TEXT is in "STD_INPUT";
file output: TEXT is out "STD_OUTPUT";
```

Updated versions of the TextIO package contain these file declarations:

```
file input: TEXT open read_mode is "STD_INPUT";
file output: TEXT open write_mode is "STD_OUTPUT";
```

STD\_INPUT is a file\_logical\_name that refers to characters that are entered interactively from the keyboard, and STD\_OUTPUT refers to text that is displayed on the screen.

In ModelSim, reading from the STD\_INPUT file allows you to enter text into the current buffer from a prompt in the Main window. The lines written to the STD\_OUTPUT file appear in the Main window transcript.

## TextIO implementation issues

### Writing strings and aggregates

A common error in VHDL source code occurs when a call to a WRITE procedure does not specify whether the argument is of type STRING or BIT\_VECTOR. For example, the VHDL procedure:

```
WRITE (L, "hello");
```

will cause the following error:

```
ERROR: Subprogram "WRITE" is ambiguous.
```

In the TextIO package, the WRITE procedure is overloaded for the types STRING and BIT\_VECTOR. These lines are reproduced here:

```
procedure WRITE(L: inout LINE; VALUE: in BIT_VECTOR;
JUSTIFIED: in SIDE:= RIGHT; FIELD: in WIDTH := 0);

procedure WRITE(L: inout LINE; VALUE: in STRING;
JUSTIFIED: in SIDE:= RIGHT; FIELD: in WIDTH := 0);
```

The error occurs because the argument "hello" could be interpreted as a string or a bit vector, but the compiler is not allowed to determine the argument type until it knows which function is being called.

The following procedure call also generates an error:

```
WRITE (L, "010101");
```

This call is even more ambiguous, because the compiler could not determine, even if allowed to, whether the argument "010101" should be interpreted as a string or a bit vector.

There are two possible solutions to this problem:

- Use a qualified expression to specify the type, as in:

```
WRITE (L, string'("hello"));
```

- Call a procedure that is not overloaded, as in:

```
WRITE_STRING (L, "hello");
```

The WRITE\_STRING procedure simply defines the value to be a STRING and calls the WRITE procedure, but it serves as a shell around the WRITE procedure that solves the overloading problem. For further details, refer to the WRITE\_STRING procedure in the io\_utils package, which is located in the file <install\_dir>/modeltech/examples/*io\_utils.vhd*.

## Reading and writing hexadecimal numbers

The reading and writing of hexadecimal numbers is not specified in standard VHDL. The Issues Screening and Analysis Committee of the VHDL Analysis and Standardization Group (ISAC-VASG) has specified that the TextIO package reads and writes only decimal numbers.

To expand this functionality, ModelSim supplies hexadecimal routines in the package `io_utils`, which is located in the file `<install_dir>/modeltech/examples/io_utils.vhd`. To use these routines, compile the `io_utils` package and then include the following use clauses in your VHDL source code:

```
use std.textio.all;
use work.io_utils.all;
```

## Dangling pointers

Dangling pointers are easily created when using the TextIO package, because WRITELINE de-allocates the access type (pointer) that is passed to it. Following are examples of good and bad VHDL coding styles:

**Bad VHDL** (because L1 and L2 both point to the same buffer):

```
READLINE (infile, L1);      -- Read and allocate buffer
L2 := L1;                  -- Copy pointers
WRITELINE (outfile, L1);   -- Deallocate buffer
```

**Good VHDL** (because L1 and L2 point to different buffers):

```
READLINE (infile, L1);      -- Read and allocate buffer
L2 := new string'(L1.all);  -- Copy contents
WRITELINE (outfile, L1);   -- Deallocate buffer
```

## The ENDLINE function

The ENDLINE function described in the *IEEE Standard VHDL Language Reference Manual, IEEE Std 1076-1987* contains invalid VHDL syntax and cannot be implemented in VHDL. This is because access types must be passed as variables, but functions only allow constant parameters.

Based on an ISAC-VASG recommendation the ENDLINE function has been removed from the TextIO package. The following test may be substituted for this function:

```
(L = NULL) OR (L'LENGTH = 0)
```

## The ENDFILE function

In the *VHDL Language Reference Manuals*, the ENDFILE function is listed as:

```
-- function ENDFILE (L: in TEXT) return BOOLEAN;
```

As you can see, this function is commented out of the standard TextIO package. This is because the ENDFILE function is implicitly declared, so it can be used with files of any type, not just files of type TEXT.

## Using alternative input/output files

You can use the TextIO package to read and write to your own files. To do this, just declare an input or output file of type TEXT. For example, for an input file:

The VHDL'87 declaration is:

```
file myinput : TEXT is in "pathname.dat";
```

The VHDL'93 declaration is:

```
file myinput : TEXT open read_mode is "pathname.dat";
```

Then include the identifier for this file ("myinput" in this example) in the READLINE or WRITELINE procedure call.

## Flushing the TEXTIO buffer

Flushing of the TEXTIO buffer is controlled by the [UnbufferedOutput](#) (UM-376) variable in the *modelsim.ini* file.

## Providing stimulus

You can stimulate and test a design by reading vectors from a file, using them to drive values onto signals, and testing the results. A VHDL test bench has been included with the ModelSim install files as an example. Check for this file:

```
<install_dir>/modeltech/examples/stimulus.vhd
```

## VITAL specification and source code

### VITAL ASIC Modeling Specification

The IEEE 1076.4 VITAL ASIC Modeling Specification is available from the Institute of Electrical and Electronics Engineers, Inc.:

IEEE Customer Service  
445 Hoes Lane  
Piscataway, NJ 08854-1331  
Tel: (732) 981-0060  
Fax: (732) 981-1721  
home page: <http://www.ieee.org>

### VITAL source code

The source code for VITAL packages is provided in the `/<install_dir>/vhdl_src/vital22b`, `/vital95`, or `/vital2000` directories.

## VITAL packages

VITAL 1995 accelerated packages are pre-compiled into the **ieee** library in the installation directory. VITAL 2000 accelerated packages are pre-compiled into the **vital2000** library. If you need to use the newer library, you'll need to add a **use** clause to your VHDL code to access the VITAL 2000 packages. For example:

```
LIBRARY vital2000;
USE vital2000.all
```

## ModelSim VITAL compliance

A simulator is VITAL compliant if it implements the SDF mapping and if it correctly simulates designs using the VITAL packages, as outlined in the VITAL Model Development Specification. ModelSim is compliant with the IEEE 1076.4 VITAL ASIC Modeling Specification. In addition, ModelSim accelerates the **VITAL\_Timing**, **VITAL\_Primitives**, and **VITAL\_memory** packages. The optimized procedures are functionally equivalent to the IEEE 1076.4 VITAL ASIC Modeling Specification (VITAL 1995 and 2000).

### VITAL compliance checking

If you are using VITAL 2.2b, you must turn off the compliance checking either by not setting the attributes, or by invoking **vcom** (CR-167) with the option **-novitalcheck**.

## Compiling and simulating with accelerated VITAL packages

**vcom** (CR-167) automatically recognizes that a VITAL function is being referenced from the **ieee** library and generates code to call the optimized built-in routines.

Invoke with the **-novital** option if you do not want to use the built-in VITAL routines (when debugging for instance). To exclude all VITAL functions, use **-novital all**:

```
vcom -novital all design.vhd
```

To exclude selected VITAL functions, use one or more **-novital <fname>** options:

```
vcom -novital VitalTimingCheck -novital VitalAND design.vhd
```

The **-novital** switch only affects calls to VITAL functions from the design units currently being compiled. Pre-compiled design units referenced from the current design units will still call the built-in functions unless they too are compiled with the **-novital** option.

ModelSim VITAL built-ins will be updated in step with new releases of the VITAL packages.

## Util package

The util package, included in ModelSim versions 5.5 and later, serves as a container for various VHDL utilities. The package is part of the `modelsim_lib` library which is located in the modeltech tree and is mapped in the default `modelsim.ini` file.

To access the utilities in the package, you would add lines like the following to your VHDL code:

```
library modelsim_lib;
use modelsim_lib.util.all;
```

### get\_resolution

`get_resolution` returns the current simulator resolution as a real number. For example, 1 femtosecond corresponds to 1e-15.

#### Syntax

```
resval := get_resolution;
```

#### Returns

| Name   | Type | Description                                    |
|--------|------|------------------------------------------------|
| resval | real | The simulator resolution represented as a real |

#### Arguments

None

#### Related functions

[to\\_real\(\)](#) (UM-75)

[to\\_time\(\)](#) (UM-76)

#### Example

If the simulator resolution is set to 10ps, and you invoke the command:

```
resval := get_resolution;
```

the value returned to resval would be 1e-11.

## **init\_signal\_driver()**

The init\_signal\_driver() procedure drives the value of a VHDL signal or Verilog net onto an existing VHDL signal or Verilog net. This allows you to drive signals or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench).

See [init\\_signal\\_driver](#) (UM-295) in *Chapter 9 - Signal Spy* for complete details.

## **init\_signal\_spy()**

The init\_signal\_spy() utility mirrors the value of a VHDL signal or Verilog register/net onto an existing VHDL signal or Verilog register. This allows you to reference signals, registers, or nets at any level of hierarchy from within a VHDL architecture (e.g., a testbench).

See [init\\_signal\\_spy](#) (UM-298) in *Chapter 9 - Signal Spy* for complete details.

## **signal\_force()**

The signal\_force() procedure forces the value specified onto an existing VHDL signal or Verilog register or net. This allows you to force signals, registers, or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench). A signal\_force works the same as the **force** command (CR-90) with the exception that you cannot issue a repeating force.

See [signal\\_force](#) (UM-300) in *Chapter 9 - Signal Spy* for complete details.

## **signal\_release()**

The signal\_release() procedure releases any force that was applied to an existing VHDL signal or Verilog register or net. This allows you to release signals, registers, or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench). A signal\_release works the same as the **norelease** command (CR-110).

See [signal\\_release](#) (UM-302) in *Chapter 9 - Signal Spy* for complete details.

**to\_real()**

`to_real()` converts the physical type time value into a real value with respect to the current simulator resolution. The precision of the converted value is determined by the simulator resolution. For example, if you were converting 1900 fs to a real and the simulator resolution was ps, then the real value would be 2.0 (i.e., 2 ps).

**Syntax**

```
realval := to_real(timeval);
```

**Returns**

| Name    | Type | Description                                                                   |
|---------|------|-------------------------------------------------------------------------------|
| realval | real | The time value represented as a real with respect to the simulator resolution |

**Arguments**

| Name    | Type | Description                         |
|---------|------|-------------------------------------|
| timeval | time | The value of the physical type time |

**Related functions**

[get\\_resolution](#) (UM-73)

[to\\_time\(\)](#) (UM-76)

**Example**

If the simulator resolution is set to ps, and you enter the following function:

```
realval := to_real(12.99 ns);
```

then the value returned to `realval` would be 12990.0. If you wanted the returned value to be in units of nanoseconds (ns) instead, you would use the [get\\_resolution](#) (UM-73) function to recalculate the value:

```
realval := 1e+9 * (to_real(12.99 ns)) * get_resolution();
```

If you wanted the returned value to be in units of femtoseconds (fs), you would enter the function this way:

```
realval := 1e+15 * (to_real(12.99 ns)) * get_resolution();
```

**to\_time()**

`to_time()` converts a real value into a time value with respect to the current simulator resolution. The precision of the converted value is determined by the simulator resolution. For example, if you were converting 5.9 to a time and the simulator resolution was ps, then the time value would be 6 ps.

**Syntax**

```
timeval := to_time(realval);
```

**Returns**

| Name    | Type | Description                                                                                 |
|---------|------|---------------------------------------------------------------------------------------------|
| timeval | time | The real value represented as a physical type time with respect to the simulator resolution |

**Arguments**

| Name    | Type | Description                |
|---------|------|----------------------------|
| realval | real | The value of the type real |

**Related functions**

[get\\_resolution](#) (UM-73)

[to\\_real\(\)](#) (UM-75)

**Example**

If the simulator resolution is set to ps, and you enter the following function:

```
timeval := to_time(72.49);
```

then the value returned to timeval would be 72 ps.

## Modeling memory

As a VHDL user, you might be tempted to model a memory using signals. Two common simulator problems are the likely result:

- You may get a "memory allocation error" message, which typically means the simulator ran out of memory and failed to allocate enough storage.
- Or, you may get very long load, elaboration, or run times.

These problems are usually explained by the fact that signals consume a substantial amount of memory (many dozens of bytes per bit), all of which needs to be loaded or initialized before your simulation starts.

Modeling memory with variables instead provides some excellent performance benefits:

- storage required to model the memory can be reduced by 1-2 orders of magnitude
- startup and run times are reduced
- associated memory allocation errors are eliminated

In the example below, we illustrate three alternative architectures for entity "memory".

Architecture "style\_87\_bad" uses a vhdl signal to store the ram data. Architecture "style\_87" uses variables in the "memory" process, and architecture "style\_93" uses variables in the architecture.

For large memories, architecture "style\_87\_bad" runs many times longer than the other two, and uses much more memory. This style should be avoided.

Both architectures "style\_87" and "style\_93" work with equal efficiency. You'll find some additional flexibility with the VHDL 1993 style, however, because the ram storage can be shared between multiple processes. For example, a second process is shown that initializes the memory; you could add other processes to create a multi-ported memory.

To implement this model, you will need functions that convert vectors to integers. To use it you will probably need to convert integers to vectors.

Example functions are provided below in package "conversions".

```

library ieee;
use ieee.std_logic_1164.all;
use work.conversions.all;

entity memory is
    generic(add_bits : integer := 12;
            data_bits : integer := 32);
    port(add_in : in std_ulogic_vector(add_bits-1 downto 0);
         data_in : in std_ulogic_vector(data_bits-1 downto 0);
         data_out : out std_ulogic_vector(data_bits-1 downto 0);
         cs, mwrite : in std_ulogic;
         do_init : in std_ulogic);
    subtype word is std_ulogic_vector(data_bits-1 downto 0);
    constant nwords : integer := 2 ** add_bits;
    type ram_type is array(0 to nwords-1) of word;
end;

architecture style_93 of memory is
-----
shared variable ram : ram_type;
-----
begin
memory:

```

```

process (cs)
    variable address : natural;
begin
    if rising_edge(cs) then
        address := sulp_to_natural(add_in);
        if (mwrite = '1') then
            ram(address) := data_in;
        end if;
        data_out <= ram(address);
    end if;
end process memory;
-- illustrates a second process using the shared variable
initialize:
process (do_init)
    variable address : natural;
begin
    if rising_edge(do_init) then
        for address in 0 to nwords-1 loop
            ram(address) := data_in;
        end loop;
    end if;
end process initialize;
end architecture style_93;

architecture style_87 of memory is
begin
memory:
process (cs)
-----
variable ram : ram_type;
-----
variable address : natural;
begin
    if rising_edge(cs) then
        address := sulp_to_natural(add_in);
        if (mwrite = '1') then
            ram(address) := data_in;
        end if;
        data_out <= ram(address);
    end if;
end process;
end style_87;

architecture bad_style_87 of memory is
-----
signal ram : ram_type;
-----
begin
memory:
process (cs)
    variable address : natural := 0;
begin
    if rising_edge(cs) then
        address := sulp_to_natural(add_in);
        if (mwrite = '1') then
            ram(address) <= data_in;
            data_out <= data_in;
        else
            data_out <= ram(address);
        end if;
    end if;
end process;
end bad_style_87;

```

```

-----
-----
library ieee;
use ieee.std_logic_1164.all;

package conversions is
    function sulp_to_natural(x : std_ulogic_vector) return
        natural;
    function natural_to_sulp(n, bits : natural) return
        std_ulogic_vector;
end conversions;

package body conversions is

    function sulp_to_natural(x : std_ulogic_vector) return
        natural is
        variable n : natural := 0;
        variable failure : boolean := false;
    begin
        assert (x'high - x'low + 1) <= 31
            report "Range of sulp_to_natural argument exceeds
                natural range"
            severity error;
        for i in x'range loop
            n := n * 2;
            case x(i) is
                when '1' | 'H' => n := n + 1;
                when '0' | 'L' => null;
                when others      => failure := true;
            end case;
        end loop;
        assert not failure
            report "sulp_to_natural cannot convert indefinite
                std_ulogic_vector"
            severity error;

        if failure then
            return 0;
        else
            return n;
        end if;
    end sulp_to_natural;

    function natural_to_sulp(n, bits : natural) return
        std_ulogic_vector is
        variable x : std_ulogic_vector(bits-1 downto 0) :=
            (others => '0');
        variable tempn : natural := n;
    begin
        for i in x'reverse_range loop
            if (tempn mod 2) = 1 then
                x(i) := '1';
            end if;
            tempn := tempn / 2;
        end loop;
        return x;
    end natural_to_sulp;

end conversions;

```

## Affecting performance by cancelling scheduled events

Performance will suffer if events are scheduled far into the future but then cancelled before they take effect. This situation will act like a memory leak and slow down simulation.

In VHDL this situation can occur several ways. The most common are waits with time-out clauses and projected waveforms in signal assignments.

The following code shows a wait with a time-out:

```
signals synch : bit := '0';
...
p: process
begin
    wait for 10 ms until synch = 1;
end process;

synch <= not synch after 10 ns;
```

At time 0, process *p* makes an event for time 10ms. When *synch* goes to 1 at 10 ns, the event at 10 ms is marked as cancelled but not deleted, and a new event is scheduled at 10ms + 10ns. The cancelled events are not reclaimed until time 10ms is reached and the cancelled event is processed. As a result there will be 500000 (10ms/20ns) cancelled but undeleted events. Once 10ms is reached, memory will no longer increase because the simulator will be reclaiming events as fast as they are added.

For projected waveforms the following would behave the same way:

```
signals synch : bit := '0';
...
p: process(synch)
begin
    output <= '0', '1' after 10ms;
end process;

synch <= not synch after 10 ns;
```

## Converting an integer into a bit\_vector

The following code demonstrates how to convert an integer into a bit\_vector.

```
library ieee;
use ieee.numeric_bit.ALL;

entity test is
end test;

architecture only of test is
    signal s1 : bit_vector(7 downto 0);
    signal int : integer := 45;
begin
    p:process
    begin
        wait for 10 ns;
        s1 <= bit_vector(to_signed(int,8));
    end process p;
end only;
```



# 5 - Verilog simulation

---

## Chapter contents

|                                                     |        |
|-----------------------------------------------------|--------|
| Introduction . . . . .                              | UM-84  |
| Compilation . . . . .                               | UM-85  |
| Incremental compilation . . . . .                   | UM-86  |
| Library usage . . . . .                             | UM-88  |
| Verilog-XL compatible compiler arguments . . . . .  | UM-90  |
| Verilog-XL `uselib compiler directive . . . . .     | UM-91  |
| Verilog configurations . . . . .                    | UM-92  |
| Simulation . . . . .                                | UM-93  |
| Invoking the simulator . . . . .                    | UM-93  |
| Simulator resolution limit . . . . .                | UM-94  |
| Event ordering in Verilog designs . . . . .         | UM-96  |
| Negative timing check limits . . . . .              | UM-100 |
| Verilog-XL compatible simulator arguments . . . . . | UM-103 |
| Cell libraries . . . . .                            | UM-103 |
| SDF timing annotation . . . . .                     | UM-104 |
| Delay modes . . . . .                               | UM-104 |
| System tasks . . . . .                              | UM-106 |
| IEEE Std 1364 system tasks . . . . .                | UM-106 |
| Verilog-XL compatible system tasks . . . . .        | UM-109 |
| ModelSim Verilog system tasks . . . . .             | UM-111 |
| Compiler directives . . . . .                       | UM-112 |
| IEEE Std 1364 compiler directives . . . . .         | UM-112 |
| Verilog-XL compatible compiler directives . . . . . | UM-113 |

## Introduction

This chapter describes how to compile and simulate Verilog designs with ModelSim Verilog. ModelSim Verilog implements the Verilog language as defined by the IEEE Standards 1364-1995 and 1364-2001. We recommend that you obtain these specifications for reference.

In addition to the functionality described in the IEEE Std 1364, ModelSim Verilog includes the following features:

- Standard Delay Format (SDF) annotator compatible with many ASIC and FPGA vendors' Verilog libraries
- Value Change Dump (VCD) file extensions for ASIC vendor test tools
- Dynamic loading of PLI/VPI applications (see *Chapter 6 - Verilog PLI / VPI*)
- Compilation into retargetable, executable code
- Incremental design compilation
- Extensive support for mixing VHDL and Verilog in the same design (including SDF annotation)
- Graphic Interface that is common with ModelSim VHDL
- Extensions to provide compatibility with Verilog-XL

The following functionality is partially implemented in ModelSim Verilog:

- Verilog Procedural Interface (VPI) (see `/<install_dir>/modeltech/docs/technotes/Verilog_VPI.note` for details)
- System Verilog 3.1, Accellera's Extensions to Verilog® (see `/<install_dir>/modeltech/docs/technotes/sysvlog.note` for implementation details)

Many of the examples in this chapter are shown from the command line. For compiling and simulating within a project or ModelSim's GUI see:

- [Getting started with projects](#) (UM-24)
- [Compiling with the graphic interface](#) (UM-265)
- [Simulating with the graphic interface](#) (UM-272)

# Compilation

Before you can simulate a Verilog design, you must first create a library and compile the Verilog source code into that library. This section provides detailed information on compiling Verilog designs. For information on creating a design library, see [Chapter 3 - Design libraries](#).

The ModelSim Verilog compiler, **vlog**, compiles Verilog source code into retargetable, executable code, meaning that the library format is compatible across all supported platforms and that you can simulate your design on any platform without having to recompile your design specifically for that platform. As you compile your design, the resulting object code for modules and UDPs is generated into a library. By default, the compiler places results into the work library. You can specify an alternate library with the **-work** argument. The following is a simple example of how to create a work library, compile a design, and simulate it:

**Contents of top.v:**

```
module top;
    initial $display("Hello world");
endmodule
```

**Create the work library:**

```
% vlib work
```

**Compile the design:**

```
% vlog top.v
-- Compiling module top
```

```
Top level modules:
top
```

**View the contents of the work library (optional):**

```
% vdir
MODULE top
```

**Simulate the design:**

```
% vsim -c top
# Loading work.top
VSIM 1> run -all
# Hello world
VSIM 2> quit
```

In this example, the simulator was run without the graphic interface by specifying the **-c** argument. After the design was loaded, the simulator command **run -all** was entered, meaning to simulate until there are no more simulator events. Finally, the quit command was entered to exit the simulator. By default, a log of the simulation is written to the *transcript* file in the current directory.

## Incremental compilation

By default, ModelSim Verilog supports incremental compilation of designs, thus saving compilation time when you modify your design. Unlike other Verilog simulators, there is no requirement that you compile the entire design in one invocation of the compiler.

You are not required to compile your design in any particular order because all module and UDP instantiations and external hierarchical references are resolved when the design is loaded by the simulator. Incremental compilation is made possible by deferring these bindings, and as a result some errors cannot be detected during compilation. Commonly, these errors include: modules that were referenced but not compiled, incorrect port connections, and incorrect hierarchical references.

The following example shows how a hierarchical design can be compiled in top-down order:

### Contents of top.v:

```
module top;
    or2 or2_i (n1, a, b);
    and2 and2_i (n2, n1, c);
endmodule
```

### Contents of and2.v:

```
module and2(y, a, b);
    output y;
    input a, b;
    and(y, a, b);
endmodule
```

### Contents of or2.v:

```
module or2(y, a, b);
    output y;
    input a, b;
    or(y, a, b);
endmodule
```

Compile the design in top down order (assumes work library already exists):

```
% vlog top.v
-- Compiling module top

Top level modules:
top
% vlog and2.v
-- Compiling module and2

Top level modules:
and2
% vlog or2.v
-- Compiling module or2

Top level modules:
or2
```

Note that the compiler lists each module as a top level module, although, ultimately, only *top* is a top-level module. If a module is not referenced by another module compiled in the same invocation of the compiler, then it is listed as a top level module. This is just an

informative message and can be ignored during incremental compilation. The message is more useful when you compile an entire design in one invocation of the compiler and need to know the top-level module names for the simulator. For example,

```
% vlog top.v and2.v or2.v
-- Compiling module top
-- Compiling module and2
-- Compiling module or2

Top level modules:
top
```

The most efficient method of incremental compilation is to manually compile only the modules that have changed. This is not always convenient, especially if your source files have compiler directive interdependencies (such as macros). In this case, you may prefer to always compile your entire design in one invocation of the compiler. If you specify the **-incr** argument, the compiler will automatically determine which modules have changed and generate code only for those modules. This is not as efficient as manual incremental compilation because the compiler must scan all of the source code to determine which modules must be compiled.

The following is an example of how to compile a design with automatic incremental compilation:

```
% vlog -incr top.v and2.v or2.v
-- Compiling module top
-- Compiling module and2
-- Compiling module or2

Top level modules:
top
```

Now, suppose that you modify the functionality of the *or2* module:

```
% vlog -incr top.v and2.v or2.v
-- Skipping module top
-- Skipping module and2
-- Compiling module or2

Top level modules:
top
```

The compiler informs you that it skipped the modules *top* and *and2*, and compiled *or2*.

Automatic incremental compilation is intelligent about when to compile a module. For example, changing a comment in your source code does not result in a recompile; however, changing the compiler command line arguments results in a recompile of all modules.

- ▶ **Note:** Changes to your source code that do not change functionality but that do affect source code line numbers (such as adding a comment line) *will* cause all affected modules to be recompiled. This happens because debug information must be kept current so that ModelSim can trace back to the correct areas of the source code.

## Library usage

All modules and UDPs in a Verilog design must be compiled into one or more libraries. One library is usually sufficient for a simple design, but you may want to organize your modules into various libraries for a complex design. If your design uses different modules having the same name, then you are required to put those modules in different libraries because design unit names must be unique within a library.

The following is an example of how you may organize your ASIC cells into one library and the rest of your design into another:

```
% vlib work
% vlib asiclib
% vlog -work asiclib and2.v or2.v
-- Compiling module and2
-- Compiling module or2

Top level modules:
  and2
  or2
% vlog top.v
-- Compiling module top

Top level modules:
  top
```

Note that the first compilation uses the **-work asiclib** argument to instruct the compiler to place the results in the **asiclib** library rather than the default **work** library.

### **Library search rules**

Since instantiation bindings are not determined at compile time, you must instruct the simulator to search your libraries when loading the design. The top-level modules are loaded from the library named **work** unless you prefix the modules with the **<library>** option. All other Verilog instantiations are resolved in the following order:

- Search libraries specified with **-Lf** arguments in the order they appear on the command line.
- Search the library specified in the "[Verilog-XL `uselib compiler directive](#)" (UM-91).
- Search libraries specified with **-L** arguments in the order they appear on the command line.
- Search the **work** library.
- Search the library explicitly named in the special escaped identifier instance name.

### Handling sub-modules with common names

The work library is not necessarily a library named **work**—rather, the **work** library refers to the library containing the module that instantiates the module or UDP that is currently being searched for. This definition is useful if you have hierarchical modules organized into separate libraries, and you have commonly-named sub-modules in the libraries that have different definitions. This may happen if you are using vendor-supplied libraries. For example, say you have the following:



*cellX* in *lib1* is defined differently than *cellX* in *lib2*. In this situation, you would specify **-L work** first in the search library arguments: **-L work -L lib1 -L lib2**. If you just specify **-L libA -L libB**, instantiations of *cellX* from *modB* resolve to the *modA* version of *cellX*.

## Verilog-XL compatible compiler arguments

The compiler arguments listed below are equivalent to Verilog-XL arguments and may ease the porting of a design to ModelSim. See the [vlog command \(CR-204\)](#) for a description of each argument.

```
+define+<macro_name>[=<macro_text>]
+delay_mode_distributed
+delay_mode_path
+delay_mode_unit
+delay_mode_zero
-f <filename>
+incdir+<directory>
+mindelays
+maxdelays
+nowarn<mnemonic>
+typdelays
-u
```

### ***Arguments supporting source libraries***

The compiler arguments listed below support source libraries in the same manner as Verilog-XL. See the [vlog command \(CR-204\)](#) for a description of each argument.

Note that these source libraries are very different from the libraries that the ModelSim compiler uses to store compilation results. You may find it convenient to use these arguments if you are porting a design to ModelSim or if you are familiar with these arguments and prefer to use them.

Source libraries are searched after the source files on the command line are compiled. If there are any unresolved references to modules or UDPs, then the compiler searches the source libraries to satisfy them. The modules compiled from source libraries may in turn have additional unresolved references that cause the source libraries to be searched again. This process is repeated until all references are resolved or until no new unresolved references are found. Source libraries are searched in the order they appear on the command line.

```
-v <filename>
-y <directory>
+libext+<suffix>
+librescan
+nolibcell
-R [<simargs>]
```

## Verilog-XL `uselib compiler directive

The `uselib compiler directive is an alternative source library management scheme to the -v, -y, and +libext compiler arguments. It has the advantage that a design may reference different modules having the same name. You compile designs that contain `uselib directive statements using the **-compile\_uselibs** argument (described below) to [vlog](#) (CR-204).

The syntax for the `uselib directive is:

```
`uselib <library_reference>...
```

where <library\_reference> is:

```
dir=<library_directory> | file=<library_file> | libext=<file_extension> |
lib=<library_name>
```

The library references are equivalent to command line arguments as follows:

```
dir=<library_directory> -y <library_directory>
file=<library_file> -v <library_file>
libext=<file_extension> +libext+<file_extension>
```

For example, the following directive

```
`uselib dir=/h/vendorA libext=.v
```

is equivalent to the following command line arguments:

```
-y /h/vendorA +libext+.v
```

Since the `uselib directives are embedded in the Verilog source code, there is more flexibility in defining the source libraries for the instantiations in the design. The appearance of a `uselib directive in the source code explicitly defines how instantiations that follow it are resolved, completely overriding any previous `uselib directives.

### **-compile\_uselibs argument**

Use the **-compile\_uselibs** argument to [vlog](#) (CR-204) to reference `uselib directives. The argument finds the source files referenced in the directive, compiles them into automatically created object libraries, and updates the *modelsim.ini* file with the logical mappings to the libraries.

When using **-compile\_uselibs**, ModelSim determines into which directory to compile the object libraries by choosing, in order, from the following three values:

- The directory name specified by the **-compile\_uselibs** argument. For example, `-compile_uselibs=../mydir`
- The directory specified by the MTL\_USELIB\_DIR environment variable (see "[Environment variables](#)" (UM-365))
- A directory named *mti\_uselibs* that is created in the current working directory

► **Note:** In ModelSim versions prior to 5.5, the library files referenced by the `uselib directive were not automatically compiled by ModelSim Verilog. To maintain backwards compatibility, this is still the default behavior when **-compile\_uselibs** is not used. See [www.model.com/support/documentation/BOOK/pre55\\_uselib.pdf](http://www.model.com/support/documentation/BOOK/pre55_uselib.pdf) for a description of the pre-5.5 implementation.

The following code fragment and compiler invocation show how two different modules that have the same name can be instantiated within the same design:

```
module top;
  `uselib dir=/h/vendorA libext=.v
  NAND2 u1(n1, n2, n3);
  `uselib dir=/h/vendorB libext=.v
  NAND2 u2(n4, n5, n6);
endmodule
```

This allows the NAND2 module to have different definitions in the vendorA and vendorB libraries.

### ***'uselib is persistent***

As mentioned above, the appearance of a **'uselib** directive in the source code explicitly defines how instantiations that follow it are resolved. This may result in unexpected consequences. For example, consider the following compile command:

```
vlog -compile_uselibs dut.v srtr.v
```

Assume that *dut.v* contains a **'uselib** directive. Since *srtr.v* is compiled after *dut.v*, the **'uselib** directive is still in effect. When *srtr* is loaded it is using the **'uselib** directive from *dut.v* to decide where to locate modules. If this is not what you intend, then you need to put an empty **'uselib** at the end of *dut.v* to "close" the previous **'uselib** statement.

## Verilog configurations

The Verilog 2001 spec added configurations. Configurations specify how a design is "assembled" during the elaboration phase of simulation. Configurations actually consist of two pieces: the library mapping and the configuration itself. The library mapping is used at compile time to determine into which libraries the source files are to be compiled. Here is an example of a simple library map file:

```
library work    ../top.v;
library rtlLib  lrm_ex_top.v;
library gateLib lrm_ex_adder.vg;
library aLib    lrm_ex_adder.v;
```

Here is an example of a library map file that uses **-incdir**:

```
library lib1 src_dir/*.v -incdir ../include_dir2, ..., my_incdir;
```

The name of the library map file is arbitrary. You specify the library map file using the **-libmap** argument to the **vlog** command (CR-204). Alternatively, you can specify the file name as the first item on the **vlog** command line, and the compiler will read it as a library map file.

The library map file must be compiled along with the Verilog source files. Multiple map files are allowed but each must be preceded by the **-libmap** argument.

The library map file and the configuration can exist in the same or different files. If they are separate, only the map file needs the **-libmap** argument. The configuration is treated as any other Verilog source file.

# Simulation

The ModelSim simulator can load and simulate both Verilog and VHDL designs, providing a uniform graphic interface and simulation control commands for debugging and analyzing your designs. The graphic interface and simulator commands are described elsewhere in this manual, while this section focuses specifically on Verilog simulation.

## Invoking the simulator

A Verilog design is ready for simulation after it has been compiled into one or more libraries. The simulator may then be invoked with the names of the top-level modules (many designs contain only one top level module). For example, if your top level modules are "testbench" and "globals", then invoke the simulator as follows:

```
vsim testbench globals
```

After the simulator loads the top-level modules, it iteratively loads the instantiated modules and UDPs in the design hierarchy, linking the design together by connecting the ports and resolving hierarchical references. By default all modules and UDPs are loaded from the library named **work**. Modules and UDPs from other libraries can be specified using the **-L** or **-Lf** arguments to **vsim** (see "[Library usage](#)" (UM-88) for details).

On successful loading of the design, the simulation time is set to zero, and you must enter a **run** command to begin simulation. Commonly, you enter **run -all** to run until there are no more simulation events or until **\$finish** is executed in the Verilog code. You can also run for specific time periods (e.g., **run 100 ns**). Enter the **quit** command to exit the simulator.

## Simulator resolution limit

The simulator internally represents time as a 64-bit integer in units equivalent to the smallest unit of simulation time, also known as the simulator resolution limit. The resolution limit defaults to the smallest time precision found among all of the `timescale compiler directives in the design. Here is an example of a `timescale directive:

```
`timescale 1 ns / 100 ps
```

The first number is the time units and the second number is the time precision. The directive above causes time values to be read as ns and to be rounded to the nearest 100 ps.

### Modules without timescale directives

You may encounter unexpected behavior if your design contains some modules with timescale directives and others without. The time units for modules without a timescale directive default to the simulator resolution. For example, say you have the two modules shown in the table below:

| Module 1                                                                                                                                                                                                                | Module 2                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>`timescale 1 ns / 10 ps  module mod1 (set);     output set;     reg set;     parameter d = 1.55;      initial     begin         set = 1'bz;         #d set = 1'b0;         #d set = 1'b1;     end  endmodule</pre> | <pre>module mod2 (set);      output set;     reg set;     parameter d = 1.55;      initial     begin         set = 1'bz;         #d set = 1'b0;         #d set = 1'b1;     end  endmodule</pre> |

If you invoke **vsim** as **vsim mod2 mod1** then Module 1 sets the simulator resolution to 10 ps. Module 2 has no timescale directive, so the time units default to the simulator resolution, in this case 10 ps. If you watched */mod1/set* and */mod2/set* in the Wave window, you'd see that in Module 1 it transitions every 1.55 ns as expected (because of the 1 ns time unit in the timescale directive). However, in Module 2, *set* transitions every 20 ps. That's because the delay of 1.55 in Module 2 is read as 15.5 ps and is rounded up to 20 ps.

In such cases ModelSim will issue the following warning message during elaboration:

```
** Warning: (vsim-3010) [TSCALE] - Module 'mod1' has a `timescale directive
in effect, but previous modules do not.
```

If you invoke **vsim** as `vsim mod1 mod2`, the simulation results would be the same but ModelSim would produce a different warning message:

```
** Warning: (vsim-3009) [TSCALE] - Module 'mod2' does not have a `timescale
directive in effect, but previous modules do.
```

These warnings should ALWAYS be investigated.

If the design contains no `timescale directives, then the resolution limit and time units default to the value specified by the **Resolution** (UM-375) variable in the modelsim.ini file. (The variable is set to 1 ps by default.)

### ***Multiple timescale directives***

As alluded to above, your design can have multiple timescale directives. The timescale directive takes effect where it appears in a source file and applies to all source files which follow in the same **vlog** (CR-204) command. Separately compiled modules can also have different timescales. The simulator determines the smallest timescale of all the modules in a design and uses that as the simulator resolution.

### ***'timescale, -t, and rounding***

The optional **vsim** argument **-t** sets the simulator resolution limit for the overall simulation. If the resolution set by **-t** is larger than the precision set in a module, the time values in that module are rounded up. If the resolution set by **-t** is smaller than the precision of the module, the precision of that module remains whatever is specified by the `timescale directive. Consider the following code:

```
`timescale 1 ns / 100 ps

module foo;

initial
#12.536 $display
```

The list below shows three possibilities for **-t** and how the delays in the module would be handled in each case:

- **-t** not set

The delay will be rounded to 12.5 as directed by the module's `timescale directive.

- **-t** is set to 1 fs

The delay will be rounded to 12.5. Again, the module's precision is determined by the `timescale directive. ModelSim does not override the module's precision.

- **-t** is set to 1 ns

The delay will be rounded to 12. The module's precision is determined by the **-t** setting. ModelSim has no choice but to round the module's time values because the entire simulation is operating at 1 ns.

### ***Choosing the resolution***

You should choose the coarsest resolution limit possible that does not result in undesired rounding of your delays. The time precision should not be unnecessarily small because it will limit the maximum simulation time limit, and it will degrade performance in some cases.

## Event ordering in Verilog designs

Event-based simulators such as ModelSim may process multiple events at a given simulation time. The Verilog language is defined such that you cannot explicitly control the order in which simultaneous events are processed. Unfortunately, some designs rely on a particular event order, and these designs may behave differently than you expect.

### **Event queues**

Section 5 of the IEEE Std 1364-1995 LRM defines several event queues that determine the order in which events are evaluated. At the current simulation time, the simulator has the following pending events:

- active events
- inactive events
- non-blocking assignment update events
- monitor events
- future events
  - inactive events
  - non-blocking assignment update events

The LRM dictates that events are processed as follows – 1) all active events are processed; 2) the inactive events are moved to the active event queue and then processed; 3) the non-blocking events are moved to the active event queue and then processed; 4) the monitor events are moved to the active queue and then processed; 5) simulation advances to the next time where there is an inactive event or a non-blocking assignment update event.

Within the active event queue, the events can be processed in any order, and new active events can be added to the queue in any order. In other words, you *cannot* control event order within the active queue. The example below illustrates potential ramifications of this situation.

Say you have these four statements:

- 1** always@(q) p = q;
- 2** always @ (q) p2 = not q;
- 3** always @(p or p2) clk = p and p2;
- 4** always @ (posedge clk)

and current values as follows: q = 0, p = 0, p2=1

The tables below show two of the many valid evaluations of these statements. Evaluation events are denoted by a number where the number is the statement to be evaluated. Update events are denoted  $\langle name \rangle (old \rightarrow new)$  where  $\langle name \rangle$  indicates the reg being updated and  $new$  is the updated value.

**Table 1: Evaluation 1**

| <b>Event being processed</b> | <b>Active event queue</b> |
|------------------------------|---------------------------|
|                              | $q(0 \rightarrow 1)$      |
| $q(0 \rightarrow 1)$         | 1, 2                      |
| 1                            | $p(0 \rightarrow 1), 2$   |
| $p(0 \rightarrow 1)$         | 3, 2                      |
| 3                            | $clk(0 \rightarrow 1), 2$ |
| $clk(0 \rightarrow 1)$       | 4, 2                      |
| 4                            | 2                         |
| 2                            | $p2(1 \rightarrow 0)$     |
| $p2(1 \rightarrow 0)$        | 3                         |
| 3                            | $clk(1 \rightarrow 0)$    |
| $clk(1 \rightarrow 0)$       | <empty>                   |

**Table 2: Evaluation 2**

| <b>Event being processed</b> | <b>Active event queue</b>                 |
|------------------------------|-------------------------------------------|
|                              | $q(0 \rightarrow 1)$                      |
| $q(0 \rightarrow 1)$         | 1, 2                                      |
| 1                            | $p(0 \rightarrow 1), 2$                   |
| 2                            | $p2(1 \rightarrow 0), p(0 \rightarrow 1)$ |
| $p(0 \rightarrow 1)$         | 3, $p2(1 \rightarrow 0)$                  |
| $p2(1 \rightarrow 0)$        | 3                                         |
| 3                            | <empty> ( $clk$ doesn't change)           |

Again, both evaluations are valid. However, in Evaluation 1,  $clk$  has a glitch on it; in Evaluation 2,  $clk$  doesn't. This indicates that the design has a zero-delay race condition on  $clk$ .

### **'Controlling' event queues with blocking/non-blocking assignments**

The only control you have over event order is to assign an event to a particular queue. You do this via blocking or non-blocking assignments.

#### **Blocking assignments**

Blocking assignments place an event in the active, inactive, or future queues depending on what type of delay they have:

- a blocking assignment without a delay goes in the active queue
- a blocking assignment with an explicit delay of 0 goes in the inactive queue
- a blocking assignment with a non-zero delay goes in the future queue

#### **Non-blocking assignments**

A non-blocking assignment goes into either the non-blocking assignment update event queue or the future non-blocking assignment update event queue. (Non-blocking assignments with no delays and those with explicit zero delays are treated the same.)

Non-blocking assignments should be used only for outputs of flip-flops. This insures that all outputs of flip-flops do not change until after all flip-flops have been evaluated.

Attempting to use non-blocking assignments in combinational logic paths to remove race conditions may only cause more problems. (In the preceding example, changing all statements to non-blocking assignments would not remove the race condition.) This includes using non-blocking assignments in the generation of gated clocks.

The following is an example of how to properly use non-blocking assignments.

```

gen1: always @(master)
      clk1 = master;

gen2: always @(clk1)
      clk2 = clk1;

f1 : always @(posedge clk1)
begin
  q1 <= d1;
end

f2:   always @(posedge clk2)
begin
  q2 <= q1;
end

```

If written this way, a value on *d1* always takes two clock cycles to get from *d1* to *q2*. If you change *clk1 = master* and *clk2 = clk1* to non-blocking assignments or *q2 <= q1* and *q1 <= d1* to blocking assignments, then *d1* may get to *q2* in less than two clock cycles.

#### **Debugging event order issues**

Since many models have been developed on Verilog-XL, ModelSim tries to duplicate Verilog-XL event ordering to ease the porting of those models to ModelSim. However, ModelSim does not match Verilog-XL event ordering in all cases, and if a model ported to ModelSim does not behave as expected, then you should suspect that there are event order dependencies.

ModelSim helps you track down event order dependencies with the following compiler arguments: **-compat**, **-hazards**, and **-keep\_delta**.

See the [vlog](#) command (CR-204) for descriptions of **-compat** and **-keep\_delta**.

### Hazard detection

The **-hazard** argument to **vsim** (CR-213) detects event order hazards involving simultaneous reading and writing of the same register in concurrently executing processes. **vsim** detects the following kinds of hazards:

- **WRITE/WRITE:**  
Two processes writing to the same variable at the same time.
- **READ/WRITE:**  
One process reading a variable at the same time it is being written to by another process. ModelSim calls this a READ/WRITE hazard if it executed the read first.
- **WRITE/READ:**  
Same as a READ/WRITE hazard except that ModelSim executed the write first.

**vsim** issues an error message when it detects a hazard. The message pinpoints the variable and the two processes involved. You can have the simulator break on the statement where the hazard is detected by setting the **break on assertion** level to **Error**.

To enable hazard detection you must invoke [vlog](#) (CR-204) with the **-hazards** argument when you compile your source code and you must also invoke **vsim** with the **-hazards** argument when you simulate.

 **Important:** Enabling **-hazards** implicitly enables the **-compat** argument. As a result, using this argument may affect your simulation results.

### Limitations of hazard detection

- Reads and writes involving bit and part selects of vectors are not considered for hazard detection. The overhead of tracking the overlap between the bit and part selects is too high.
- A WRITE/WRITE hazard is flagged even if the same value is written by both processes.
- A WRITE/READ or READ/WRITE hazard is flagged even if the write does not modify the variable's value.
- Glitches on nets caused by non-guaranteed event ordering are not detected.

## Negative timing check limits

Verilog supports negative limit values in the \$setuphold and \$recrem system tasks. These tasks have optional delayed versions of input signals to insure proper evaluation of models with negative timing check limits. Delay values for these delayed nets are determined by the simulator so that valid data is available for evaluation before a clocking signal.

### Example

```
$setuphold(posedge clk, negedge d, 5, -3, Notifier,,, clk_dly, d_dly);
```



ModelSim calculates the delay for signal *d\_dly* as 4 time units instead of 3. It does this to prevent *d\_dly* and *clk\_dly* from occurring simultaneously when a violation isn't reported.

ModelSim accepts negative limit checks by default, unlike current versions of Verilog-XL. To match Verilog-XL default behavior (i.e., zeroing all negative timing check limits), use the **+no\_neg\_tcheck** argument to **vsim** (CR-213).

### Negative timing constraint algorithm

The algorithm ModelSim uses to calculate delays for delayed nets isn't described in IEEE Std 1364. Rather, ModelSim matches Verilog-XL behavior. The algorithm attempts to find a set of delays so the data net is valid when the clock net transitions and the timing checks are satisfied. The algorithm is iterative because a set of delays can be selected that satisfies all timing checks for a pair of inputs but then causes mis-ordering of another pair (where both pairs of inputs share a common input). When a set of delays that satisfies all timing checks is found, the delays are said to converge.

When none of the delay sets cause convergence, the algorithm pessimistically changes the timing check limits to force convergence. Basically the algorithm zeroes the smallest negative \$setup/\$recovery limit. If a negative \$setup/\$recovery doesn't exist, then the algorithm zeros the smallest negative \$hold/\$removal limit. After zeroing a negative limit, the delay calculation procedure is repeated. If the delays don't converge, the algorithm zeros another negative limit, repeating the process until convergence is found.

A simple example will help clarify the algorithm. Assume you have the following timing checks:

```
$setuphold(posedge clk, posedge d, 3, -2, NOTIFIER,, clk_dly, d_dly);
$setuphold(posedge clk, negedge d, 6, -5, NOTIFIER,, clk_dly, d_dly);
$setuphold(posedge clk, posedge t, 20, -12, NOTIFIER,, clk_dly, t_dly);
$setuphold(posedge clk, negedge t, 18, -11, NOTIFIER,, clk_dly, t_dly);
```

The violation regions for t and d in this example are:



Note that the delays between *clk/clk\_dly*, *t/t\_dly*, and *d/d\_dly* are not edge sensitive, and they must be the same for both rising and falling transitions of *clk*, *t*, and *d*. A  $d \Rightarrow d_{dly}$  delay of 5 will satisfy the negedge case (transitions of *d* from 5 to 0 before *clk* won't be latched), but valid transitions of posedge *d*, in the region of 5 to 3 before *clk*, won't latch correctly. Therefore, to find convergence, the algorithm starts zeroing negative **\$hold** limits (-12, then -11, and then -5). The check limits on *t* are zeroed first because of their magnitude.

ModelSim will display messages when limits are zeroed if you use the **+ntc\_warn** argument. Even if you don't set **+ntc\_warn**, ModelSim displays a summary of any zeroed limits.

### ***Extending check limits without zeroing***

If zeroing limits is too pessimistic for your design, you can use the **vsim** (CR-213) arguments **-extend\_tcheck\_data\_limit** and **-extend\_tcheck\_ref\_limit** instead. These arguments cause a one-time extension of qualifying data or reference limits in an attempt to provide a solution prior to any limit zeroing. A limit qualifies if it bounds a violation region which does not overlap a related violation region.

An example will help illustrate. Assume you have the following timing checks:

```
$setuphold( posedge clk, posedge d, 45, 70, notifier,,dclk,dd);
$setuphold( posedge clk, negedge d, 216, -68, notifier,,dclk,dd);
```

The violation regions for d in this example are:



The delay net delay analysis in this case does not provide a solution. The required negative hold delay of 68 between *d* and *dd* could cause a non-violating posedge *d* transition to be delayed on *dd* so that it could arrive after *dclk* for functional evaluation. By default the -68 hold limit is set pessimistically to 0 to insure the correct functional evaluation.

Alternatively, you could use **-extend\_tcheck\_data\_limit** to overlap the regions. In this example we must specify the percentage by which to "decrease" the negative hold limit in order to overlap the positive setup limit. In other words, you must extend the 216, -68 region to 216, -44. You would calculate the percentage as follows:

- 1 Calculate the size of the negative edge violation region:

$$216 - 68 = 148$$

- 2 Calculate the gap between the negative hold limit and the positive setup limit and add one timing unit to allow for overlap:

$$68 - 45 = 23 + 1 = 24$$

- 3 Divide the gap size by the violation region size:

$$24 / 148 = .16$$

Hence, you would set **-extend\_tcheck\_data\_limit** to 16.

► **Note:** ModelSim will extend the limit only as far as is needed to derive a solution. So if you used 100 in the previous example, it would still only extend the limit 16 percent. Indeed, in some cases it may be easiest to select a large percentage number and not worry about an exact calculation.

### ***Using delayed inputs for timing checks***

By default ModelSim performs timing checks on inputs specified in the timing check. If you want timing checks performed on the delayed inputs, use the **+delayed\_timing\_checks** argument to vsim.

Consider an example. This timing check:

```
$setuphold(posedge clk, posedge t, 20, -12, NOTIFIER,,, clk_dly, t_dly);
```

reports a timing violation when posedge *t* occurs in the violation region:



With the **+delayed\_timing\_checks** argument, the violation region between the delayed inputs is:



Although the check is performed on the delayed inputs, the timing check violation message is adjusted to reference the undelayed inputs. Only the report time of the violation message is noticeably different between the delayed and undelayed timing checks.

By far the greatest difference between these modes is evident when there are conditions on a delayed check event because the condition is not implicitly delayed. Also, timing checks specified without explicit delayed signals are delayed, if necessary, when they reference an input that is delayed for a negative timing check limit.

## Verilog-XL compatible simulator arguments

The simulator arguments listed below are equivalent to Verilog-XL arguments and may ease the porting of a design to ModelSim. See the **vsim** command (CR-213) for a description of each argument.

```
+alt_path_delays
-l <filename>
+maxdelays
+mindelays
+multisource_int_delays
+no_cancelled_e_msg
+no_neg_tchk
+no_notifier
+no_path_edge
+no_pulse_msg
+no_show_cancelled_e
+nosdfwarn
+nowarn<mnemonic>
+ntc_warn
+pulse_e/<percent>
+pulse_e_style_ondetect
+pulse_e_style_onevent
+pulse_int_e/<percent>
+pulse_int_r/<percent>
+pulse_r/<percent>
+sdf_nocheck_celltype
+sdf_verbose
+show_cancelled_e
+transport_int_delays
+transport_path_delays
+typdelays
```

### Cell libraries

Model Technology passed the ASIC Council's Verilog test suite and achieved the "Library Tested and Approved" designation from Si2 Labs. This test suite is designed to ensure Verilog timing accuracy and functionality and is the first significant hurdle to complete on the way to achieving full ASIC vendor support. As a consequence, many ASIC and FPGA vendors' Verilog cell libraries are compatible with ModelSim Verilog.

The cell models generally contain Verilog "specify blocks" that describe the path delays and timing constraints for the cells. See section 13 in the IEEE Std 1364-1995 for details on specify blocks, and section 14.5 for details on timing constraints. ModelSim Verilog fully implements specify blocks and timing constraints as defined in IEEE Std 1364 along with some Verilog-XL compatible extensions.

## SDF timing annotation

ModelSim Verilog supports timing annotation from Standard Delay Format (SDF) files. See *Chapter 10 - Standard Delay Format (SDF) Timing Annotation* for details.

## Delay modes

Verilog models may contain both distributed delays and path delays. The delays on primitives, UDPs, and continuous assignments are the distributed delays, whereas the port-to-port delays specified in specify blocks are the path delays. These delays interact to determine the actual delay observed. Most Verilog cells use path delays exclusively, with the distributed delays set to zero. For example,

```
module and2(y, a, b);
    input a, b;
    output y;

    and(y, a, b);

    specify
        (a => y) = 5;
        (b => y) = 5;
    endspecify
endmodule
```

In the above two-input "and" gate cell, the distributed delay for the "and" primitive is zero, and the actual delays observed on the module ports are taken from the path delays. This is typical for most cells, but a complex cell may require non-zero distributed delays to work properly. Even so, these delays are usually small enough that the path delays take priority over the distributed delays. The rule is that if a module contains both path delays and distributed delays, then the larger of the two delays for each path shall be used (as defined by the IEEE Std 1364). This is the default behavior, but you can specify alternate delay modes with compiler directives and arguments. These arguments and directives are compatible with Verilog-XL. Compiler delay mode arguments take precedence over delay mode directives in the source code.

### **Distributed delay mode**

In distributed delay mode the specify path delays are ignored in favor of the distributed delays. Select this delay mode with the **+delay\_mode\_distributed** compiler argument or the **`delay\_mode\_distributed** compiler directive.

### **Path delay mode**

In path delay mode the distributed delays are set to zero in any module that contains a path delay. Select this delay mode with the **+delay\_mode\_path** compiler argument or the **`delay\_mode\_path** compiler directive.

### **Unit delay mode**

In unit delay mode the distributed delays are set to one unit of simulation resolution (determined by the minimum time\_precision argument in all ‘timescale directives in your design or the value specified with the -t argument to vsim), and the specify path delays and timing constraints are ignored. Select this delay mode with the **+delay\_mode\_unit** compiler argument or the **`delay\_mode\_unit** compiler directive.

### **Zero delay mode**

In zero delay mode the distributed delays are set to zero, and the specify path delays and timing constraints are ignored. Select this delay mode with the **+delay\_mode\_zero** compiler argument or the **`delay\_mode\_zero** compiler directive.

## System tasks

The IEEE Std 1364 defines many system tasks as part of the Verilog language, and ModelSim Verilog supports all of these along with several non-standard Verilog-XL system tasks. The system tasks listed in this chapter are built into the simulator, although some designs depend on user-defined system tasks implemented with the Programming Language Interface (PLI) or Verilog Procedural Interface (VPI). If the simulator issues warnings regarding undefined system tasks, then it is likely that these system tasks are defined by a PLI/VPI application that must be loaded by the simulator.

### IEEE Std 1364 system tasks

The following system tasks are described in detail in the IEEE Std 1364.

| <b>Timescale tasks</b>                      | <b>Simulator control tasks</b> | <b>Simulation time functions</b> | <b>Command line input</b> |
|---------------------------------------------|--------------------------------|----------------------------------|---------------------------|
| \$printtimescale                            | \$finish                       | \$realtime                       | \$test\$plusargs          |
| \$timeformat                                | \$stop                         | \$stime                          | \$value\$plusargs         |
|                                             |                                | \$time                           |                           |
| <b>Probabilistic distribution functions</b> | <b>Conversion functions</b>    | <b>Stochastic analysis tasks</b> | <b>Timing check tasks</b> |
| \$dist_chi_square                           | \$bitstoreal                   | \$q_add                          | \$hold                    |
| \$dist_erlang                               | \$itor                         | \$q_exam                         | \$nochange                |
| \$dist_exponential                          | \$realtobits                   | \$q_full                         | \$period                  |
| \$dist_normal                               | \$rtoi                         | \$q_initialize                   | \$recovery                |
| \$dist_poisson                              | \$signed                       | \$q_remove                       | \$setup                   |
| \$dist_t                                    | \$unsigned                     |                                  | \$setuphold               |
| \$dist_uniform                              |                                |                                  | \$skew                    |
| \$random                                    |                                |                                  | \$width <sup>a</sup>      |
|                                             |                                |                                  | \$removal                 |
|                                             |                                |                                  | \$recrem                  |

a.Verilog-XL ignores the threshold argument even though it is part of the Verilog spec. ModelSim does not ignore this argument. Be careful that you don't set the threshold argument greater-than-or-equal to the limit argument as that essentially disables the \$width check. Note too that you cannot override the threshold argument via SDF annotation.

| <b>Display tasks</b> | <b>PLA modeling tasks</b> | <b>Value change dump (VCD) file tasks</b> |
|----------------------|---------------------------|-------------------------------------------|
| \$display            | \$async\$and\$array       | \$dumpall                                 |
| \$displayb           | \$async\$nand\$array      | \$dumpfile                                |
| \$displayh           | \$async\$or\$array        | \$dumpflush                               |
| \$displayo           | \$async\$nor\$array       | \$dumplimit                               |
| \$monitor            | \$async\$and\$plane       | \$dumpoff                                 |
| \$monitorb           | \$async\$nand\$plane      | \$dumpon                                  |
| \$monitorh           | \$async\$or\$plane        | \$dumpvars                                |
| \$monitoro           | \$async\$nor\$plane       |                                           |
| \$monitoroff         | \$sync\$and\$array        |                                           |
| \$monitoron          | \$sync\$nand\$array       |                                           |
| \$strobe             | \$sync\$or\$array         |                                           |
| \$strobeb            | \$sync\$nor\$array        |                                           |
| \$strobeh            | \$sync\$and\$plane        |                                           |
| \$strobeo            | \$sync\$nand\$plane       |                                           |
| \$write              | \$sync\$or\$plane         |                                           |
| \$writeb             | \$sync\$nor\$plane        |                                           |
| \$writeh             |                           |                                           |
| \$writeo             |                           |                                           |

**File I/O tasks**

|             |            |                  |
|-------------|------------|------------------|
| \$fclose    | \$fopen    | \$fwriteh        |
| \$fdisplay  | \$fread    | \$fwriteo        |
| \$fdisplayb | \$fscanf   | \$readmemb       |
| \$fdisplayh | \$fseek    | \$readmemh       |
| \$fdisplayo | \$fstrobe  | \$rewind         |
| \$ferror    | \$fstrobeb | \$sdf_annotation |
| \$fflush    | \$fstrobeh | \$sformat        |
| \$fgetc     | \$fstrobeo | \$sscanf         |
| \$fgets     | \$ftell    | \$swrite         |
| \$fmonitor  | \$fwrite   | \$fwriteb        |
| \$fmonitorb | \$fwriteb  | \$fwriteh        |
| \$fmonitorh |            | \$fwriteo        |
| \$fmonitoro |            | \$ungetc         |

## Verilog-XL compatible system tasks

The following system tasks are provided for compatibility with Verilog-XL. Although they are not part of the IEEE standard, they are described in an annex of the IEEE Std 1364.

```
$countdrivers
$getpattern
$srreadmemb
$srreadmemh
```

The following system tasks are also provided for compatibility with Verilog-XL; they are not described in the IEEE Std 1364.

```
$deposit(variable, value);
```

This system task sets a Verilog register or net to the specified value. **variable** is the register or net to be changed; **value** is the new value for the register or net. The value remains until there is a subsequent driver transaction or another \$deposit task for the same register or net. This system task operates identically to the ModelSim **force -deposit** command.

```
$disable_warnings("<keyword>[,<module_instance>...]);
```

This system task instructs ModelSim to disable warnings about timing check violations or triregs that acquire a value of ‘X’ due to charge decay. <keyword> may be **decay** or **timing**. You can specify one or more module instance names. If you don’t specify a module instance, ModelSim disables warnings for the entire simulation.

```
$enable_warnings("<keyword>[,<module_instance>...]);
```

This system task enables warnings about timing check violations or triregs that acquire a value of ‘X’ due to charge decay. <keyword> may be **decay** or **timing**. You can specify one or more module instance names. If you don’t specify a module\_instance, ModelSim enables warnings for the entire simulation.

The following system tasks are extended to provide additional functionality for negative timing constraints and an alternate method of conditioning, as in Verilog-XL.

```
$recovery(reference_event, data_event, removal_limit, recovery_limit,
[notifier], [tstamp_cond], [tcheck_cond], [delayed_reference],
[delayed_data])
```

The \$recovery system task normally takes a recovery\_limit as the third argument and an optional notifier as the fourth argument. By specifying a limit for both the third and fourth arguments, the \$recovery timing check is transformed into a combination removal and recovery timing check similar to the \$recrrem timing check. The only difference is that the removal\_limit and recovery\_limit are swapped.

```
$setuphold(clk_event, data_event, setup_limit, hold_limit, [notifier],
[tstamp_cond], [tcheck_cond], [delayed_clk], [delayed_data])
```

The tstamp\_cond argument conditions the data\_event for the setup check and the clk\_event for the hold check. This alternate method of conditioning precludes specifying conditions in the clk\_event and data\_event arguments.

The tcheck\_cond argument conditions the data\_event for the hold check and the clk\_event for the setup check. This alternate method of conditioning precludes specifying conditions in the clk\_event and data\_event arguments.

The delayed\_clk argument is a net that is continuously assigned the value of the net specified in the clk\_event. The delay is non-zero if the setup\_limit is negative, zero otherwise.

The delayed\_data argument is a net that is continuously assigned the value of the net specified in the data\_event. The delay is non-zero if the hold\_limit is negative, zero otherwise.

The delayed\_clk and delayed\_data arguments are provided to ease the modeling of devices that may have negative timing constraints. The model's logic should reference the delayed\_clk and delayed\_data nets in place of the normal clk and data nets. This ensures that the correct data is latched in the presence of negative constraints. The simulator automatically calculates the delays for delayed\_clk and delayed\_data such that the correct data is latched as long as a timing constraint has not been violated. See "[Negative timing check limits](#)" (UM-100) for more details.

The following system tasks are Verilog-XL system tasks that are not implemented in ModelSim Verilog, but have equivalent simulator commands.

`$input("filename")`

This system task reads commands from the specified filename. The equivalent simulator command is **do <filename>**.

`$list[(hierarchical_name)]`

This system task lists the source code for the specified scope. The equivalent functionality is provided by selecting a module in the graphic interface Structure window. The corresponding source code is displayed in the Source window.

`$reset`

This system task resets the simulation back to its time 0 state. The equivalent simulator command is **restart**.

`$restart("filename")`

This system task sets the simulation to the state specified by filename, saved in a previous call to \$save. The equivalent simulator command is **restore <filename>**.

`$save("filename")`

This system task saves the current simulation state to the file specified by filename. The equivalent simulator command is **checkpoint <filename>**.

`$scope(hierarchical_name)`

This system task sets the interactive scope to the scope specified by hierarchical\_name. The equivalent simulator command is **environment <pathname>**.

`$showscopes`

This system task displays a list of scopes defined in the current interactive scope. The equivalent simulator command is **show**.

`$showvars`

This system task displays a list of registers and nets defined in the current interactive scope. The equivalent simulator command is **show**.

## ModelSim Verilog system tasks

The following system tasks are specific to ModelSim. They are not included in the IEEE Std 1364 nor are they likely supported in other simulators. Their use may limit the portability of your code.

`$init_signal_driver`

The `$init_signal_driver()` system task drives the value of a VHDL signal or Verilog net onto an existing VHDL signal or Verilog net. This allows you to drive signals or nets at any level of the design hierarchy from within a Verilog module (e.g., a testbench). See [\\$init\\_signal\\_driver \(UM-304\)](#) in *Chapter 9 - Signal Spy* for complete details.

`$init_signal_spy`

The `$init_signal_spy()` system task mirrors the value of a VHDL signal or Verilog register/net onto an existing Verilog register or VHDL signal. This system task allows you to reference signals, registers, or nets at any level of hierarchy from within a Verilog module (e.g., a testbench). See [\\$init\\_signal\\_spy \(UM-307\)](#) in *Chapter 9 - Signal Spy* for complete details.

`$signal_force`

The `$signal_force()` system task forces the value specified onto an existing VHDL signal or Verilog register or net. This allows you to force signals, registers, or nets at any level of the design hierarchy from within a Verilog module (e.g., a testbench). A `$signal_force` works the same as the **force** command (CR-90) with the exception that you cannot issue a repeating force. See [\\$signal\\_force \(UM-309\)](#) in *Chapter 9 - Signal Spy* for complete details.

`$signal_release`

The `$signal_release()` system task releases a value that had previously been forced onto an existing VHDL signal or Verilog register or net. A `$signal_release` works the same as the **noforce** command (CR-110). See [\\$signal\\_release \(UM-311\)](#) in *Chapter 9 - Signal Spy*.

`$sdf_done`

This task is a "cleanup" function that removes internal buffers, called MIPDs, that have a delay value of zero. These MIPDs are inserted in response to the `-v2k_int_delay` argument to the **vsim** command (CR-213). In general the simulator will automatically remove all zero delay MIPDs. However, if you have `$sdf_annotate()` calls in your design that are not getting executed, the zero-delay MIPDs are not removed. Adding the `$sdf_done` task after your last `$sdf_annotate()` will remove any zero-delay MIPDs that have been created.

## Compiler directives

ModelSim Verilog supports all of the compiler directives defined in the IEEE Std 1364, some Verilog-XL compiler directives, and some that are proprietary.

Many of the compiler directives (such as `timescale) take effect at the point they are defined in the source code and stay in effect until the directive is redefined or until it is reset to its default by a `resetall directive. The effect of compiler directives spans source files, so the order of source files on the compilation command line could be significant. For example, if you have a file that defines some common macros for the entire design, then you might need to place it first in the list of files to be compiled.

The `resetall directive affects only the following directives by resetting them back to their default settings (this information is not provided in the IEEE Std 1364):

```
`celldefine
`default_decay_time
`default_nettype
`delay_mode_distributed
`delay_mode_path
`delay_mode_unit
`delay_mode_zero
`protected
`timescale
`unconnected_drive
`uselib
```

ModelSim Verilog implicitly defines the following macro:

```
`define MODEL_TECH
```

### IEEE Std 1364 compiler directives

The following compiler directives are described in detail in the IEEE Std 1364.

```
`celldefine
`default_nettype
`define
`else
`elsif
`endcelldefine
`endif
`ifdef
`ifndef
`include
`line
`nunconnected_drive
`resetall
`timescale
`unconnected_drive
`undef
```

## Verilog-XL compatible compiler directives

The following compiler directives are provided for compatibility with Verilog-XL.

`'default_decay_time <time>`

This directive specifies the default decay time to be used in trireg net declarations that do not explicitly declare a decay time. The decay time can be expressed as a real or integer number, or as "infinite" to specify that the charge never decays.

`'delay_mode_distributed`

This directive disables path delays in favor of distributed delays. See "["Delay modes"](#)" (UM-104) for details.

`'delay_mode_path`

This directive sets distributed delays to zero in favor of path delays. See "["Delay modes"](#)" (UM-104) for details.

`'delay_mode_unit`

This directive sets path delays to zero and non-zero distributed delays to one time unit. See "["Delay modes"](#)" (UM-104) for details.

`'delay_mode_zero`

This directive sets path delays and distributed delays to zero. See "["Delay modes"](#)" (UM-104) for details.

`'uselib`

This directive is an alternative to the `-v`, `-y`, and `+libext` source library compiler arguments. See "["Verilog-XL `uselib compiler directive"](#)" (UM-91) for details.

The following Verilog-XL compiler directives are silently ignored by ModelSim Verilog. Many of these directives are irrelevant to ModelSim Verilog, but may appear in code being ported from Verilog-XL.

```
'accelerate
`autoexpand_vectornets
`disable_portfaults
`enable_portfaults
`expand_vectornets
`noaccelerate
`noexpand_vectornets
`noremove_gatenames
`noremove_netnames
`nosuppress_faults
`remove_gatenames
`remove_netnames
`suppress_faults
```

The following Verilog-XL compiler directives produce warning messages in ModelSim Verilog. These are not implemented in ModelSim Verilog, and any code containing these directives may behave differently in ModelSim Verilog than in Verilog-XL.

```
'default_trireg_strength
`signed
`unsigned
```



# 6 - Verilog PLI / VPI

---

## Chapter contents

|                                                         |        |
|---------------------------------------------------------|--------|
| Introduction . . . . .                                  | UM-116 |
| Registering PLI applications . . . . .                  | UM-117 |
| Registering VPI applications . . . . .                  | UM-119 |
| Example . . . . .                                       | UM-119 |
| Compiling and linking PLI/VPI C applications . . . . .  | UM-121 |
| Compiling and linking PLI/VPI C++ applications. . . . . | UM-122 |
| Specifying the PLI/VPI file to load . . . . .           | UM-123 |
| PLI example . . . . .                                   | UM-124 |
| VPI example . . . . .                                   | UM-125 |
| The PLI callback reason argument. . . . .               | UM-126 |
| The sizetf callback function . . . . .                  | UM-128 |
| PLI object handles . . . . .                            | UM-129 |
| Third party PLI applications . . . . .                  | UM-130 |
| Support for VHDL objects . . . . .                      | UM-131 |
| IEEE Std 1364 ACC routines . . . . .                    | UM-132 |
| IEEE Std 1364 TF routines . . . . .                     | UM-134 |
| Verilog-XL compatible routines . . . . .                | UM-136 |
| PLI/VPI tracing . . . . .                               | UM-137 |
| The purpose of tracing files . . . . .                  | UM-137 |
| Invoking a trace . . . . .                              | UM-137 |
| Syntax . . . . .                                        | UM-137 |
| Arguments . . . . .                                     | UM-137 |
| Examples . . . . .                                      | UM-138 |
| Debugging PLI/VPI application code . . . . .            | UM-139 |

## Introduction

This chapter describes the ModelSim implementation of the Verilog PLI (Programming Language Interface) and VPI (Verilog Procedural Interface). Both interfaces provide a mechanism for defining system tasks and functions that communicate with the simulator through a C procedural interface. There are many third party applications available that interface to Verilog simulators through the PLI (see "[Third party PLI applications](#)" (UM-130)). In addition, you may write your own PLI/VPI applications.

ModelSim Verilog implements the PLI as defined in the IEEE Std 1364, with the exception of the **acc\_handle\_datapath()** routine. We did not implement the **acc\_handle\_datapath()** routine because the information it returns is more appropriate for a static timing analysis tool.

The VPI is partially implemented as defined in the IEEE Std 1364-2001. The list of currently supported functionality can be found in the following file:

```
<install_dir>/modeltech/docs/technotes/Verilog_VPI.note
```

The IEEE Std 1364 is the reference that defines the usage of the PLI/VPI routines. This manual only describes details of using the PLI/VPI with ModelSim Verilog.

## Registering PLI applications

Each PLI application must register its system tasks and functions with the simulator, providing the name of each system task and function and the associated callback routines. Since many PLI applications already interface to Verilog-XL, ModelSim Verilog PLI applications make use of the same mechanism to register information about each system task and function in an array of `s_tfcell` structures. This structure is declared in the `veriuser.h` include file as follows:

```
typedef int (*p_tffn)();

typedef struct t_tfcell {
    short type; /* USERTASK, USERFUNCTION, or USERREALFUNCTION */
    short data; /* passed as data argument of callback function */
    p_tffn checktf; /* argument checking callback function */
    p_tffn sizetf; /* function return size callback function */
    p_tffn calltf; /* task or function call callback function */
    p_tffn misctf; /* miscellaneous reason callback function */
    char *tfname; /* name of system task or function */

    /* The following fields are ignored by ModelSim Verilog */
    int forwref;
    char *tfveritool;
    char *tferrmessage;
    int hash;
    struct t_tfcell *left_p;
    struct t_tfcell *right_p;
    char *namecell_p;
    int warning_printed;
} s_tfcell, *p_tfcell;
```

The various callback functions (`checktf`, `sizetf`, `calltf`, and `misctf`) are described in detail in the IEEE Std 1364. The simulator calls these functions for various reasons. All callback functions are optional, but most applications contain at least the `calltf` function, which is called when the system task or function is executed in the Verilog code. The first argument to the callback functions is the value supplied in the `data` field (many PLI applications don't use this field). The `type` field defines the entry as either a system task (USERTASK) or a system function that returns either a register (USERFUNCTION) or a real (USERREALFUNCTION). The `tfname` field is the system task or function name (it must begin with \$). The remaining fields are not used by ModelSim Verilog.

On loading of a PLI application, the simulator first looks for an `init_usertfs` function, and then a `veriusersts` array. If `init_usertfs` is found, the simulator calls that function so that it can call `mti_RegisterUserTF()` for each system task or function defined. The `mti_RegisterUserTF()` function is declared in `veriuser.h` as follows:

```
void mti_RegisterUserTF(p_tfcell usertf);
```

The storage for each usertf entry passed to the simulator must persist throughout the simulation because the simulator de-references the usertf pointer to call the callback functions. We recommend that you define your entries in an array, with the last entry set to 0. If the array is named veriusertfs (as is the case for linking to Verilog-XL), then you don't have to provide an init\_usertfs function, and the simulator will automatically register the entries directly from the array (the last entry must be 0). For example,

```
s_tfcell veriusertfs[] = {
    {usertask, 0, 0, 0, abc_calltf, 0, "$abc"},  

    {usertask, 0, 0, 0, xyz_calltf, 0, "$xyz"},  

    {0} /* last entry must be 0 */
};
```

Alternatively, you can add an init\_usertfs function to explicitly register each entry from the array:

```
void init_usertfs()
{
    p_tfcell usertf = veriusertfs;
    while (usertf->type)
        mti_RegisterUserTF(usertf++);
}
```

It is an error if a PLI shared library does not contain a veriusertfs array or an init\_usertfs function.

Since PLI applications are dynamically loaded by the simulator, you must specify which applications to load (each application must be a dynamically loadable library, see ["Compiling and linking PLI/VPI C applications"](#) (UM-121)). The PLI applications are specified as follows (note that on a Windows platform the file extension would be .dll):

- As a list in the Veriuser entry in the *modelsim.ini* file:

```
Veriuser = pliapp1.so pliapp2.so pliappn.so
```

- As a list in the PLIOBJJS environment variable:

```
% setenv PLIOBJJS "pliapp1.so pliapp2.so pliappn.so"
```

- As a -pli argument to the simulator (multiple arguments are allowed):

```
-pli pliapp1.so -pli pliapp2.so -pli pliappn.so
```

The various methods of specifying PLI applications can be used simultaneously. The libraries are loaded in the order listed above. Environment variable references can be used in the paths to the libraries in all cases.

# Registering VPI applications

Each VPI application must register its system tasks and functions and its callbacks with the simulator. To accomplish this, one or more user-created registration routines must be called at simulation startup. Each registration routine should make one or more calls to `vpi_register_systf()` to register user-defined system tasks and functions and `vpi_register_cb()` to register callbacks. The registration routines must be placed in a table named `vlog_startup_routines` so that the simulator can find them. The table must be terminated with a 0 entry.

## Example

```

PLI_INT32 MyFuncCalltf( PLI_BYTE8 *user_data )
{ ... }

PLI_INT32 MyFuncCompiletf( PLI_BYTE8 *user_data )
{ ... }

PLI_INT32 MyFuncSizetf( PLI_BYTE8 *user_data )
{ ... }

PLI_INT32 MyEndOfCompCB( p_cb_data cb_data_p )
{ ... }

PLI_INT32 MyStartOfSimCB( p_cb_data cb_data_p )
{ ... }

void RegisterMySystfs( void )
{
    vpiHandle tmpH;
    s_cb_data callback;
    s_vpi_systf_data systf_data;

    systf_data.type      = vpiSysFunc;
    systf_data.sysfuncype = vpiSizedFunc;
    systf_data.tfname    = "$myfunc";
    systf_data.calltf   = MyFuncCalltf;
    systf_data.compiletf = MyFuncCompiletf;
    systf_data.sizetf    = MyFuncSizetf;
    systf_data.user_data = 0;
    tmpH = vpi_register_systf( &systf_data );
    vpi_free_object(tmpH);

    callback.reason     = cbEndOfCompile;
    callback.cb_rtn     = MyEndOfCompCB;
    callback.user_data = 0;
    tmpH = vpi_register_cb( &callback );
    vpi_free_object(tmpH);

    callback.reason     = cbStartOfSimulation;
    callback.cb_rtn     = MyStartOfSimCB;
    callback.user_data = 0;
    tmpH = vpi_register_cb( &callback );
    vpi_free_object(tmpH);
}

void (*vlog_startup_routines[ ] ) () = {
    RegisterMySystfs,
    0      /* last entry must be 0 */
};

```

Loading VPI applications into the simulator is the same as described in "[Registering PLI applications](#)" (UM-117).

PLI and VPI applications can co-exist in the same application object file. In such cases, the applications are loaded at startup as follows:

- If an init\_usertfs() function exists, then it is executed and only those system tasks and functions registered by calls to mti\_RegisterUserTF() will be defined.
- If an init\_usertfs() function does not exist but a veriusertfs table does exist, then only those system tasks and functions listed in the veriusertfs table will be defined.
- If an init\_usertfs() function does not exist and a veriusertfs table does not exist, but a vlog\_startup\_routines table does exist, then only those system tasks and functions and callbacks registered by functions in the vlog\_startup\_routines table will be defined.

As a result, when PLI and VPI applications exist in the same application object file, they must be registered in the same manner. VPI registration functions that would normally be listed in a vlog\_startup\_routines table can be called from an init\_usertfs() function instead.

## Compiling and linking PLI/VPI C applications

The following platform-specific instructions show you how to compile and link your PLI/VPI C applications so that they can be loaded by ModelSim. Microsoft Visual C/C++ is supported for creating Windows DLLs.

The PLI/VPI routines are declared in the include files located in the ModelSim `<install_dir>/modeltech/include` directory. The `acc_user.h` file declares the ACC routines, the `veriuser.h` file declares the TF routines, and the `vpi_user.h` file declares the VPI routines.

The following instructions assume that the PLI or VPI application is in a single source file. For multiple source files, compile each file as specified in the instructions and link all of the resulting object files together with the specified link instructions.

Although compilation and simulation switches are platform-specific, loading shared libraries is the same for all platforms. For information on loading libraries, see "["Specifying the PLI/VPI file to load"](#) (UM-123).

### Windows platforms

```
cl -c -I<install_dir>\modeltech\include app.c
link -dll -export:<init_function> app.obj \
      <install_dir>\modeltech\win32\mtipli.lib /out:app.dll
```

For the Verilog PLI, the `<init_function>` should be "init\_usersts". Alternatively, if there is no `init_usersts` function, the `<init_function>` specified on the command line should be "veriusersts". For the Verilog VPI, the `<init_function>` should be "vlog\_startup\_routines". These requirements ensure that the appropriate symbol is exported, and thus ModelSim can find the symbol when it dynamically loads the DLL.

The PLI and VPI have been tested with DLLs built using Microsoft Visual C/C++ compiler version 4.1 or greater.

The gcc compiler *cannot* be used to compile PLI/VPI applications under Windows. This is because gcc does not support the Microsoft `.lib/.dll` format.

When executing **cl** commands in a DO file, use the **/NOLOGO** switch to prevent the Microsoft C compiler from writing the logo banner to stderr. Writing the logo causes Tcl to think an error occurred.

## Compiling and linking PLI/VPI C++ applications

ModelSim does not have direct support for any language other than standard C; however, C++ code can be loaded and executed under certain conditions.

Since ModelSim's PLI/VPI functions have a standard C prototype, you must prevent the C++ compiler from mangling the PLI/VPI function names. This can be accomplished by using the following type of extern:

```
extern "C"
{
    <PLI/VPI application function prototypes>
}
```

The header files *veriuser.h*, *acc\_user.h*, and *vpi\_user.h* already include this type of extern. You must also put the PLI/VPI shared library entry point (*veriusertfs*, *init\_usertfs*, or *vlog\_startup\_routines*) inside of this type of extern.

The following platform-specific instructions show you how to compile and link your PLI/VPI C++ applications so that they can be loaded by ModelSim. Microsoft Visual C++ is supported for creating Windows DLLs.

Although compilation and simulation switches are platform-specific, loading shared libraries is the same for all platforms. For information on loading libraries, see "["Specifying the PLI/VPI file to load"](#) (UM-123).

### Windows platforms

#### **Microsoft Visual C++:**

```
cl -c [-GX] -I<install_dir>\modeltech\include app.cxx
link -dll -export:<init_function> app.obj \
    <install_dir>\modeltech\win32\mtipli.lib /out:app.dll
```

The **-GX** argument enables exception handling.

For the Verilog PLI, the **<init\_function>** should be "init\_usertfs". Alternatively, if there is no init\_usertfs function, the **<init\_function>** specified on the command line should be "veriusertfs". For the Verilog VPI, the **<init\_function>** should be "vlog\_startup\_routines". These requirements ensure that the appropriate symbol is exported, and thus ModelSim can find the symbol when it dynamically loads the DLL.

The GNU C++ compiler *cannot* be used to compile PLI/VPI applications under Windows. This is because GNU C++ does not support the Microsoft *.lib/.dll* format.

When executing **cl** commands in a DO file, use the **/NOLOGO** switch to prevent the Microsoft C compiler from writing the logo banner to stderr. Writing the logo causes Tcl to think an error occurred.

## Specifying the PLI/VPI file to load

The PLI/VPI applications are specified as follows:

- As a list in the Veriuser entry in the *modelsim.ini* file:

```
Veriuser = pliappl.so pliapp2.so pliappn.so
```

- As a list in the PLIOBJ\$ environment variable:

```
% setenv PLIOBJ$ "pliappl.so pliapp2.so pliappn.so"
```

- As a **-pli** argument to the simulator (multiple arguments are allowed):

```
-pli pliappl.so -pli pliapp2.so -pli pliappn.so
```

The various methods of specifying PLI/VPI applications can be used simultaneously. The libraries are loaded in the order listed above. Environment variable references can be used in the paths to the libraries in all cases.

See also *Appendix A - ModelSim variables* for more information on the *modelsim.ini* file.

## PLI example

The following example is a trivial, but complete PLI application.

hello.c:

```
#include "veriuser.h"
static PLI_INT32 hello()
{
    io_printf("Hi there\n");
    return 0;
}
s_tfcell veriusertfs[] = {
    {usertask, 0, 0, 0, hello, 0, "$hello"},
    {0} /* last entry must be 0 */
};
```

hello.v:

```
module hello;
    initial $hello;
endmodule
```

Compile the PLI code for the Solaris operating system:

```
% cc -c -I<install_dir>/modeltech/include hello.c
% ld -G -o hello.sl hello.o
```

Compile the Verilog code:

```
% vlib work
% vlog hello.v
```

Simulate the design:

```
% vsim -c -pli hello.sl hello
# Loading work.hello
# Loading ./hello.sl
VSIM 1> run -all
# Hi there
VSIM 2> quit
```

## VPI example

The following example is a trivial, but complete VPI application. A general VPI example can be found in <install\_dir>/modeltech/examples/vpi.

```
hello.c:

#include "vpi_user.h"
static PLI_INT32 hello(PLI_BYTE8 * param)
{
    vpi_printf( "Hello world!\n" );
    return 0;
}

void RegisterMyTfs( void )
{
    s_vpi_systf_data systf_data;
    vpiHandle systf_handle;
    systf_data.type      = vpiSysTask;
    systf_data.sysfunctype = vpiSysTask;
    systf_data.tfname     = "$hello";
    systf_data.calltf     = hello;
    systf_data.compiletf   = 0;
    systf_data.sizetf     = 0;
    systf_data.user_data   = 0;
    systf_handle = vpi_register_systf( &systf_data );
    vpi_free_object( systf_handle );
}

void (*vlog_startup_routines[])() = {
    RegisterMyTfs,
    0
};
```

hello.v:

```
module hello;
    initial $hello;
endmodule
```

Compile the VPI code for the Solaris operating system:

```
% gcc -c -I<install_dir>/include hello.c
% ld -G -o hello.sl hello.o
```

Compile the Verilog code:

```
% vlib work
% vlog hello.v
```

Simulate the design:

```
% vsim -c -pli hello.sl hello
# Loading work.hello
# Loading ./hello.sl
VSIM 1> run -all
# Hello world!
VSIM 2> quit
```

## The PLI callback reason argument

The second argument to a PLI callback function is the reason argument. The values of the various reason constants are defined in the veriuser.h include file. See IEEE Std 1364 for a description of the reason constants. The following details relate to ModelSim Verilog, and may not be obvious in the IEEE Std 1364. Specifically, the simulator passes the reason values to the misctf callback functions under the following circumstances:

`reason_endofcompile`

For the completion of loading the design.

`reason_finish`

For the execution of the \$finish system task or the **quit** command.

`reason_startofsave`

For the start of execution of the **checkpoint** command, but before any of the simulation state has been saved. This allows the PLI application to prepare for the save, but it shouldn't save its data with calls to `tf_write_save()` until it is called with `reason_save`.

`reason_save`

For the execution of the **checkpoint** command. This is when the PLI application must save its state with calls to `tf_write_save()`.

`reason_startofrestart`

For the start of execution of the **restore** command, but before any of the simulation state has been restored. This allows the PLI application to prepare for the restore, but it shouldn't restore its state with calls to `tf_read_restart()` until it is called with `reason_restart`. The `reason_startofrestart` value is passed only for a restore command, and not in the case that the simulator is invoked with `-restore`.

`reason_restart`

For the execution of the **restore** command. This is when the PLI application must restore its state with calls to `tf_read_restart()`.

`reason_reset`

For the execution of the **restart** command. This is when the PLI application should free its memory and reset its state. We recommend that all PLI applications reset their internal state during a restart as the shared library containing the PLI code might not be reloaded. (See the **-keeploaded** (CR-215) and **-keeploadedrestart** (CR-215) arguments to **vsim** for related information.)

`reason_endofreset`

For the completion of the **restart** command, after the simulation state has been reset but before the design has been reloaded.

`reason_interactive`

For the execution of the \$stop system task or any other time the simulation is interrupted and waiting for user input.

`reason_scope`

For the execution of the **environment** command or selecting a scope in the Structure window. Also for the call to `acc_set_interactive_scope()` if the `callback_flag` argument is non-zero.

`reason_paramvc`

For the change of value on the system task or function argument.

`reason_synch`  
For the end of time step event scheduled by `tf_synchronize()`.

`reason_rosynch`  
For the end of time step event scheduled by `tf_rosynchronize()`.

`reason_reactivate`  
For the simulation event scheduled by `tf_setdelay()`.

`reason_paramdrc`  
Not supported in ModelSim Verilog.

`reason_force`  
Not supported in ModelSim Verilog.

`reason_release`  
Not supported in ModelSim Verilog.

`reason_disable`  
Not supported in ModelSim Verilog.

## The sizetf callback function

A user-defined system function specifies the width of its return value with the sizetf callback function, and the simulator calls this function while loading the design. The following details on the sizetf callback function are not found in the IEEE Std 1364:

- If you omit the sizetf function, then a return width of 32 is assumed.
- The sizetf function should return 0 if the system function return value is of Verilog type "real".
- The sizetf function should return -32 if the system function return value is of Verilog type "integer".

## PLI object handles

Many of the object handles returned by the PLI ACC routines are pointers to objects that naturally exist in the simulation data structures, and the handles to these objects are valid throughout the simulation, even after the acc\_close() routine is called. However, some of the objects are created on demand, and the handles to these objects become invalid after acc\_close() is called. The following object types are created on demand in ModelSim Verilog:

```
accOperator (acc_handle_condition)
accWirePath (acc_handle_path)
accTerminal (acc_handle_terminal, acc_next_cell_load, acc_next_driver, and
             acc_next_load)
accPathTerminal (acc_next_input and acc_next_output)
accTchkTerminal (acc_handle_tchkarg1 and acc_handle_tchkarg2)
accPartSelect (acc_handle_conn, acc_handle_pathin, and acc_handle_pathout)
```

If your PLI application uses these types of objects, then it is important to call acc\_close() to free the memory allocated for these objects when the application is done using them.

If your PLI application places value change callbacks on accRegBit or accTerminal objects, *do not* call acc\_close() while these callbacks are in effect.

## Third party PLI applications

Many third party PLI applications come with instructions on using them with ModelSim Verilog. Even without the instructions, it is still likely that you can get it to work with ModelSim Verilog as long as the application uses standard PLI routines. The following guidelines are for preparing a Verilog-XL PLI application to work with ModelSim Verilog.

Generally, a Verilog-XL PLI application comes with a collection of object files and a veriuser.c file. The veriuser.c file contains the registration information as described above in "[Registering PLI applications](#)" (UM-117). To prepare the application for ModelSim Verilog, you must compile the veriuser.c file and link it to the object files to create a dynamically loadable object (see "[Compiling and linking PLI/VPI C applications](#)" (UM-121)). For example, if you have a *veriuser.c* file and a library archive *libapp.a* file that contains the application's object files, then the following commands should be used to create a dynamically loadable object for the Solaris operating system:

```
% cc -c -I<install_dir>/modeltech/include veriuser.c  
% ld -G -o app.sl veriuser.o libapp.a
```

The PLI application is now ready to be run with ModelSim Verilog. All that's left is to specify the resulting object file to the simulator for loading using the **Veriuser** entry in the *modesim.ini* file, the **-pli** simulator argument, or the PLIOBJS environment variable (see "[Registering PLI applications](#)" (UM-117)).

- ▶ **Note:** On the HP700 platform, the object files must be compiled as position-independent code by using the **+z** compiler argument. Since, the object files supplied for Verilog-XL may be compiled for static linking, you may not be able to use the object files to create a dynamically loadable object for ModelSim Verilog. In this case, you must get the third party application vendor to supply the object files compiled as position-independent code.

## Support for VHDL objects

The PLI ACC routines also provide limited support for VHDL objects in an all VHDL design. The following table lists the VHDL objects for which handles may be obtained and their type and fulltype constants:

| Type            | Fulltype             | Description                                                                                                                                                         |
|-----------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| accArchitecture | accArchitecture      | instantiation of an architecture                                                                                                                                    |
| accArchitecture | accEntityVitalLevel0 | instantiation of an architecture whose entity is marked with the attribute VITAL_Level0                                                                             |
| accArchitecture | accArchVitalLevel0   | instantiation of an architecture which is marked with the attribute VITAL_Level0                                                                                    |
| accArchitecture | accArchVitalLevel1   | instantiation of an architecture which is marked with the attribute VITAL_Level1                                                                                    |
| accArchitecture | accForeignArch       | instantiation of an architecture which is marked with the attribute FOREIGN and which does not contain any VHDL statements or objects other than ports and generics |
| accArchitecture | accForeignArchMixed  | instantiation of an architecture which is marked with the attribute FOREIGN and which contains some VHDL statements or objects besides ports and generics           |
| accBlock        | accBlock             | block statement                                                                                                                                                     |
| accForLoop      | accForLoop           | for loop statement                                                                                                                                                  |
| accForeign      | accShadow            | foreign scope created by mti_CreateRegion()                                                                                                                         |
| accGenerate     | accGenerate          | generate statement                                                                                                                                                  |
| accPackage      | accPackage           | package declaration                                                                                                                                                 |
| accSignal       | accSignal            | signal declaration                                                                                                                                                  |

The type and fulltype constants for VHDL objects are defined in the *acc\_vhdl.h* include file. All of these objects (except signals) are scope objects that define levels of hierarchy in the Structure window. Currently, the PLI ACC interface has no provision for obtaining handles to generics, types, constants, variables, attributes, subprograms, and processes.

## IEEE Std 1364 ACC routines

ModelSim Verilog supports the following ACC routines, described in detail in the IEEE Std 1364.

|                              |                         |                          |
|------------------------------|-------------------------|--------------------------|
| acc_append_delays            | acc_append_pulsere      | acc_close                |
| acc_collect                  | acc_compare_handles     | acc_configure            |
| acc_count                    | acc_fetch_argc          | acc_fetch_argv           |
| acc_fetch_attribute          | acc_fetch_attribute_int | acc_fetch_attribute_str  |
| acc_fetch_defname            | acc_fetch_delay_mode    | acc_fetch_delays         |
| acc_fetch_direction          | acc_fetch_edge          | acc_fetch_fullname       |
| acc_fetch_fulltype           | acc_fetch_index         | acc_fetch_location       |
| acc_fetch_name               | acc_fetch_paramtype     | acc_fetch_paramval       |
| acc_fetch_polarity           | acc_fetch_precision     | acc_fetch_pulsere        |
| acc_fetch_range              | acc_fetch_size          | acc_fetch_tfarg          |
| acc_fetch_itfarg             | acc_fetch_tfarg_int     | acc_fetch_itfarg_int     |
| acc_fetch_tfarg_str          | acc_fetch_itfarg_str    | acc_fetch_timescale_info |
| acc_fetch_type               | acc_fetch_type_str      | acc_fetch_value          |
| acc_free                     | acc_handle_by_name      | acc_handle_calling_mod_m |
| acc_handle_condition         | acc_handle_conn         | acc_handle_hiconn        |
| acc_handle_interactive_scope | acc_handle_loconn       | acc_handle_modpath       |
| acc_handle_notifier          | acc_handle_object       | acc_handle_parent        |
| acc_handle_path              | acc_handle_pathin       | acc_handle_pathout       |
| acc_handle_port              | acc_handle_scope        | acc_handle_simulated_net |
| acc_handle_tchk              | acc_handle_tchkarg1     | acc_handle_tchkarg2      |
| acc_handle_terminal          | acc_handle_tfarg        | acc_handle_itfarg        |
| acc_handle_tfinst            | acc_initialize          | acc_next                 |
| acc_next_bit                 | acc_next_cell           | acc_next_cell_load       |
| acc_next_child               | acc_next_driver         | acc_next_hiconn          |
| acc_next_input               | acc_next_load           | acc_next_loconn          |
| acc_next_modpath             | acc_next_net            | acc_next_output          |
| acc_next_parameter           | acc_next_port           | acc_next_portout         |

|                        |                    |                           |
|------------------------|--------------------|---------------------------|
| acc_next_primitive     | acc_next_scope     | acc_next_specparam        |
| acc_next_tchk          | acc_next_terminal  | acc_next_topmod           |
| acc_object_in_typelist | acc_object_of_type | acc_product_type          |
| acc_product_version    | acc_release_object | acc_replace_delays        |
| acc_replace_pulsere    | acc_reset_buffer   | acc_set_interactive_scope |
| acc_set_pulsere        | acc_set_scope      | acc_set_value             |
| acc_vcl_add            | acc_vcl_delete     | acc_version               |

acc\_fetch\_paramval() cannot be used on 64-bit platforms to fetch a string value of a parameter. Because of this, the function acc\_fetch\_paramval\_str() has been added to the PLI for this use. acc\_fetch\_paramval\_str() is declared in acc\_user.h. It functions in a manner similar to acc\_fetch\_paramval() except that it returns a char \*. acc\_fetch\_paramval\_str() can be used on all platforms.

## IEEE Std 1364 TF routines

ModelSim Verilog supports the following TF routines, described in detail in the IEEE Std 1364.

|                     |                       |                   |
|---------------------|-----------------------|-------------------|
| io_mcdprintf        | io_printf             | mc_scan_plusargs  |
| tf_add_long         | tf_asynchoff          | tf_iasynchoff     |
| tf_asynchon         | tf_iasynchon          | tf_clearalldelays |
| tf_iclearalldelays  | tf_compare_long       | tf_copypvc_flag   |
| tf_icopypvc_flag    | tf_divide_long        | tf_dofinish       |
| tf_dostop           | tf_error              | tf_evaluatep      |
| tf_ievaluatep       | tf_exprinfo           | tf_iexprinfo      |
| tf_getcstringp      | tf_igetcstringp       | tfGetInstance     |
| tf_getlongp         | tf_igetlongp          | tf_getlongtime    |
| tf_igetlongtime     | tf_getnextlongtime    | tf_getp           |
| tf_igetp            | tf_getpchange         | tf_igetpchange    |
| tf_getrealp         | tf_igetrealp          | tf_getrealtime    |
| tf_igetrealtime     | tf_gettime            | tf_igettime       |
| tf_gettimeprecision | tf_igettimelprecision | tf_gettimeunit    |
| tf_igettimelunit    | tf_getworkarea        | tf_igetworkarea   |
| tf_long_to_real     | tf_longtime_tostr     | tf_message        |
| tf_mipname          | tf_imipname           | tf_movepvc_flag   |
| tf_imovepvc_flag    | tf_multiply_long      | tf_nodeinfo       |
| tf_inodeinfo        | tf_nump               | tf_inump          |
| tf_propagatep       | tf_ipropagatep        | tf_putstrongp     |
| tf_iputlongp        | tf_putp               | tf_iputp          |
| tf_putrealp         | tf_iputrealp          | tf_read_restart   |
| tf_real_to_long     | tf_rosynchronize      | tf_irosynchronize |
| tf_scale_longdelay  | tf_scale_realdelay    | tf_setdelay       |
| tf_isetdelay        | tf_setlongdelay       | tf_isetlongdelay  |
| tf_setrealdelay     | tf_isetrealdelay      | tf_setworkarea    |
| tf_isetworkarea     | tf_sizep              | tf_isizep         |

|                   |                      |                      |
|-------------------|----------------------|----------------------|
| tf_spname         | tf_ispname           | tf_strdelputp        |
| tf_istrdelputp    | tf_strgetp           | tf_istrgetp          |
| tf_strgettime     | tf_strlongdelputp    | tf_istrlongdelputp   |
| tf_strrealdelputp | tf_istrrealdelputp   | tf_subtract_long     |
| tf_synchronize    | tf_isynchronize      | tf_testpvc_flag      |
| tf_itestpvc_flag  | tf_text              | tf_typep             |
| tf_itypep         | tf_unscale_longdelay | tf_unscale_realdelay |
| tf_warning        | tf_write_save        |                      |

## Verilog-XL compatible routines

The following PLI routines are not defined in IEEE Std 1364, but ModelSim Verilog provides them for compatibility with Verilog-XL.

```
char *acc_decompile_exp(handle condition)
```

This routine provides similar functionality to the Verilog-XL **acc\_decompile\_expr** routine. The condition argument must be a handle obtained from the **acc\_handle\_condition** routine. The value returned by **acc\_decompile\_exp** is the string representation of the condition expression.

```
char *tf_dumpfilename(void)
```

This routine returns the name of the VCD file.

```
void tf_dumpflush(void)
```

A call to this routine flushes the VCD file buffer (same effect as calling **\$dumpflush** in the Verilog code).

```
int tf_getlongsimtime(int *aof_hightime)
```

This routine gets the current simulation time as a 64-bit integer. The low-order bits are returned by the routine, while the high-order bits are stored in the **aof\_hightime** argument.

## PLI/VPI tracing

The foreign interface tracing feature is available for tracing PLI and VPI function calls. Foreign interface tracing creates two kinds of traces: a human-readable log of what functions were called, the value of the arguments, and the results returned; and a set of C-language files that can be used to replay what the foreign interface code did.

### The purpose of tracing files

The purpose of the logfile is to aid you in debugging PLI or VPI code. The primary purpose of the replay facility is to send the replay files to MTI support for debugging co-simulation problems, or debugging PLI/VPI problems for which it is impractical to send the PLI/VPI code. We still need you to send the VHDL/Verilog part of the design to actually execute a replay, but many problems can be resolved with the trace only.

### Invoking a trace

To invoke the trace, call **vsim** (CR-213) with the **-trace\_foreign** argument:

### Syntax

```
vsim
  -trace_foreign <action> [-tag <name>]
```

### Arguments

**<action>**  
Specifies one of the following actions:

| Value | Action                     | Result                                                                                                       |
|-------|----------------------------|--------------------------------------------------------------------------------------------------------------|
| 1     | create log only            | writes a local file called "mti_trace_<tag>"                                                                 |
| 2     | create replay only         | writes local files called "mti_data_<tag>.c", "mti_init_<tag>.c", "mti_replay_<tag>.c" and "mti_top_<tag>.c" |
| 3     | create both log and replay |                                                                                                              |

**-tag <name>**  
Used to give distinct file names for multiple traces. Optional.

## Examples

```
vsim -trace_foreign 1 mydesign  
Creates a logfile.  
  
vsim -trace_foreign 3 mydesign  
Creates both a logfile and a set of replay files.  
  
vsim -trace_foreign 1 -tag 2 mydesign  
Creates a logfile with a tag of "2".
```

The tracing operations will provide tracing during all user foreign code-calls, including PLI/VPI user tasks and functions (calltf, checktf, sizetf and miscf routines), and Verilog VCL callbacks.

## Debugging PLI/VPI application code

In order to debug your PLI/VPI application code in a debugger, your application code must be compiled with debugging information (for example, by using the **-g** option) and without optimizations (for example, don't use the **-O** option). You must then load **vsim** into a debugger. Even though **vsim** is stripped, most debuggers will still execute it. You can invoke the debugger directly on **vsimk**, the simulation kernal where your application code is loaded (for example, "ddd `which vsimk`"), or you can attach the debugger to an already running **vsim** process. In the second case, you must attach to the PID for **vsimk**, and you must specify the full path to the **vsimk** executable (for example, "gdb \$MTI\_HOME/sunos5/vsimk 1234").

On Solaris, AIX, and Linux systems you can use either **gdb** or **ddd**. On HP-UX systems you can use the **wdb** debugger from HP. You will need version 1.2 or later.

Since initially the debugger recognizes only **vsim**'s PLI/VPI function symbols, when invoking the debugger directly on **vsim** you need to place a breakpoint in the first PLI/VPI function that is called by your application code. An easy way to set an entry point is to put a call to `acc_product_version()` as the first executable statement in your application code. Then, after **vsim** has been loaded into the debugger, set a breakpoint in this function. Once you have set the breakpoint, run **vsim** with the usual arguments (e.g., "run -c top").

On HP-UX you might see some warning messages that **vsim** does not have debugging information available. This is normal. If you are using Exceed to access an HP machine from Windows NT, it is recommended that you run **vsim** in command line or batch mode because your NT machine may hang if you run **vsim** in GUI mode. Click on the "go" button, or use F5 or the **go** command to execute **vsim** in **wdb**.

When the breakpoint is reached, the shared library containing your application code has been loaded. In some debuggers you must use the **share** command to load the PLI/VPI application's symbols.

On HP-UX you might see a warning about not finding "`__dld_flags`" in the object file. This warning can be ignored. You should see a list of libraries loaded into the debugger. It should include the library for your PLI/VPI application. Alternatively, you can use **share** to load only a single library.

At this point all of the PLI/VPI application's symbols should be visible. You can now set breakpoints in and single step through your PLI/VPI application code.



# 7 - WLF files (datasets) and virtuals

---

## Chapter contents

|                                                                |        |
|----------------------------------------------------------------|--------|
| <a href="#">WLF files (datasets)</a>                           | UM-142 |
| <a href="#">Saving a simulation to a WLF file</a>              | UM-143 |
| <a href="#">Opening datasets</a>                               | UM-144 |
| <a href="#">Viewing dataset structure</a>                      | UM-145 |
| <a href="#">Managing multiple datasets</a>                     | UM-146 |
| <a href="#">Saving at intervals with Dataset Snapshot</a>      | UM-148 |
| <a href="#">Virtual Objects (User-defined buses, and more)</a> | UM-150 |
| <a href="#">Virtual signals</a>                                | UM-150 |
| <a href="#">Virtual functions</a>                              | UM-151 |
| <a href="#">Virtual regions</a>                                | UM-152 |
| <a href="#">Virtual types</a>                                  | UM-152 |
| <a href="#">Dataset, WLF file, and virtual commands</a>        | UM-153 |

A ModelSim simulation can be saved to a wave log format (WLF) file for future viewing or comparison to a current simulation. We use the term "dataset" to refer to a WLF file that has been reopened for viewing.

You can open more than one WLF file for simultaneous viewing. You can also create virtual signals that are simple logical combinations of, or logical functions of, signals from different datasets.

## WLF files (datasets)

Wave Log Format (WLF) files are recordings of simulation runs. The files contain data from logged items (e.g., signals and variables) and the design hierarchy in which the logged items are found. You can record the entire design or choose specific items.

The WLF file provides you with precise in-simulation and post-simulation debugging capability. Any number of WLF files can be reloaded for viewing or comparing to the active simulation.

A dataset is a previously recorded simulation that has been loaded into ModelSim. Each dataset has a logical name to let you indicate the dataset to which any command applies. This logical name is displayed as a prefix. The current, active simulation is prefixed by "sim:", while any other datasets are prefixed by the name of the WLF file by default.

Two datasets are displayed in the Wave window below. The current simulation is shown in the top pane and is indicated by the "sim" prefix. A dataset from a previous simulation is shown in the bottom pane and is indicated by the "gold" prefix.



The simulator resolution (see "Simulator resolution limit" (UM-67)) must be the same for all datasets you're comparing, including the current simulation. If you have a WLF file that is in a different resolution, you can use the `wlfman` command (CR-370) to change it.

## Saving a simulation to a WLF file

If you add items to the Dataflow, List, or Wave windows, or log items with the **log** command, the results of each simulation run are automatically saved to a WLF file called *vsim.wlf* in the current directory. If you run a new simulation in the same directory, the *vsim.wlf* file is overwritten with the new results.

If you want to save the WLF file and not have it overwritten, select **File > Save> sim dataset** (Main window) or **File > Save Dataset > sim** (Wave window). Or, you can use the **-wlf <filename>** argument to the **vsim** command (CR-213) or the **dataset save** command (CR-69).

▲ **Important:** If you do not use **dataset save** or **dataset snapshot**, you must end a simulation session with a **quit** or **quit -sim** command in order to produce a valid WLF file. If you don't end the simulation in this manner, the WLF file will not close properly, and ModelSim may issue the error message "bad magic number" when you try to open an incomplete dataset in subsequent sessions. If you end up with a "damaged" WLF file, you can try to "repair" it using the **wlfrecover** command (CR-240).

## Opening datasets

To open a dataset, select either **File > Open > Dataset** (Main window) or use the [dataset open](#) command (CR-67).



The Open Dataset dialog includes the following options.

- **Dataset Pathname**  
Identifies the path and filename of the WLF file you want to open.
- **Logical Name for Dataset**  
This is the name by which the dataset will be referred. By default this is the name of the WLF file.

## Viewing dataset structure

Each dataset you open creates a Structure tab in the Main window workspace. The tab is labeled with the name of the dataset and displays the same data as the "[Structure window](#)" (UM-230).

The graphic below shows three Structure tabs: one for the active simulation (*sim*) and one each for two datasets (*gold* and *test*).



If you have too many tabs to display in the available space, you can scroll the tabs left or right by clicking and dragging them.

Each Structure tab has a context menu that you access by clicking the right mouse button anywhere within the Structure tab. See "[Structure window context menu](#)" (UM-232) for details.

## Managing multiple datasets

### *GUI*

When you have one or more datasets open, you can manage them using the **Dataset Browser**. To open the browser, select **View > Datasets** (Main window).



The Dataset Browser dialog box includes the following options.

- **Open**  
Opens the Open Dataset dialog box (see "[Opening datasets](#)" (UM-144)) so you can open additional datasets.
- **Close**  
Closes the selected dataset. This will also remove the dataset's Structure tab in the Main window workspace.
- **Make Active**  
Makes the selected dataset "active." You can also effect this change by double-clicking the dataset name. Active dataset means that if you type a region path as part of a command and omit the dataset prefix, the active dataset will be assumed. It is equivalent to typing `env <dataset>:` at the VSIM prompt. The active dataset is displayed at the bottom of the Main window.
- **Rename**  
Allows you to assign a new logical name for the selected dataset.

### *Command line*

You can open multiple datasets when the simulator is invoked by specifying more than one `vsm -view <filename>` option. By default the dataset prefix will be the filename of the WLF file. You can specify a different dataset name as an optional qualifier to the `vsm -view` switch on the command line using the following syntax:

```
-view <dataset>=<filename>
```

For example: **vsim -view foo=vsim.wlf**

ModelSim designates one of the datasets to be the "active" dataset, and refers all names without dataset prefixes to that dataset. The active dataset is displayed in the context path at the bottom of the Main window. When you select a design unit in a dataset's Structure tab, that dataset becomes active automatically. Alternatively, you can use the Dataset Browser or the **environment** command (CR-81) to change the active dataset.

Design regions and signal names can be fully specified over multiple WLF files by using the dataset name as a prefix in the path. For example:

```
sim:/top/alu/out
view:/top/alu/out
golden:.top.alu.out
```

Dataset prefixes are not required unless more than one dataset is open, and you want to refer to something outside the active dataset. When more than one dataset is open, ModelSim will automatically prefix names in the Wave and List windows with the dataset name. You can change this default by selecting **Tools > Window Preferences** (Wave and List windows).

ModelSim also remembers a "current context" within each open dataset. You can toggle between the current context of each dataset using the **environment** command (CR-81), specifying the dataset without a path. For example:

```
env foo:
```

sets the active dataset to **foo** and the current context to the context last specified for **foo**. The context is then applied to any unlocked windows.

The current context of the current dataset (usually referred to as just "current context") is used for finding objects specified without a path.

The Signals window can be locked to a specific context of a dataset. Being locked to a dataset means that the window will update only when the content of that dataset changes. If locked to both a dataset and a context (e.g., test: /top/foo), the window will update only when that specific context changes. You specify the dataset to which the window is locked by selecting **File > Environment** (Signals window).

### ***Restricting the dataset prefix display***

The default for dataset prefix viewing is set with a variable in *pref.tcl*, **PrefMain(DisplayDatasetPrefix)**. Setting the variable to 1 will display the prefix, setting it to 0 will not. It is set to 1 by default. Either edit the *pref.tcl* file directly or use the **Tools > Edit Preferences** (Main window) command to change the variable value.

Additionally, you can restrict display of the dataset prefix if you use the **environment -nodataset** command to view a dataset. To display the prefix use the **environment** command (CR-81) with the **-dataset** option (you won't need to specify this option if the variable noted above is set to 1). The **environment** command line switches override the *pref.tcl* variable.

## Saving at intervals with Dataset Snapshot

Dataset Snapshot lets you periodically copy data from the current simulation WLF file to another file. This is useful for taking periodic "snapshots" of your simulation or for clearing the current simulation WLF file based on size or elapsed time.

Once you have logged the appropriate items, select **Tools > Dataset Snapshot** (Wave window).



The Dataset Snapshot dialog includes these options:

### Dataset Snapshot State

- Enabled/Disabled**

Enable or disable Dataset Snapshot. All other dialog options are unavailable if Disabled is selected.

### Snapshot Type

- **Simulation Time**

Specifies that data is copied to the specified snapshot file every <x> time units. Default is 1000000 time units.

- **WLF File Size**

Specifies that data is copied to the specified snapshot file whenever the current simulation WLF file reaches <x> megabytes. Default is 100 MB.

### Snapshot Contents

- **Snapshot contains only data since previous snapshot**

Specifies that each snapshot contains only data since the last snapshot. This option causes ModelSim to clear the current simulation WLF file each time a snapshot is taken.

- **Snapshot contains all previous data**

Specifies that each snapshot contains all data from the time signals were first logged. The entire contents of the current simulation WLF file are saved each time a snapshot is taken.

### Snapshot Directory and File

- **Directory**

The directory in which ModelSim saves the snapshot files.

- **File Prefix**

The name of the snapshot files. ModelSim adds .wlf to the snapshot files.

### Overwrite / Increment

- **Always replace snapshot file**

Specifies that a single file is created for all snapshots. Each new snapshot overwrites the previous.

- **Use incrementing suffix on snapshot files**

Specifies that a new file is created for each snapshot. Each new snapshot creates a separate file (e.g., vsim\_snapshot\_1.wlf, vsim\_snapshot\_2.wlf, etc.).

## Virtual Objects (User-defined buses, and more)

Virtual objects are signal-like or region-like objects created in the GUI that do not exist in the ModelSim simulation kernel. ModelSim supports the following kinds of virtual objects:

- [Virtual signals](#) (UM-150)
- [Virtual functions](#) (UM-151)
- [Virtual regions](#) (UM-152)
- [Virtual types](#) (UM-152)

Virtual objects are indicated by an orange diamond as illustrated by *bus* below:



### Virtual signals

Virtual signals are aliases for combinations or subelements of signals written to the WLF file by the simulation kernel. They can be displayed in the Signals, List, and Wave windows, accessed by the **examine** command, and set using the **force** command. You can create virtual signals using the **Tools > Combine Signals** (Wave and List windows) command or use the **virtual signal** command (CR-198). Once created, virtual signals can be dragged and dropped from the Signals window to the Wave and List windows.

Virtual signals are automatically attached to the design region in the hierarchy that corresponds to the nearest common ancestor of all the elements of the virtual signal. The **virtual signal** command has an **-install <region>** option to specify where the virtual signal should be installed. This can be used to install the virtual signal in a user-defined region in

order to reconstruct the original RTL hierarchy when simulating and driving a post-synthesis, gate-level implementation.

A virtual signal can be used to reconstruct RTL-level design buses that were broken down during synthesis. The **virtual hide** command (CR-189) can be used to hide the display of the broken-down bits if you don't want them cluttering up the Signals window.

If the virtual signal has elements from more than one WLF file, it will be automatically installed in the virtual region *virtuals:/Signals*.

Virtual signals are not hierarchical – if two virtual signals are concatenated to become a third virtual signal, the resulting virtual signal will be a concatenation of all the scalar elements of the first two virtual signals.

The definitions of virtuals can be saved to a macro file using the **virtual save** command (CR-196). By default, when quitting, ModelSim will append any newly-created virtuals (that have not been saved) to the *virtuals.do* file in the local directory.

If you have virtual signals displayed in the Wave or List window when you save the Wave or List format, you will need to execute the *virtuals.do* file (or some other equivalent) to restore the virtual signal definitions before you re-load the Wave or List format during a later run. There is one exception: "implicit virtuals" are automatically saved with the Wave or List format.

### ***Implicit and explicit virtuals***

An implicit virtual is a virtual signal that was automatically created by ModelSim without your knowledge and without you providing a name for it. An example would be if you expand a bus in the Wave window, then drag one bit out of the bus to display it separately. That action creates a one-bit virtual signal whose definition is stored in a special location, and is not visible in the Signals window or to the normal virtual commands.

All other virtual signals are considered "explicit virtuals".

## **Virtual functions**

Virtual functions behave in the GUI like signals but are not aliases of combinations or elements of signals logged by the kernel. They consist of logical operations on logged signals and can be dependent on simulation time. They can be displayed in the Signals, Wave, and List windows and accessed by the **examine** command (CR-82), but cannot be set by the **force** command (CR-90).

Examples of virtual functions include the following:

- a function defined as the inverse of a given signal
- a function defined as the exclusive-OR of two signals
- a function defined as a repetitive clock
- a function defined as "the rising edge of CLK delayed by 1.34 ns"

Virtual functions can also be used to convert signal types and map signal values.

The result type of a virtual signal can be any of the types supported in the GUI expression syntax: integer, real, boolean, std\_logic, std\_logic\_vector, and arrays and records of these types. Verilog types are converted to VHDL 9-state std\_logic equivalents and Verilog net strengths are ignored.

Virtual functions can be created using the [virtual function](#) command (CR-186).

Virtual functions are also implicitly created by ModelSim when referencing bit-selects or part-selects of Verilog registers in the GUI, or when expanding Verilog registers in the Signals, Wave, or List window. This is necessary because referencing Verilog register elements requires an intermediate step of shifting and masking of the Verilog "vreg" data structure.

## Virtual regions

User-defined design hierarchy regions can be defined and attached to any existing design region or to the virtuals context tree. They can be used to reconstruct the RTL hierarchy in a gate-level design and to locate virtual signals. Thus, virtual signals and virtual regions can be used in a gate-level design to allow you to use the RTL test bench.

Virtual regions are created and attached using the [virtual region](#) command (CR-195).

## Virtual types

User-defined enumerated types can be defined in order to display signal bit sequences as meaningful alphanumeric names. The virtual type is then used in a type conversion expression to convert a signal to values of the new type. When the converted signal is displayed in any of the windows, the value will be displayed as the enumeration string corresponding to the value of the original signal.

Virtual types are created using the [virtual type](#) command (CR-201).

## Dataset, WLF file, and virtual commands

The table below provides a brief description of the actions associated with datasets, WLF files, and virtual commands. For complete details about syntax, arguments, and usage, refer to the *ModelSim Command Reference*.

| Command name                                  | Action                                                                                                                           |
|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">dataset alias</a> (CR-62)         | assigns an additional name (alias) to a dataset                                                                                  |
| <a href="#">dataset clear</a> (CR-63)         | removes all event data from the current simulation WLF file while keeping all currently logged signals logged                    |
| <a href="#">dataset close</a> (CR-64)         | closes the specified dataset                                                                                                     |
| <a href="#">dataset info</a> (CR-65)          | reports a variety of information about a dataset                                                                                 |
| <a href="#">dataset list</a> (CR-66)          | lists all open datasets                                                                                                          |
| <a href="#">dataset open</a> (CR-67)          | opens a WLF file                                                                                                                 |
| <a href="#">dataset rename</a> (CR-68)        | assigns a new logical name to the specified dataset                                                                              |
| <a href="#">dataset save</a> (CR-69)          | saves the current simulation to a WLF file                                                                                       |
| <a href="#">dataset snapshot</a> (CR-70)      | saves the current simulation to a WLF file at regular intervals                                                                  |
| <a href="#">log</a> (CR-95)                   | creates a WLF file for the current simulation                                                                                    |
| <a href="#">nolog</a> (CR-111)                | suspends writing of data to the WLF file for the specified signals                                                               |
| <a href="#">searchlog</a> (CR-135)            | searches one or more of the currently open WLF files for a specified condition                                                   |
| <a href="#">virtual function</a> (CR-186)     | creates a new signal that consists of logical operations on existing signals and simulation time                                 |
| <a href="#">virtual region</a> (CR-195)       | creates a new user-defined design hierarchy region                                                                               |
| <a href="#">virtual signal</a> (CR-198)       | creates a new signal that consists of concatenations of signals and subelements                                                  |
| <a href="#">virtual type</a> (CR-201)         | creates a new enumerated type                                                                                                    |
| <a href="#">vsim</a> (CR-213) -wlf <filename> | creates a WLF file for the simulation which can be reopened as a dataset                                                         |
| <a href="#">wlf2log</a> (CR-234)              | translates a ModelSim WLF file ( <i>vsim.wlf</i> ) to a QuickSim II logfile                                                      |
| <a href="#">wlfman</a> (CR-237)               | allows you to get information about and manipulate WLF files                                                                     |
| <a href="#">wlfrecover</a> (CR-240)           | attempts to "repair" WLF files that are incomplete due to a crash or the file being copied prior to completion of the simulation |



## 8 - Graphic interface

---

### Chapter contents

|                                                 |        |
|-------------------------------------------------|--------|
| Window overview . . . . .                       | UM-156 |
| Common window features . . . . .                | UM-157 |
| Main window . . . . .                           | UM-163 |
| Dataflow window . . . . .                       | UM-171 |
| List window . . . . .                           | UM-187 |
| Memory window . . . . .                         | UM-201 |
| Process window . . . . .                        | UM-213 |
| Signals window . . . . .                        | UM-215 |
| Source window . . . . .                         | UM-224 |
| Structure window . . . . .                      | UM-230 |
| Variables window . . . . .                      | UM-233 |
| Wave window . . . . .                           | UM-236 |
| Compiling with the graphic interface . . . . .  | UM-265 |
| Simulating with the graphic interface . . . . . | UM-272 |
| Creating and managing breakpoints . . . . .     | UM-284 |
| Miscellaneous tools and add-ons . . . . .       | UM-288 |

## Window overview

The ModelSim simulation and debugging environment consists of many windows. A brief description of each window follows:

- [Main window](#) (UM-163)  
The initial window that appears upon startup. All subsequent ModelSim windows are opened from the Main window. This window contains the session transcript and the Workspace, which can contain Project, Library, Structure, and Files tabs.
- [Dataflow window](#) (UM-171)  
Lets you trace signals and nets through your VHDL/Verilog design by showing related processes.
- [List window](#) (UM-187)  
Shows the simulation values of selected VHDL signals and variables Verilog nets, registers, and variables in tabular format.
- [Memory window](#) (UM-201)  
Displays memories in the current design context.
- [Process window](#) (UM-213)  
Displays a list of processes in the region currently selected in the Structure window.
- [Signals window](#) (UM-215)  
Shows the names and current values of VHDL signals, and Verilog nets, registers, and variables in the region currently selected in the Structure window.
- [Source window](#) (UM-224)  
Displays the HDL source code for the design.
- [Structure window](#) (UM-230)  
Displays the hierarchy of structural elements such as VHDL component instances, packages, blocks, generate statements Verilog module instances, named blocks, tasks and functions. In versions 5.5 and later, this same information is displayed in the Main window workspace.
- [Variables window](#) (UM-233)  
Displays VHDL constants, generics, variables, and Verilog registers and variables in the current process and their current values.
- [Wave window](#) (UM-236)  
Displays waveforms, and current values for the VHDL signals and variables Verilog nets, registers, and variables you have selected. Current and past simulations can be compared side-by-side in one Wave window.

## Common window features

ModelSim's graphic interface provides many features that add to its usability; features common to many of the windows are described below.

| Feature                                                                                                                     | Feature applies to these windows                                                 |
|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| <a href="#">Quick access toolbars</a> (UM-158)                                                                              | Dataflow, Main, Source, and Wave windows                                         |
| <a href="#">Drag and drop</a> (UM-160)                                                                                      | Dataflow, List, Process, Signals, Source, Structure, Variables, and Wave windows |
| <a href="#">Automatic window updating</a> (UM-160)                                                                          | Dataflow, Memory Process, Signals, and Structure windows                         |
| <a href="#">Finding names</a> (UM-161)                                                                                      | various windows                                                                  |
| <a href="#">Sorting items</a> (UM-161)                                                                                      | Process, Signals, Source, Structure, Variables and Wave windows                  |
| <a href="#">Menu tear off</a> (UM-161)                                                                                      | all windows                                                                      |
| <a href="#">Combining items in the List window</a> (UM-193),<br><a href="#">Combining items in the Wave window</a> (UM-244) | List and Wave windows                                                            |
| <a href="#">Tree window hierarchical view</a> (UM-162)                                                                      | Structure, Signals, Variables, and Wave windows                                  |

- Cut/Copy/Paste/Delete into any entry box by clicking the right mouse button in the entry box.
- Standard cut/copy/paste shortcut keystrokes –  $\text{^X}/\text{^C}/\text{^V}$  – will work in all entry boxes.
- When the focus changes to an entry box, the contents of that box are selected (highlighted). This allows you to replace the current contents of the entry box with new contents with a simple paste command, without having to delete the old value.
- Dialog boxes will appear on top of their parent window (instead of the upper left corner of the screen).
- You can change the title of any window with the -title switch of the **view** command. See [view command](#) (CR-179) for details.



- The middle mouse button will allow you to paste the following into the transcript window:
  - text currently selected in the transcript window,
  - a current primary X-Windows selection (can be from another application), or
  - contents of the clipboard.
- The **Edit > Paste** operation in the Transcript pane will ONLY paste from the clipboard.
- All menus highlight their accelerator keys.

## Quick access toolbars

Toolbar buttons in several windows provide access to commonly used commands and functions. These toolbars can be docked and undocked (moved to or from the main toolbar area) by clicking and dragging on the vertical bar at the left-edge of a toolbar.

You can also hide/show the various toolbars. To hide or show a toolbar, right-click on a blank spot of the main toolbar area and select a toolbar from the list.



To reset the toolbars to their original state, right-click on a blank spot of the main toolbar area and select **Reset**.

## Columnar information display

Many windows (e.g., Main, Signals, Structure) display information in a columnar format. You can sort by any of the columns by clicking the column heading. Click once to sort in ascending order; click again to sort in descending order.

Also, you can hide or show columns by either right-clicking a column heading and selecting an item from the context menu or by clicking the column-list drop down arrow and selecting an item.

| Name            | Value  | Mode     |
|-----------------|--------|----------|
| fifo_reset      | U      | Out      |
| int_ack         | U      | In       |
| data_strobe     | U      | Out      |
| slot_window     | U      | Out      |
| overhead_octet  | U      | Out      |
| buffer_in       | U      | In       |
| sout            | UUUUUU | Internal |
| sfull           | U      | Internal |
| retime_crc_rise | U      | Internal |
| retime_crc_fall | U      | Internal |

## Docking and undocking panes

Several windows are made up of multiple "panes." When you see a double bar at the top edge of a window area, it means you can click and drag the pane to "undock" it from the parent window. Once the pane is undocked, it becomes a free-floating window.

To redock a floating pane, click on the double bar at the top of the window and drag it back into the parent window.

## Drag and drop

Drag and drop of items is possible between the following windows. Using the left mouse button, click and release to select an item, then click and hold to drag it.

- Drag items from these windows:**

Dataflow, List, Process, Signals, Source, Structure, Variables, and Wave windows

- Drop items into these windows:**

Dataflow, List, Structure, and Wave windows

Drag and drop works to rearrange items *within* the List and Wave windows as well.

## Automatic window updating

Selecting an item in the following windows automatically updates other related ModelSim windows as indicated below:

| Select an item in this window                                                        | To update these windows                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">Dataflow window</a> (UM-171)                                             | <a href="#">Memory window</a> (UM-201)<br><a href="#">Process window</a> (UM-213)<br><a href="#">Signals window</a> (UM-215)<br><a href="#">Source window</a> (UM-224)<br><a href="#">Structure window</a> (UM-230)<br><a href="#">Variables window</a> (UM-233) |
| <a href="#">Process window</a> (UM-213)                                              | <a href="#">Dataflow window</a> (UM-171)<br><a href="#">Signals window</a> (UM-215)<br><a href="#">Source window</a> (UM-224)<br><a href="#">Variables window</a> (UM-233)                                                                                       |
| <a href="#">Signals window</a> (UM-215)                                              | <a href="#">Dataflow window</a> (UM-171)                                                                                                                                                                                                                         |
| <a href="#">Structure window</a> (UM-230) or structure pane in Main window Workspace | <a href="#">Memory window</a> (UM-201)<br><a href="#">Process window</a> (UM-213)<br><a href="#">Signals window</a> (UM-215)<br><a href="#">Source window</a> (UM-224)<br><a href="#">Variables window</a> (UM-233)                                              |

## Finding names

- **Find** item names with the **Edit > Find** menu selection in these windows: Dataflow, List, Process, Signals, Source, Structure, Variables, and Wave windows.  
A **Find** request that starts with a backslash (\ ) forces case sensitivity. Elsewhere in the pattern backslashes are used to escape special interpretation of basic regular expression characters. To search explicitly for a backslash character, it is necessary to escape the character. For example, to match \Arch Signal 1\, the pattern \\Arch... is required.

## Sorting items

Use the **View > Sort** menu selection in the Process, Signals, Structure, Variables, and Wave windows to sort items in ascending, descending or declaration order.

Names such as *net\_1*, *net\_10*, and *net\_2* will sort numerically in the Signals and Wave windows.

## Saving window layout

You can save the current positions and sizes of ModelSim windows as a default. Follow these steps to save the layout as a default:

- 1 Position and size the windows the way you want them to display.
- 2 Select **Tools > Save Preferences** (Main window) and save the *modelsim.tcl* file into the desired directory.
- 3 Modify the "Working Directory" of your ModelSim shortcut to point at the directory, or set the MODELSIM\_TCL environment variable to point at the *modelsim.tcl* file (see "[Creating environment variables in Windows](#)" (UM-367) for more details).

## Context menus

Context menus refer to menus that "pop-up" in the middle of the interface by clicking the right mouse button. The commands on the menu change depending on where in the interface you click. In other words, the menus change based on the context of their use. These menus are available in the following windows: Dataflow, List, Main, Memory, Signals, Source, Structure, and Wave.

## Menu tear off

All window menus can be "torn off" to create a separate menu window. To tear off, click on the menu, then select the dotted-line button at the top of the menu.

## Tree window hierarchical view

ModelSim provides a hierarchical, or "tree view" of your design in various windows (e.g., Main, Signals, Structure).



Depending on which window you are viewing, you will see various design items. Icons denote the item type as follows:

- Blue circle – Verilog item
- Blue square – VHDL item
- Green diamond – SystemC item
- Orange diamond – Virtual item
- Yellow triangle – Comparison item

See the individual window descriptions later in the chapter for which items are viewable in which windows.

### ***Viewing the hierarchy***

Whenever you see a tree view, you can use the mouse to collapse or expand the hierarchy. Select the symbols as shown below to change the view of the structure.

| Symbol | Description                                                  |
|--------|--------------------------------------------------------------|
| [ + ]  | click a plus box to expand the item and view the structure   |
| [ - ]  | click a minus box to hide a hierarchy that has been expanded |

## Main window

The Main window is pictured below as it appears when ModelSim is first invoked. Note that your operating system graphic interface provides the window-management frame only; ModelSim handles all internal-window features including menus, buttons, and scroll bars.



You can customize the Main window layout—click and drag on the bars noted in the graphic above to change the position of the panes and toolbars. You can also change the relative size of each pane by dragging on its border. The graphic below shows a customized layout.



The graphic below shows the Main window as it might appear when you have a project and a design loaded.



The menu bar at the top of the window provides access to a wide variety of simulation commands and ModelSim preferences. The toolbar provides buttons for quick access to the many common commands. The status bar at the bottom of the window gives you information about the data in the active ModelSim window. The panes display different parts of your design or different features of ModelSim. The panes, menu bar, toolbar, and status bar are described in detail below.

## Workspace

The Workspace is available in ModelSim versions 5.5 and later. It provides convenient access to projects, libraries, design files, compiled design units, simulation/dataset structures, and Waveform Comparison objects. It can be hidden or displayed by selecting **View > Workspace** (Main window).

The Workspace can display five types of tabs as shown in the graphic above.

- **Project tab**

Shows all files that are included in the open project. See *Chapter 2 - Projects* for details.

- **Library tab**

Shows design libraries and compiled design units. See "[Managing library contents](#)" (UM-47) for details.

- **Structure tabs**

Shows a hierarchical view of the active simulation and any open datasets. This is the same data that is displayed in the "[Structure window](#)" (UM-230). There is one tab for the current simulation (named "sim") and one tab for each open dataset. See "[Viewing dataset structure](#)" (UM-145) for details.

- **Files tab**

Shows the source files for the loaded design.

## Transcript

The Transcript portion of the Main window maintains a running history of commands that are invoked and messages that occur as you work with ModelSim. When a simulation is running, the Transcript displays a VSIM prompt, allowing you to enter command-line commands from within the graphic interface.

You can scroll backward and forward through the current work history by using the vertical scrollbar. You can also use arrow keys to recall previous commands, or copy and paste using the mouse within the window (see "[Mouse and keyboard shortcuts](#)" (UM-170) for details).

### **Saving the Main window transcript file**

Variable settings determine the filename used for saving the Main window transcript. If either **PrefMain(file)** in the *modelsim.tcl* file or **TranscriptFile** in the *modelsim.ini* file is set, then the transcript output is logged to the specified file. By default the **TranscriptFile** variable in *modelsim.ini* is set to *transcript*. If either variable is set, the transcript contents are always saved and no explicit saving is necessary.

If you would like to save an additional copy of the transcript with a different filename, you can use the **File > Transcript > Save Transcript As**, or **File > Transcript > Save Transcript** menu items. The initial save must be made with the **Save Transcript As** selection, which stores the filename in the Tcl variable **PrefMain(saveFile)**. Subsequent saves can be made with the **Save Transcript** selection. Since no automatic saves are performed for this file, it is written only when you invoke a **Save** command. The file is written to the specified directory and records the contents of the transcript at the time of the save.

### **Using the saved transcript as a macro (DO file)**

Saved transcript files can be used as macros (DO files). See the **do** command (CR-75) for more information.

## Active processes

This pane displays all processes that are scheduled to run during the current simulation cycle. You can hide or display this pane by selecting **View > Active Processes** (Main window). This same data can be displayed in the "[Process window](#)" (UM-213).

## The Main window menu bar

This section provides information on select menu commands available in the Main window. Many of the commands are also available from a context menu (click right or 3rd mouse button within the window panes).

### File menu

|                  |                                                                                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| New              | Folder – create a new folder in the current directory<br>Library – create a new design library and mapping; see " <a href="#">Creating a library</a> " (UM-46) |
| Import           | Library – import FPGA libraries; see " <a href="#">Importing FPGA libraries</a> " (UM-56)                                                                      |
| Change Directory | this command is disabled if you have a project or dataset open or a simulation running                                                                         |
| Transcript       | Save Transcript – save the Main window transcript; see " <a href="#">Saving the Main window transcript file</a> " (UM-165)                                     |
| Add to Project   | these commands are only available if you have a project open; see <i>Chapter 2 - Projects</i>                                                                  |

### View menu

|                  |                                                                                                                                                                                                  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Encoding         | select from alphabetical list of encoding names that enable proper display of character representations used by various operating systems or file systems, such as Unicode, ASCII, or Shift-JIS. |
| Properties       | show information about the item selected in the Workspace                                                                                                                                        |
| Project Settings | show information about the open project; disabled if you don't have a project open                                                                                                               |

**Compile menu**

|                  |                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Compile          | compile source files; disabled if you have a project open                                                                                                             |
| Compile Options  | set various compile options; see " <a href="#">Setting default compile options</a> " (UM-267); disabled if you have a project open                                    |
| Compile All      | compile all files in the open project; disabled if you don't have a project open                                                                                      |
| Compile Selected | compile the files selected in the project tab; disabled if you don't have a project open                                                                              |
| Compile Order    | set the compile order of the files in the open project; see " <a href="#">Changing compile order</a> " (UM-32) for details; disabled if you don't have a project open |
| Compile Report   | report on the compilation history of the selected file(s) in the project; disabled if you don't have a project open                                                   |
| Compile Summary  | report on the compilation history of all files in the project; disabled if you don't have a project open                                                              |

**Simulate menu**

|                    |                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Simulate           | load the selected design unit with the specified options; see " <a href="#">Simulating with the graphic interface</a> " (UM-272)                                                                                                                                                                                                                      |
| Simulation Options | set various simulation options; see " <a href="#">Setting default simulation options</a> " (UM-281)                                                                                                                                                                                                                                                   |
| Run                | Restart – reload the design elements and reset the simulation time to zero; only design elements that have changed are reloaded; you specify whether to maintain the following after restart–List and Wave window environment, breakpoints, logged signals, virtual definitions, and assertion settings; see also the <b>restart</b> command (CR-130) |

**Tools menu**

|                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Breakpoints                                                   | open the Breakpoints dialog box; see " <a href="#">Setting file-line breakpoints</a> " (UM-228) for details                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Options<br>(all options are set for the current session only) | <p>provides these options:</p> <p>Transcript File – set a transcript file to save for this session only</p> <p>Command History – set a file for saving command history only, no comments</p> <p>Save File – set filename for Save Transcript, and Save Transcript As</p> <p>Saved Lines – limit the number of lines saved in the transcript (default is 5000)</p> <p>Line Prefix – specify the comment prefix for the transcript</p> <p>Update Rate – specify the update frequency for the Main window status bar</p> <p>ModelSim Prompt – change the title of the ModelSim prompt</p> <p>VSIM Prompt – change the title of the VSIM prompt</p> <p>Paused Prompt – change the title of the Paused prompt</p> <p>HTML Viewer – specify the path to your browser; used for displaying online help</p> <p>PDF Viewer – specify the path to your PDF viewer; used to display documentation</p> |
| Edit Preferences                                              | set various preference variables; see " <a href="#">Preference variables located in Tcl files</a> " (UM-381) for more information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Save Preferences                                              | save current ModelSim settings to a Tcl preference file; see " <a href="#">Preference variables located in Tcl files</a> " (UM-381) for more information                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

**Window menu**

|                           |                                                                                                                                                                                                                                                                                                                                     |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Initial Layout            | restore all windows to the size and placement of the initial full-screen layout                                                                                                                                                                                                                                                     |
| Layout Style <sup>a</sup> | provides these options:<br>Default - restore the windows to version 5.5 layout<br>Millennium - restore the windows to version 5.6 layout<br>Classic - restore the windows to pre-5.5 layout<br>Cascade - cascade all open windows<br>Horizontal - tile all open windows horizontally<br>Vertical - tile all open windows vertically |

a. You can specify a Layout Style to become the default for ModelSim. After choosing the Layout Style you want, select **Tools > Save Preferences** and the layout style will be saved to the PrefMain(layoutStyle) preference variable.

## The Main window status bar



Fields at the bottom of the Main window provide the following information about the current simulation:

| Field       | Description                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Project     | name of the current project                                                                                                                                                                                       |
| Now         | the current simulation time, using the default resolution units (see " <a href="#">Simulating with the graphic interface</a> " (UM-272)), or a larger time unit if one can be used without a fractional remainder |
| Delta       | the current simulation iteration number                                                                                                                                                                           |
| environment | name of the current context (item selected in the <a href="#">Structure window</a> (UM-230))                                                                                                                      |

## Mouse and keyboard shortcuts

See "[Main and Source window mouse and keyboard shortcuts](#)" (UM-389).

## Dataflow window

The Dataflow window allows you to explore the "physical" connectivity of your design.

- ▶ **Note:** OEM versions of ModelSim have limited Dataflow functionality. Many of the features described below will operate differently. The window will show only one process and its attached signals or one signal and its attached processes, as displayed in the graphic below.

### Items you can view



The Dataflow window displays processes and signals, nets, and registers. The window has built-in mappings for all Verilog primitive gates (i.e., AND, OR, etc.). For components other than Verilog primitives, you can define a mapping between processes and built-in symbols. See "[Symbol mapping](#)" (UM-184) for details.

## Adding items to the window

You can use any of the following methods to add items to the Dataflow window:

- drag and drop items from other windows
- use the Navigate menu options in the Dataflow window
- use the **add dataflow** command (CR-37)
- double-click any waveform in the Wave window display

The **Navigate** menu offers four commands that will add items to the window. The commands include:

**View region** — clear the window and display all signals from the current region

**Add region** — display all signals from the current region without first clearing window

**View all nets** — clear the window and display all signals from the entire design

**Add ports** — add port symbols to the port signals in the current region

When you view regions or entire nets, the window initially displays only the drivers of the added items in order to reduce clutter. You can easily view readers by selecting an item and invoking **Navigate > Expand net to readers**.

A small circle above an input signal on a block denotes a trigger signal that is on the process' sensitivity list.

## Links to other windows

The Dataflow window has links to other windows as described below:

| Window                                  | Link                                                                                                                                                                                                                                                   |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">Main window</a> (UM-163)    | select a signal or process in the Dataflow window, and the Structure pane updates if that item is in a different design unit                                                                                                                           |
| <a href="#">Process window</a> (UM-213) | select a process in either window, and that process is highlighted in the other                                                                                                                                                                        |
| <a href="#">Signals window</a> (UM-215) | select a signal in either window, and that signal is highlighted in the other                                                                                                                                                                          |
| <a href="#">Wave window</a> (UM-236)    | <ul style="list-style-type: none"> <li>• trace through the design in the Dataflow window, and the associated signals are added to the Wave window</li> <li>• move a cursor in the Wave window, and the values update in the Dataflow window</li> </ul> |
| <a href="#">Source window</a> (UM-224)  | select an item in the Dataflow window, and the Source window updates if that item is in a different source file                                                                                                                                        |

## Dataflow window menu bar

This section provides information on select menu commands available in the Dataflow window. Many of the commands are also available from the context menu (click right or 3rd mouse button).

### Edit menu

|                 |                                                      |
|-----------------|------------------------------------------------------|
| Erase selected  | clear the selected object from the window            |
| Erase highlight | remove green highlighting from interconnect lines    |
| Regenerate      | clear and redraw the display using an optimal layout |

### View menu

|           |                                                                           |
|-----------|---------------------------------------------------------------------------|
| Show Wave | open the embedded wave viewer pane                                        |
| Select    | set left mouse button to select mode and middle mouse button to zoom mode |
| Zoom      | set left mouse button to zoom mode and middle mouse button to pan mode    |
| Pan       | set left mouse button to pan mode and middle mouse button to zoom mode    |
| Default   | set mouse to default mode                                                 |

### Navigate menu

|                            |                                                                                                                                               |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Expand net to drivers      | display driver(s) of the selected signal, net, or register                                                                                    |
| Expand net to readers      | display reader(s) of the selected signal, net, or register                                                                                    |
| Expand net                 | display driver(s) and reader(s) of the selected signal, net, or register                                                                      |
| Expand to design inputs    | display the top-level driver of the net, which will most likely be in a testbench or in the top entity or module                              |
| Expand to hierarchy inputs | display the primary driver (port) of the net within its level of hierarchy                                                                    |
| Hide selected              | remove the selected component and all other components from the same region and replace them with a single component representing that region |
| Show selected              | expand the selected component to show all underlying components                                                                               |

|               |                                                                               |
|---------------|-------------------------------------------------------------------------------|
| View region   | clear the window and display all signals from the current region              |
| Add region    | display all signals from the current region without first clearing the window |
| View all nets | clear the window and display all signals from the entire design               |
| Add ports     | add port symbols to the port signals in the current region                    |

**Trace menu**

|                   |                                                                                |
|-------------------|--------------------------------------------------------------------------------|
| TraceX™           | step back to the last driver of an unknown (X) value                           |
| ChaseX™           | jump to the source of an unknown (X) value                                     |
| TraceX Delay      | step back in time to the last driver of an unknown (X) value                   |
| ChaseX Delay      | jump back in time to the point where the output value transitions to X         |
| Trace next event  | move the next event cursor to the next input event driving the selected output |
| Trace event set   | jump to the source of the selected input event                                 |
| Trace event reset | return the next event cursor to the selected output                            |

**Tools menu**

|                          |                                                                                                |
|--------------------------|------------------------------------------------------------------------------------------------|
| Load built-in symbol map | load a .bsm file for mapping symbol instances; see " <a href="#">Symbol mapping</a> " (UM-184) |
| Load symlib library      | load a user-defined symbol library                                                             |
| Create symlib index      | create an index for a user-defined symbol library                                              |
| Options                  | configure Dataflow window preferences                                                          |

**Window menu**

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Exploring the connectivity of your design

A primary use of the Dataflow window is exploring the "physical" connectivity of your design. One way of doing this is by expanding the view from process to process. This allows you to see the drivers/receivers of a particular signal, net, or register.

You can expand the view of your design using menu commands or your mouse. To expand with the mouse, simply double click a signal, register, or process. Depending on the specific item you click, the view will expand to show the driving process and interconnect, the reading process and interconnect, or both.

Alternatively, you can select a signal, register, or net, and use one of the toolbar buttons or menu commands described below:

|                                                                                                                                                                                                               |                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| <br><b>Expand net to all drivers</b><br>display driver(s) of the selected signal, net, or register                           | Navigate > Expand net to drivers |
| <br><b>Expand net to all drivers and readers</b><br>display driver(s) and reader(s) of the selected signal, net, or register | Navigate > Expand net            |
| <br><b>Expand net to all readers</b><br>display reader(s) of the selected signal, net, or register                          | Navigate > Expand net to readers |

As you expand the view, note that the "layout" of the design may adjust to best show the connectivity. For example, the location of an input signal may shift from the bottom to the top of a process.

### Tracking your path through the design

You can quickly traverse through many components in your design. To help mark your path, the items that you have expanded are highlighted in green.



You can clear this highlighting using the **Edit > Erase highlight** command.



### The embedded wave viewer

Another way of exploring your design is to use the Dataflow window's embedded wave viewer. This viewer closely resembles, in appearance and operation, the stand-alone Wave window (see "[Wave window](#)" (UM-236) for more information).

The wave viewer is opened using the **View > Show Wave** command.



One common scenario is to place signals in the wave viewer and the Dataflow panes, run the design for some amount of time, and then use time cursors to investigate value changes. In other words, as you place and move cursors in the wave viewer pane (see "[Using time cursors in the Wave window](#)" (UM-255) for details), the signal values update in the Dataflow pane.



Another scenario is to select a process in the Dataflow pane, which automatically adds to the wave viewer pane all signals attached to the process.

See "[Tracing events \(causality\)](#)" (UM-178) for another example of using the embedded wave viewer.

## Zooming and panning

The Dataflow window offers several tools for zooming and panning the display.

### ***Zooming with toolbar buttons***

These zoom buttons are available on the toolbar:

|                                                                                                                                                         |                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <br><b>Zoom In</b><br>zoom in by a factor of two from the current view | <br><b>Zoom Out</b><br>zoom out by a factor of two from current view |
| <br><b>Zoom Full</b><br>zoom out to view the entire schematic          |                                                                                                                                                       |

### ***Zooming with the mouse***

To zoom with the mouse, you can either use the middle mouse button or enter Zoom Mode by selecting **View > Zoom** and then use the left mouse button.

Four zoom options are possible by clicking and dragging in different directions:

- Down-Right: Zoom Area (In)
- Up-Right: Zoom Out (zoom amount is displayed at the mouse cursor)
- Down-Left: Zoom Selected
- Up-Left: Zoom Full

The zoom amount is displayed at the mouse cursor. A zoom operation must be more than 10 pixels to activate.

### ***Panning with the mouse***

You can pan with the mouse in two ways: 1) enter Pan Mode by selecting **View > Pan** and then drag with the left mouse button to move the design; 2) hold down the **<Ctrl>** key and drag with the middle mouse button to move the design.

## Tracing events (causality)

One of the most useful features of the Dataflow window is tracing an event to see the cause of an unexpected output. This feature uses the Dataflow window's embedded wave viewer (see "[The embedded wave viewer](#)" (UM-176) for more details).

In short you identify an output of interest in the Dataflow pane and then use time cursors in the wave viewer pane to identify events that contribute to the output.

The process for tracing events is as follows:

- 1** Log all signals before starting the simulation (add log -r /\*).
- 2** After running a simulation for some period of time, open the Dataflow window and the wave viewer pane.
- 3** Add a process or signal of interest into the Dataflow window (if adding a signal, find its driving process). Select the process and all signals attached to the selected process will appear in the wave viewer pane.
- 4** Place a time cursor on an edge of interest; the edge should be on a signal that is an output of the process.

- 5** Select **Trace > Trace next event**.



A second cursor is added at the most recent input event.

- 6** Keep selecting **Trace > Trace next event** until you've reached an input event of interest. Note that the signals with the events are selected in the wave pane.

- 7** Now select **Trace > Trace event set**.



The Dataflow display "jumps" to the source of the selected input event(s). The operation follows all signals selected in the wave viewer pane. You can change which signals are followed by changing the selection.

- 8** To continue tracing, go back to step 5 and repeat.

If you want to start over at the originally selected output, select **Trace > Trace event reset**.

## Tracing the source of an unknown (X)

Another useful debugging option is locating the source of an unknown (X). Unknown values are most clearly seen in the Wave window—the waveform displays in red when a value is unknown.



The procedure for tracing an unknown is as follows:

- 1 Load your design.
- 2 Log all signals in the design or any signals that may possibly contribute to the unknown value (`log -r /*` will log all signals in the design).
- 3 Add signals to the Wave window or wave viewer pane, and run your design the desired length of time.
- 4 Put a cursor on the time at which the signal value is unknown.
- 5 Add the signal of interest to the Dataflow window, making sure the signal is selected.
- 6 Select **Trace > TraceX**, **Trace > TraceX Delay**, **Trace > ChaseX**, or **Trace > ChaseX Delay**.

These commands behave as follows:

**TraceX / TraceX Delay**—Step back to the last driver of an X value. **TraceX Delay** works similarly but it steps back in time to the last driver of an X value. **TraceX** should be used for RTL designs; **TraceX Delay** should be used for gate-level netlists with backannotated delays.

**ChaseX / ChaseX Delay** — "Jumps" through a design from output to input, following X values. **ChaseX Delay** acts the same as **ChaseX** but also moves backwards in time to the point where the output value transitions to X. **ChaseX** should be used for RTL designs; **ChaseX Delay** should be used for gate-level netlists with backannotated delays.

## Finding items by name in the Dataflow window

Select **Edit > Find** to search for signal, net, or register names or an instance of a component.



Enter an item name and specify whether it is an instance of a process (Instance); a signal, net, or register (Signal); or either (Any).

Specify **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find */top/clk* and *clk1*.

If you want to zoom in on the located item, select **Zoom To**. You can continue searching using the **Find Next** button.

## Saving the display

### *Saving a .eps file*

Select **File > Print Postscript** to save the waveform as a .eps file.



The **Print Postscript** dialog box includes these options:

#### Printer

- **File name**

Enter a filename for the encapsulated Postscript (.eps) file to create; or browse to a previously created .eps file and use that filename.

#### Paper

#### Setup button

See "[Printer Page Setup](#)" (UM-263).

### **Printing on Windows platforms**

Select **File > Print** to print the Dataflow display or to save the display to a file.



The **Print** dialog box includes these options:

#### **Printer**

- **Name**

Choose the printer from the drop-down menu. Set printer properties with the *Properties* button.

- **Status**

Indicates the availability of the selected printer.

- **Type**

Printer driver name for the selected printer. The driver determines what type of file is output if "Print to file" is selected.

- **Where**

The printer port for the selected printer.

- **Comment**

The printer comment from the printer properties dialog box.

- **Print to file**

Make this selection to print the display to a file instead of a printer. The printer driver determines what type of file is created. Postscript printers create a Postscript (.ps) file, non-Postscript printers create a .prn or printer control language file. To create an encapsulated Postscript file (.eps) use the **File > Print Postscript** menu selection.

## Configuring page setup

Clicking the Setup button in the Print Postscript or Print dialog box allows you to define the following options (this is the same dialog that opens via **File > Page setup**).



The **Dataflow Page Setup** dialog box includes these options:

- **View**  
Specifies **Full** (everything in the window) or **Current View** (only that which is visible).
- **Highlight**  
Specifies that highlighting (see "Tracking your path through the design" (UM-175)) is **On** or **Off**.
- **Color Mode**  
Specifies **Color** (256 colors), **Invert Color** (gray-scale) or **Mono** (monochrome) color mode.
- **Orientation**  
Specifies **Landscape** (horizontal) or **Portrait** (vertical) orientation.
- **Paper**  
Specifies the font to use for printing.

## Symbol mapping

The Dataflow window has built-in mappings for all Verilog primitive gates (i.e., AND, OR, etc.). For components other than Verilog primitives, you can define a mapping between processes and built-in symbols. This is done through a file containing name pairs, one per line, where the first name is the concatenation of the design unit and process names, (DName.Processname), and the second name is the name of a built-in symbol. For example:

```
xorg(only).p1 XOR
org(only).p1 OR
andg(only).p1 AND
```

Entities and modules are mapped the same way:

```
AND1 AND
AND2 AND # A 2-input and gate
AND3 AND
AND4 AND
AND5 AND
AND6 AND
xnor(test) XNOR
```

Note that for primitive gate symbols, pin mapping is automatic.

The Dataflow window looks in the current working directory and inside each library referenced by the design for the file *dataflow.bsm* (.bsm stands for "Built-in Symbol Map"). It will read all files found.

### User-defined symbols

You can also define your own symbols using an ASCII symbol library file format for defining symbol shapes. This capability is delivered via Concept Engineering's NIview™ widget Symlib format. For more specific details on this widget, see [www.model.com/support/documentation/BOOK/nlviewSymlib.pdf](http://www.model.com/support/documentation/BOOK/nlviewSymlib.pdf).

The Dataflow window will search the current working directory, and inside each library referenced by the design, for the file *dataflow.sym*. Any and all files found will be given to the NIview widget to use for symbol lookups. Again, as with the built-in symbols, the DU name and optional process name is used for the symbol lookup. Here's an example of a symbol for a full adder:

```
symbol adder(structural) * DEF \
    port a in -loc -12 -15 0 -15 \
    pinattdsp @name -cl 2 -15 8 \
    port b in -loc -12 15 0 15 \
    pinattdsp @name -cl 2 15 8 \
    port cin in -loc 20 -40 20 -28 \
    pinattdsp @name -uc 19 -26 8 \
    port cout out -loc 20 40 20 28 \
    pinattdsp @name -lc 19 26 8 \
    port sum out -loc 63 0 51 0 \
    pinattdsp @name -cr 49 0 8 \
    path 10 0 0 7 \
    path 0 7 0 35 \
    path 0 35 51 17 \
    path 51 17 51 -17 \
    path 51 -17 0 -35 \
    path 0 -35 0 -7 \
    path 0 -7 10 0
```

Port mapping is done by name for these symbols, so the port names in the symbol definition must match the port names of the Entity|Module|Process (in the case of the process, it's the signal names that the process reads/writes).

**Important:** When you create or modify a symlib file, you must generate a file index. This index is how the Nlview widget finds and extracts symbols from the file. To generate the index, select **Tools > Create symlib index** (Dataflow window) and specify the symlib file. The file will be rewritten with a correct, up-to-date index.

## Configuring window options

You can configure several options that determine how the Dataflow window behaves. The settings affect only the current session.

Select **Tools > Options** to open the Dataflow Options dialog box.



The **General options** tab includes these options:

- **Hide Cells**  
By default the Dataflow window automatically hides instances that have either 'celldefine, VITAL\_LEVEL0, or VITAL\_LEVEL1 attributes. Unchecking this disables automatic cell hiding.
- **Keep Dataflow**  
Keeps previous contents when adding new signals or processes to the window.
- **Show Hierarchy**  
Displays connectivity using hierarchical references. Note that selecting this will erase the current contents of the window.
- **Bottom inout pins**  
Places inout pins on the bottom of components rather than on the right with output pins.

- **Disable Sprout**

Displays only the selected signal or process with its immediate fanin/fanout. Configures window to behave like the Dataflow window of versions prior to 5.6.

- **Select equivalent nets**

If the item you select traverses hierarchy, then ModelSim selects all connected items across the hierarchy.

- **Log nets**

Logs signals when they are added to the window.

- **Select Environment**

Updates the Structure, Signals, and Source windows to reflect the net selected in the Dataflow window.

- **Automatic Add to Wave**

Adds signals automatically to the Wave pane or window when executing ChaseX or TraceX.



The **Warning options** tab includes these options:

- **Enable diverging X fanin warning**

Enables the warning message, "ChaseX: diverging X fanin. Reduce the selection list and try again."

- **Enable depth limit warning**

Enables the warning message, "ChaseX: Stop because depth limit reached! Possible loop?"

- **Enable X event at time 0 warning**

Enables the warning message, ""Driving X event at time 0."

## List window

The List window displays the results of your simulation run in tabular format. The window is divided into two adjustable panes, which allow you to scroll horizontally through the listing on the right, while keeping time and delta visible on the left.



### Items you can view

The following type of items can be viewed in the List window:

#### VHDL

signals, aliases, process variables, and shared variables

#### Verilog

nets, registers, and variables

#### Virtuals

Virtual signals and functions

Constants, generics, and parameters are not viewable in the List or Wave windows.

## Adding items to the List window

Before adding items to the List window you may want to set the window display properties (see "[Setting List window display properties](#)" (UM-194)). You can add items to the List window in several ways.

### ***Adding items with drag and drop***

You can drag and drop items into the List window from the Signals, Source, Process, Variables, Wave, or Structure window. Select the items in the first window, then drop them into the List window. Depending on what you select, all items or any portion of the design may be added.

### ***Adding items from the Main window command line***

Invoke the **add list** (CR-38) command to add one or more individual items; separate the names with a space:

```
add list <item_name> <item_name>
```

You can add all the items in the current region with this command:

```
add list *
```

Or add all the items in the design with:

```
add list -r /*
```

### ***Adding items with a List window format file***

To use a List window format file you must first save a format file for the design you are simulating. The saved format file can then be used as a DO file to recreate the List window formatting. Follow these steps:

- Add items to your List window.
- Edit and format the items to create the view you want (see "[Editing and formatting items in the List window](#)" (UM-191)).
- Save the format to a file by selecting **File > Save Format** (List window).

To use the format file, start with a blank List window, and run the DO file in one of two ways:

- Invoke the **do** (CR-75) command from the command line:

```
do <my_list_format>
```

- Select **File > Load Format** from the List window menu bar.

List window format files are design-specific; use them only with the design you were simulating when they were created. If you try to use the wrong format file, ModelSim will advise you of the items it expects to find.

## The List window menu bar

This section provides information on select menu commands available in the List window.

### File menu

|             |                                                                                                                                                                                                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write List  | save the List window data to a text file in one of three formats; see " <a href="#">Saving List window data to a file</a> " (UM-200) for details                                                     |
| Save Format | save the current List window display and signal preferences to a DO (macro) file; running the DO file will reformat the List window to match the display as it appeared when the DO file was created |
| Load Format | run a List window format DO file previously saved with Save Format                                                                                                                                   |

### Edit menu

|               |                                                                                                                                 |
|---------------|---------------------------------------------------------------------------------------------------------------------------------|
| Add Marker    | add a time marker at the currently selected line; see " <a href="#">Setting time markers in the List window</a> " (UM-199)      |
| Delete Marker | delete the selected marker from the listing                                                                                     |
| Find          | find the specified item label within the List window; see " <a href="#">Finding items by name in the List window</a> " (UM-198) |

### View menu

|                   |                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------|
| Signal Properties | set item properties; see " <a href="#">Editing and formatting items in the List window</a> " (UM-191) |
| Goto              | choose the time marker to go to from a list of current markers                                        |

### Tools menu

|                    |                                                                                                                                                                                     |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Combine Signals    | combine the selected fields into a user-defined bus; keep copies of the original items rather than moving them; see " <a href="#">Combining items in the List window</a> " (UM-193) |
| Window Preferences | set display properties for items in the window; see " <a href="#">Setting List window display properties</a> " (UM-194)                                                             |

### Window menu

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

### The List window context menu

Some commands like the following are available by clicking the right mouse button on an entry in the right-hand pane:

|               |                                                                                                                           |
|---------------|---------------------------------------------------------------------------------------------------------------------------|
| Examine       | display the value of the item at the time selected                                                                        |
| Annotate Diff | Add a note to explain a comparison difference. See <a href="#">Chapter 11 - Waveform Compare</a> for further information. |
| Ignore Diff   | Disregard the selected comparison difference. See <a href="#">Chapter 11 - Waveform Compare</a> for further information.  |

## Editing and formatting items in the List window

Once you have the items you want in the List window, you can edit and format the list to create the view you find most useful. (See also, "Adding items to the List window" (UM-188))

### **To edit an item:**

Select the item's label at the top of the List window or one of its values from the listing. Move, copy or remove the item by selecting commands from the List window **Edit menu** (UM-189) menu.

You can also click+drag to move items within the window.

### **To format an item:**

Select the item's label at the top of the List window or one of its values from the listing, then select **View > Signal Properties** (List window). The resulting List Signal Properties dialog box allows you to set the item's label, label width, triggering, and radix.



The **List Signal Properties** dialog box includes these options:

- **Signal**  
Shows the full pathname of the selected signal.
- **Display Name**  
Specifies the label that appears at the top of the List window column.

- **Radix**

Specifies the radix (base) in which the item value is expressed. The default radix is symbolic, which means that for an enumerated type, the List window lists the actual values of the enumerated type of that item. You can change the default radix for the current simulation using either **Simulate > Simulation Options** (Main window) or the [radix command](#) (CR-126). You can change the default radix permanently by editing the **DefaultRadix** (UM-373) variable in the *modelsim.ini* file.

For the other radices - binary, octal, decimal, unsigned, hexadecimal, or ASCII - the item value is converted to an appropriate representation in that radix. In the system initialization file, *modelsim.tcl*, you can specify the list translation rules for arrays of enumerated types for binary, octal, decimal, unsigned decimal, or hexadecimal item values in the design unit.

Changing the radix can make it easier to view information in the List window. Compare the image below (with decimal values) with the image on [page UM-187](#) (with symbolic values).

| ns      | clk | /top/pdata | /top/sdata | /top/prw | /top/srw | /top/pstrb | /top/sstrb | /top/prdy | /top/srdy | /top/paddr | /top/saddr |
|---------|-----|------------|------------|----------|----------|------------|------------|-----------|-----------|------------|------------|
| ns      |     |            |            |          |          |            |            |           |           |            |            |
| delta   |     |            |            |          |          |            |            |           |           |            |            |
| 1540 +0 |     | 1 0 1 1    | 7          |          | 7 0 1 1  | 7          |            |           |           |            | 7          |
| 1560 +0 |     | 0 0 1 1    | 7          |          | 7 0 1 1  | 7          |            |           |           |            | 7          |
| 1580 +0 |     | 1 0 1 1    | 7          |          | 7 0 1 1  | 7          |            |           |           |            | 7          |
| 1585 +0 |     | 1 0 1 1    | 7          |          | 7 0 1 0  | 7          |            |           |           |            | 7          |
| 1590 +0 |     | 1 0 1 0    | 7          |          | 7 0 1 0  | 7          |            |           |           |            | 7          |
| 1600 +0 |     | 0 0 1 0    | 7          |          | 7 0 1 0  | 7          |            |           |           |            | 7          |
| 1620 +0 |     | 1 0 1 0    | 7          |          | 7 0 1 0  | 7          |            |           |           |            | 7          |
| 1625 +0 |     | 1 0 0 1    | 8          |          | 2 0 1 1  | 7          |            |           |           |            | 2          |

- **Width**

Allows you to specify the desired width of the column used to list the item value. The default is an approximation of the width of the current value.

- **Trigger: Triggers line**

Specifies that a change in the value of the selected item causes a new line to be displayed in the List window.

- **Trigger: Does not trigger line**

Specifies that a change in the value of the selected item does not affect the List window.

The trigger specification affects the trigger property of the selected item. See also, ["Setting List window display properties"](#) (UM-194).

## Combining items in the List window

You can combine signals in the List window into busses. A bus is a collection of signals concatenated in a specific order to create a new virtual signal with a specific value. To create a bus, select one or more signals in the List window and then choose **Tools > Combine Signals**.



The **Combine Selected Signals** dialog box includes these options:

- **Name**  
Specifies the name of the newly created bus.
- **Order of Indexes**  
Specifies in which order the selected signals are indexed in the bus. If set to **Ascending**, the first signal selected in the List window will be assigned an index of 0. If set to **Descending**, the first signal selected will be assigned the highest index number. Note that the signals are added to the bus in the order that they appear in the window. Ascending and descending affect only the order and direction of the indexes of the bus.
- **Remove selected signals after combining**  
Specifies whether you want to remove the selected signals from the List window once the bus is created.

## Setting List window display properties

Before you add items to the List window you can set the window's display properties. To change when and how a signal is displayed in the List window, select **Tools > Window Preferences** (List window). The resulting Modify Display Properties dialog box contains tabs for Window Properties and Triggers.

### **Window Properties tab**



The **Window Properties** tab includes these options:

- **Signal Names**  
Sets the number of path elements to be shown in the List window. For example, "0" shows the full path. "1" shows only the leaf element.
- **Max Title Rows**  
Sets the maximum number of rows in the name pane.
- **Dataset Prefix: Always Show Dataset Prefixes**  
Displays the dataset prefix associated with each signal pathname. Useful for displaying signals from multiple datasets.
- **Dataset Prefix: Show Dataset Prefix if 2 or more**  
Displays dataset prefixes if there are signals in the window from 2 or more datasets.

- **Dataset Prefix: Never Show Dataset Prefixes**  
Turns off display of dataset prefixes.

#### Triggers tab

The **Triggers** tab controls the triggering for the display of new lines in the List window. You can specify whether an item trigger or a strobe trigger is used to determine when the List window displays a new line. If you choose **Trigger on: Signal Change**, then you can choose between collapsed or expanded delta displays. You can also choose a combination of signal and strobe triggers. To use gating, **Signal Change** or **Strobe** or both must be selected.



The **Triggers** tab includes the following options:

- **Expand Deltas**

When selected with the **Trigger on: Signal Change** check box, displays a new line for each time step on which items change, including deltas within a single unit of time resolution.

- **Collapse Deltas**

Displays only the final value for each time unit.

- **No Deltas**

Hides the simulation cycle (delta) column.

- **Trigger On Signal Change**

Triggers on signal changes. Defaults to all signals. Individual signals can be excluded from triggering by using the **View > Signal Properties** dialog box or by originally adding them with the **-notrigger** option to the **add list** command (CR-38).

- **Trigger On Strobe**

Triggers on the **Strobe Period** you specify; specify the first strobe with **First Strobe at:**

- **Use Gating Expression**

Enables triggers to be gated on (a value of 1) or off (a value of 0) by the specified **Expression**, much like a hardware signal analyzer might be set up to start recording data on a specified setup of address bits and clock edges. Affects the display of data, not the acquisition of the data.

- **Use Expression Builder** (button)

Opens the Expression Builder to help you write a gating expression. See "[The GUI Expression Builder](#)" (UM-288)

- **Expression**

Enter the expression for trigger gating into this field, or use the Expression Builder (select the **Use Expression Builder** button). The expression is evaluated when the List window would normally have displayed a row of data (given the trigger on signals and strobe settings above).

- **On Duration**

The duration for gating to remain open after the last list row in which the expression evaluates to true; expressed in x number of default timescale units. Gating is level-sensitive rather than edge-triggered.

List window gating information is saved as configuration statements when the list format is saved. The gating portion of a configuration statement might look like this:

```
configure list -usegating 1
configure list -gateduration 100
configure list -gateexpr {<expression>}
```

## Configuring a List trigger with the Expression Builder

This example shows you how to set a List window trigger based on a gating expression created with the ModelSim Expression Builder. Here is the procedure:

- 1** Select **Tools > Window Preferences** to access the Triggers tab.
- 2** Check the **Use Gating Expression** check box and click **Use Expression Builder**.



- 3** Select the signal in the List window that you want to be the enable signal by clicking on its name in the header area of the List window.
- 4** Click **Insert Selected Signal** and then **'rising'** in the Expression Builder.

- 5** Click OK to close the Expression Builder.

You should see the name of the signal plus "'rising" added to the Expression entry box of the Modify Display Properties dialog box.

- 6** Click **OK** to close the dialog.

If you already have simulation data in the List window, the display should immediately switch to showing only those cycles for which the gating signal is rising. If that isn't quite what you want, you can go back to the expression builder and play with it until you get it the way you want it.

If you want the enable signal to work like a "One-Shot" that would display all values for the next, say 10 ns, after the rising edge of enable, then set the **On Duration** value to **10 ns**.

## Sampling signals at a clock change

You can sample signals at a clock change easily using the **add list** command (CR-38) with the **-notrigger** argument. **-notrigger** disables triggering the display on the specified signals. For example:

```
add list clk -notrigger a b c
```

When you run the simulation, List window entries for *clk*, *a*, *b*, and *c* appear only when *clk* changes.

If you want to display on rising edges only, you have two options:

- 1** Turn off the List window triggering on the clock signal, and then define a repeating strobe for the List window.
- 2** Define a "gating expression" for the List window that requires the clock to be in a specified state. See "["Configuring a List trigger with the Expression Builder"](#)" (UM-197).

## Finding items by name in the List window

The Find dialog box allows you to search for text strings in the List window. Select **Edit > Find** (List window) to bring up the Find dialog box.

Enter a text string and **Find** it by searching **Right** or **Left** through the List window display.

Specify **Name** to search the real pathnames of the items or **Label** to search their assigned names (see "["Setting List window display properties"](#)" (UM-194)).

Check **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find */top/clk* and *clk1*.

Check **Auto Wrap** to continue the search at the beginning of the window.



## Setting time markers in the List window

Select **Edit > Add Marker** (List window) to tag the selected list line with a marker. The marker is indicated by a thin box surrounding the marked line. The selected line uses the same indicator, but its values are highlighted. Delete markers by first selecting the marked line, then selecting **Edit > Delete Marker**.

### Finding a marker



Choose a specific marked line to view by selecting **View > Goto**. The marker name (on the **Goto** list) corresponds to the simulation time of the selected line.

## Saving List window data to a file

Select **File > Write List** (List window) to save the List window data in one of these formats:

- **Tabular**

writes a text file that looks like the window listing

| ns | delta | /a | /b | /cin | /sum | /cout |
|----|-------|----|----|------|------|-------|
| 0  | +0    | X  | X  | U    | X    | U     |
| 0  | +1    | 0  | 1  | 0    | X    | U     |
| 2  | +0    | 0  | 1  | 0    | X    | U     |

- **Events**

writes a text file containing transitions during simulation

```
@0 +0
/a X
/b X
/cin U
/sum X
/cout U
@0 +1
/a 0
/b 1
/cin 0
```

- **TSSI**

writes a file in standard TSSI format; see also, the [write tssi](#) command (CR-247)

```
0 000000000000000010???????
2 000000000000000010??????1?
3 000000000000000010?????010
4 000000000000000010000000010
100 00000001000000010000000010
```

You can also save List window output using the [write list](#) command (CR-243).

## List window keyboard shortcuts

See "[List window keyboard shortcuts](#)" (UM-391) .

## Memory window

The memory window lists and displays the contents of the memories in your design. The window is divided into two adjustable panes, allowing you to scroll vertically through the memory contents displayed on the right, while keeping the memory list browser visible on the left.



### Memories you can view

The memory browser identifies and lists the following types of arrays as memories:

- reg, wire, bit, and std\_logic arrays

Any signal or variable that is an array of two dimensions (including arrays of arrays) are identified as memories and listed if the base type is a Verilog reg or wire type, or a VHDL enumerated type with values in std\_ulogic, bit, and all related sub-types.

- Integer arrays

Single dimensional arrays of integers are interpreted as 2D memory arrays. In these cases, the word width listed in the Memory List pane is equal to the integer size, and the depth is the size of the array itself. The appearance of this type of array in the memory list can be disabled via the View menu or the [ShowIntMem](#) (UM-375) variable in the *modelsim.ini*.

- Single dimensional arrays of VHDL enumerated types other than std\_logic or bit

These enumerated type value sets must have values that are longer than one character. The listed width is the number of entries in the enumerated type definition and the depth is the size of the array itself. The appearance of this type of array in the memory list can

be disabled via the View menu or the [ShowEnumMem](#) (UM-376) variable in the *modelsim.ini*.

- 3D or greater arrays

Memories with three or more dimensions display with a plus sign '+' next to their names in the Memory List. Click the '+' to show the array indices under that level. When you finally expand down to the 2D level, you can click on the index, and the data for the selected 2D slice of the memory will appear in the memory contents pane. The appearance of this type of array in the memory list can be disabled via the View menu or the [Show3DMem](#) (UM-375) variable in the *modelsim.ini*.

## The Memory window menu bar

This section provides information on select menu commands available in the Memory window. Several commands are also available on a context menu by right-clicking within the content or address pane.

### File menu

|             |                                                                                                                                      |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Load        | load memory data to the currently displayed memory instance from a file; see " <a href="#">Loading files and patterns</a> " (UM-208) |
| Save        | save currently displayed memory data (all or a range) to a file; see " <a href="#">Saving memory data to a file</a> " (UM-211)       |
| Environment | set the environment of the memory being viewed either to follow context selection or to the current context                          |

### Edit menu

|             |                                                                                                                                                                                     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Goto        | go to specific memory address in currently displayed memory instance; see " <a href="#">Using the Goto dialog</a> " (UM-206)                                                        |
| Change      | change the memory contents for all addresses or a range of addresses in the currently displayed memory instance; see " <a href="#">Interactive memory initialization</a> " (UM-210) |
| Find        | find the specified text string within the Memory window; see " <a href="#">Finding a memory instance</a> " (UM-207)                                                                 |
| Data Search | searches for a specified memory data pattern in the currently displayed memory instance; see " <a href="#">Searching for a data pattern</a> " (UM-206)                              |

## View menu

|                    |                                                                                                                                                            |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory Declaration | open up the Source window to the line of code where the currently displayed memory instance is defined                                                     |
| Split Screen       | split the address pane horizontally into two identically-sized panes, one upper and one lower; see " <a href="#">Splitting the Data Screen</a> " (UM-205). |
| Memory List        | toggle on and off the display of the Memory List pane                                                                                                      |
| ShowIntMem         | toggle on and off the display in the Memory List pane of single dimensional arrays of integers                                                             |
| ShowEnumMem        | toggle on and off the display in the Memory List pane of single dimensional arrays of VHDL enumerated types other than std_logic or bit                    |
| Show3DMem          | toggle on and off the display in the Memory List pane of arrays of 3 or more dimensions                                                                    |
| Display Options    | set various window display options; see " <a href="#">Modifying the memory window display</a> " (UM-204).                                                  |

## Window menu

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Viewing memory contents

To bring up a Memory window, either select **View > Memory** from the menu bar, or enter **view memory** at the command prompt. Multiple memory windows can be viewed simultaneously.

### ***Selecting memory instances***

To select a memory instance for viewing its contents, you can:

- Click on one of the memory instances appearing in the Memory List pane.
- Drag and drop any instance shown in the other ModelSim windows, such as Structure or Wave into the **Address / Data** pane. All memory instances in that level of hierarchy are displayed.
- Enter the command **add mem <instance>** at the vsim command prompt.

### ***Viewing multiple memory instances***

You can view multiple memory instances. A tab appears at the bottom of the Address / Data pane corresponding to each memory instance that is added to the view, as shown below. To close one instance or all instances, select **File > Close Instance** or **Close All**, respectively.

## Modifying the memory window display

When you have added memory instances to the view, the Memory window appears as follows:



The display can be modified by setting different display options and splitting the Data / Address pane.

### **Setting display options**

To change the display's address and data radix, or line wrapping of the selected memory, select **View > Display Options**. You can also right-click anywhere in the Address/Data pane to bring up a pop-up menu containing **Display Options**.

The **Display Options** dialog box includes these options:

- **Address Radix**

The radix for the address. Can be Hexadecimal or Decimal.

- **Data Radix**

The radix for the data. Non-enumerated type memories can be Symbolic, Binary, Octal, Decimal, Unsigned, and Hexadecimal.

Enumerated type memories are only symbolic data types, and all other options are grayed out.

- **Line Wrap**

The number of words per line can be set, or arbitrarily determined based on the size of the window.



### **Splitting the Data Screen**

To split the Address / Data pane into two screens displaying the contents of a single memory instance, select **View > Split Screen** (or right-click in the pane and select **Split Screen** from the pop-up menu). This allows you to view different address locations within the same memory instance simultaneously.



## Navigating to memory locations within a memory instance

Other than using the scroll bar to scroll up and down through the memory, you can navigate to specific memory locations within an instance in several ways.

### **Using the Goto dialog**

Select **Edit > Goto** to bring up the Goto Memory dialog. You can also right-click on the address column in the Address / Data display area, and select **Goto** from the pop-up menu. When selected, it brings up the Goto dialog box, shown here. Enter the desired address location into the field, select **OK**, and the data view shifts to display the data in that location.



### **Direct address navigation**

You can navigate to any address location directly by editing the address in the address column. Double-click on any address, type in the desired address, and hit **Enter**. The address display scrolls to the specified location.

| Address  | Data                |
|----------|---------------------|
| 00000005 | 000000000000000101  |
| 00000006 | 000000000000000110  |
| 00000012 | 000000000000000111  |
| 00000008 | 0000000000000001000 |
| 00000009 | 0000000000000001001 |
| 0000000a | xxxxxxxxxxxxxx      |

### **Searching for a data pattern**

To find a particular data pattern, select **Edit > Data Search** or right-click in the data area of the pane, and select **Data Search**. The Data Search in Memory dialog box appears as shown here. Specify the pattern you want to find in the **Search for:** field and, optionally, a replacement pattern in the **Replace with:** field. The **Search Next** button performs the search and replace operation. Select **Search backward** to search and/or replace backward through the memory for the specified pattern. Select **Close** to close the Data Search dialog box.



### Finding a memory instance

To find a particular data pattern, select **Edit > Find** or right-click in the data area of the pane, and select **Find**. The Find dialog box appears as shown here, containing a search pattern definition field and a Find Next button.

Select Exact match to search for patterns exactly matching the specified pattern. Select Search backward to search backward through the memory for the specified pattern. Select Close to close the Find dialog box.



## Initializing memories

You can initialize memories in your design by either loading the contents from a file, or by an interactive command. An entire memory, a specific range of addresses, or an individual word can be overwritten. Choose the type of Load operation to be performed in the Load Type area. The default load type is File Only. When either File Only or Data Only is selected, the unused section of the dialog box is grayed out.

### ***Loading files and patterns***

To initialize a memory from a file:

Select **File > Load**. The Load Memory dialog box appears, as follows:



The Load Memory dialog box includes these options:

- **Instance Name**  
Displays the name of the memory instance being loaded.

- **Load Type**

Defines the type of load function you will perform. Your choices for loading data are: File Only, Data Only or Both File and Data.

- **Address Range**

Specifies all addresses or a range of addresses in the memory that you want to load. The address radix of the displayed memory is shown in parentheses.

- **File Load**

Contains all inputs related to loading from a file. This whole area of the dialog is grayed out if Load Type is specified as Data Only.

- **File Format**

Specifies the format of the file to be loaded. Verilog Hex, Verilog Binary, or MTI format can be explicitly set, or the format can be determined automatically from the file (if the file was created with the **mem save** command).

- **Filter**

Filters the file list.

- **File name**

The name of the memory file to load. You can manually edit this field, or select a file from the Files list, and it will fill in automatically.

- **Data Load**

Contains all inputs related to loading memory data. This area of the dialog is grayed out if Load Type is specified as File Only.

- **Fill Data**

Specifies the fill data for addresses not contained in the load file.

- **Fill Type**

Specifies how to apply the fill data, either directly as a value, or algorithmically. See the **mem load** command (CR-102) for more information on Fill Type and Fill Data.

- **Skip**

Specifies the number of words to skip when applying a fill pattern sequence.

### **Interactive memory initialization**

Memory contents can be modified interactively during simulation for greater ease in debugging your design. You can change the data values in multiple addresses in the memory by using the Change Memory dialog, or change individual data values by editing them directly in the data area of the Address / Data pane.

#### Changing data for multiple addresses

Select **Edit > Change** to open the Change Memory dialog box.



The Change Memory dialog box includes the following:

- **Instance Name**  
Displays the name of the memory instance being loaded.
- **Address Range**  
Specifies all addresses or a starting and ending address to be changed. The address radix of the currently displayed memory is shown in parentheses.
- **Fill Data**  
Specifies the fill data for specified addresses.
- **Fill Type**  
Specifies how to apply the fill data, either directly as a value, or algorithmically. See the **mem load** command (CR-102) for more information on Fill Type and Fill Data.
- **Skip**  
Specifies the number of words to skip after applying a fill pattern sequence.

#### Changing data for individual addresses

To edit memory data in place, **Double click** (or right-click and select **Edit in Place**) on any word in the Address/Data pane of the Memory window. The data is highlighted. Type in the desired change. Pressing <Enter> commits the change; <Esc> aborts it. <Tab> scrolls down the list of data entries, while <Shift>-<Tab> scrolls up the list. As a short-cut, after editing

| Address  | Data                                 |
|----------|--------------------------------------|
| 00000005 | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx |
| 00000004 | xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx |
| 00000003 | 00000000000000000000000000000000     |
| 00000002 | 00000000000000000000000000000000     |
| 00000001 | 00000000000000000000000000000000     |
| 00000000 | 00000000000000000000000000000000     |

one data value, you can double-click on another data value to commit the change and edit the second value.

### **Saving memory data to a file**

To save the current memory data to a file, select **File > Save**.



The Save Memory File dialog box includes the following:

- **File name**  
Name of file to be saved.
- **Address Range**  
Specifies all or a range of addresses to be saved into the file. The address radix
- **File Format**  
Specifies whether memory is to be saved in Verilog Hex, Verilog Binary, or MTI format. Also, specify the Address and Data radix for MTI format.
- **No addresses**  
Specifies that no addresses are to appear in the saved file. This enables the file to be reloaded anywhere in the memory.

- **Compress**

Applies a simple ASCII compression to the saved file. The compression algorithm replaces repeating lines with a single asterisk, like is done with the Unix “od” command.

#### MTI memory data file format

The MTI memory data file format is as illustrated in the following example:

```
// memory data file
// (do not edit the following line - required for mem load use)
// format=mti addressradix=d dataradix=s direction=ascending
0: 110 110 110 110 110 110
6: 110 110 110 110 000 000
12: 000 000 000 000 000 000
18: 000 000 000 000 000 000
24: 000 000 000 000 000 000
30: 000 000
```

The possible format, address radix, data radix, and direction settings are as specified by the corresponding options in the **mem save** and **mem load** commands. See the **mem save** command (CR-105) and the **mem load** command (CR-102) for more information.

## Process window

The Process window displays a list of processes. In ModelSim versions 5.7 and later, the information contained in the Process window can also be displayed in the Main window [Workspace](#) (UM-164).

If **View > Active** is selected then all processes scheduled to run during the current simulation cycle are displayed along with the pathname of the instance in which each process is located. If **View > In Region** is selected then only the processes in the currently selected region are displayed.

### Understanding process status

Each item in the scrollbox is preceded by one of the following indicators:

- **<Ready>**

Indicates that the process is scheduled to be executed within the current delta time.

- **<Wait>**

Indicates that the process is waiting for a VHDL signal or Verilog net or variable to change or for a specified time-out period.

- **<Done>**

Indicates that the process has executed a VHDL wait statement without a time-out or a sensitivity list. The process will not restart during the current simulation run.



If you select a "Ready" process, it will be executed next by the simulator.

### Links to other windows

When you click on a process in the Process window, the following windows are updated:

| Window updated                            | Result                                                                      |
|-------------------------------------------|-----------------------------------------------------------------------------|
| <a href="#">Dataflow window</a> (UM-171)  | highlights the selected process                                             |
| <a href="#">Memory window</a> (UM-201)    | shows the memory instances in that process                                  |
| <a href="#">Signals window</a> (UM-215)   | shows the signals in the region in which the process is located             |
| <a href="#">Source window</a> (UM-224)    | shows the associated source code                                            |
| <a href="#">Structure window</a> (UM-230) | shows the region in which the process is located                            |
| <a href="#">Variables window</a> (UM-233) | shows the VHDL variables and Verilog registers and variables in the process |

## The Process window menu bar

This section provides information on select menu commands available in the Process window.

### File menu

|             |                                                                                                                                                                                                        |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Save List   | save the process tree to a text file                                                                                                                                                                   |
| Environment | <b>Follow Context Selection:</b> update the window based on the selection in the <a href="#">Structure window</a> (UM-230);<br><b>Fix to Current Context:</b> maintain the current view, do not update |

### View menu

|           |                                                                                         |
|-----------|-----------------------------------------------------------------------------------------|
| Active    | display all the processes that are scheduled to run during the current simulation cycle |
| In Region | display any processes that exist in the region that is selected in the Structure window |
| Sort      | sort the process list in either ascending, descending, or declaration order             |

### Window menu

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Signals window

The Signals window shows the names and current values of items in the current region (which is selected in the Structure window). The data in this pane is similar to that shown in the [Wave window](#) (UM-236), except that the values do not change dynamically with movement of the selected Wave window cursor.

Clicking on a signal name in the Signals window highlights that signal in the Dataflow and Wave windows. Double-clicking a signal highlights that signal in the Source window (opening a Source window if one is not open already). You can also right click a signal name and add it to the List or Wave window, or the current log file.

The items can be sorted in ascending, descending, or declaration order.



### Items you can view

One entry is created for each of the following items in the design:

#### VHDL items

signals, aliases, generics, shared variables

#### Verilog items

nets, registers, variables, named events, and module parameters

### Virtual items

virtual signals and virtual functions; see "[Virtual signals](#)" (UM-150) for more information  
VHDL composite types (arrays and record types) and Verilog vector nets, vector registers, and memories are shown in a hierarchical fashion. ModelSim indicates hierarchy with plus (expandable), minus (expanded), and blank (single level) boxes. See "[Tree window hierarchical view](#)" (UM-162) for more information.

## The Signals window menu bar

This section provides information on select menu commands available in the Signals window. Several commands are also available on a context menu by right-clicking on a signal name.

### File menu

|             |                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------|
| Save List   | save the signals tree to a text file                                                                          |
| Environment | allow the window contents to change based on the current environment, or fix to a specific context or dataset |
| Close       | close this copy of the Signals window                                                                         |

### Edit menu

|         |                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------|
| Force   | apply stimulus to the specified signal; see " <a href="#">Forcing signal and net values</a> " (UM-220) |
| Noforce | remove the effect of an active force                                                                   |
| Clock   | define clock signals; see " <a href="#">Defining clock signals in HDL designs</a> " (UM-222)           |

**View menu**

|                    |                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------|
| Signal Declaration | open the source file in the Source window and highlight the signal declaration                      |
| Sort               | sort the signals tree in either ascending, descending, or declaration order                         |
| Filter             | choose the port and signal types to view; see " <a href="#">Filtering by signal type</a> " (UM-218) |

**Add menu**

Allows you to add the specified signals to the Wave or List windows or the current WLF file

**Tools menu**

|             |                                                                                                 |
|-------------|-------------------------------------------------------------------------------------------------|
| Breakpoints | open the Breakpoints dialog; see " <a href="#">Creating and managing breakpoints</a> " (UM-284) |
|-------------|-------------------------------------------------------------------------------------------------|

**Window menu**

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Filtering the signal list

You can filter the signal list by name or by signal type.

### **Filtering by name**

To filter by name, start typing letters in the **Contains** field on the toolbar. As you type letters, the signals list filters to show only those signals that contain those letters.



To display all signals again, click the Eraser icon to clear the entry.

Filters are stored relative to the region selected in the Structure window. If you re-select a region that had a filter applied, that filter is restored. This allows you to apply different filters to different regions.

### **Filtering by signal type**

The **View > Filter** menu selection allows you to specify which signal types to display in the Signals window. Multiple options can be selected.



## Finding items in the Signals window

To find the specified text string within the Signals window, choose the **Name** or **Value** field to search and the search direction: **Down** or **Up**.



Check **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find */top/clk* and *clk1*.

Check **Auto Wrap** to continue the search at the beginning of the window.

You can also do a quick find from the keyboard. When the Signals window is active, each time you type a letter the signal selector (highlight) will move to the next signal whose name begins with that letter.

## Forcing signal and net values

The **Edit > Force** command displays a dialog box that allows you to apply stimulus to the selected signal or net. Multiple signals can be selected and forced; the force dialog box remains open until all of the signals are either forced, skipped, or you close the dialog box. To cancel a force command, use the **Edit > NoForce** command. See also the **force** command (CR-90).



The **Force** dialog box includes these options:

- **Signal Name**

Specifies the signal or net for the applied stimulus.

- **Value**

Initially displays the current value, which can be changed by entering a new value into the field. A value can be specified in radices other than decimal by using the form (for VHDL and Verilog, respectively):

base#value -or- b|o|d|h'value

16#EE or h'EE, for example, specifies the hexadecimal value EE.

- **Kind: Freeze**

Freezes the signal or net at the specified value until it is forced again or until it is unforced with a **noforce** command (CR-110).

**Freeze** is the default for Verilog nets and unresolved VHDL signals and **Drive** is the default for resolved signals.

If you prefer **Freeze** as the default for resolved and unresolved signals, you can change the default force kind in the *modelsim.ini* file; see *Appendix A - ModelSim variables*.

- **Kind: Drive**

Attaches a driver to the signal and drives the specified value until the signal or net is forced again or until it is unforced with a **noforce** command (CR-110). This type of force is illegal for unresolved VHDL signals.

- **Kind: Deposit**

Sets the signal or net to the specified value. The value remains until there is a subsequent driver transaction, or until the signal or net is forced again, or until it is unforced with a **noforce** command (CR-110).

- **Delay For**

Allows you to specify how many time units from the current time the stimulus is to be applied.

- **Cancel After**

Cancels the **force** command (CR-90) after the specified period of simulation time.

- **OK**

When you click the OK button, a **force** command (CR-90) is issued with the parameters you have set, and is echoed in the Main window. If more than one signal is selected to force, the next signal down appears in the dialog box each time the OK button is selected. Unique force parameters can be set for each signal.

## **Adding items to the Wave and List windows or a WLF file**

Use the **Add** menu to add items from the Signals window to the [Wave window](#) (UM-236), [List window](#) (UM-187), or log file (WLF file). You can also access these same commands by right-clicking a signal in the window.



The WLF file is written as an archive file in binary format and is used to drive the List and Wave windows at a later time.

Once signals are added to the WLF file they cannot be removed (though you can turn off logging with the **nolog** command (CR-111)). If you begin a simulation by invoking **vsim** (CR-213) with the **-view <WLF\_fileame>** argument, ModelSim reads the WLF file to drive the Wave and List windows.

Choose one of the following options from the **Add** sub-menus:

- **Selected Signals**

Adds only the item(s) selected in the Signals window.

- **Signals in Region**

Adds all items in the region that is selected in the Structure window.

- **Signals in Design**

Adds all items in the design.

## **Adding items from the Main window command line**

Another way to add items to the Wave or List window or the WLF file is to enter one of the following commands at the VSIM prompt (choose either the **add list** (CR-38), **add wave** (CR-41), or **log** (CR-95) command):

```
add list | add wave | log <item_name> <item_name>
```

You can add all the items in the current region with this command:

```
add list | add wave | log *
```

If the target window (Wave or List) is closed, ModelSim opens it when you invoke the command.

## Setting signal breakpoints in HDL designs

You can set "Signal breakpoints" (UM-284) in the Signals window. When a signal breakpoint is hit, a message appears in the Main window Transcript stating which signal caused the breakpoint.

To insert a signal breakpoint, right-click a signal name and select **Insert Breakpoint**. See "[Creating and managing breakpoints](#)" (UM-284) for more information.

## Defining clock signals in HDL designs

Select **Edit > Clock** to define clock signals by Name, Period, Duty Cycle, Offset, and whether the first edge is rising or falling. You can also specify a simulation period after which the clock definition should be cancelled.



For clock signals starting on the rising edge, the definition for Period, Offset, and Duty Cycle is as follows:



If the signal type is std\_logic, std\_ulogic, bit, verilog wire, verilog net, or any other logic type where 1 and 0 are valid, then 1 is the default High Value and 0 is the default Low Value. For other signal types, you will need to specify a High Value and a Low Value for the clock.

## Source window

The Source window allows you to view and edit your source code. When you first load a design, the source file will display automatically if the Source window is open.

Alternatively, you can select an item in a Structure tab of the Main window or use the **File > Open** command (Source window) to add a file to the window..

The window displays your source code with line numbers. As shown in the picture below, you may also see the following:

- Blue line numbers – denote lines on which you can set a breakpoint
- Blue arrow – denotes a process that you have selected in the [Process window](#) (UM-213) or the line corresponding to a breakpoint at which the simulator is currently stopped
- Red diamonds – denote file-line breakpoints; hollow diamonds denote breakpoints that are currently disabled
- File tabs – represent each open file
- Templates pane – displays [HDL language templates](#) (UM-290)

The screenshot shows the ModelSim Source window titled "source - proc.v". The main area displays the following HDL code:

```

75      // Read back 10 locations
76      for (a = 0; a < 10; a = a + 1)
77 // uncomment for wavecompare
78 //           #10 read(a, d);
79         read(a, d);
80         if (d !== a)
81             $display("%t: Read/Wri
82         end
83
84         if (verbose) $display("Read/Wr
85         $stop(1);
86     end
87 endmodule
88

```

The code editor features color-coded syntax highlighting and several visual markers:

- Line 75:** A solid red diamond indicates a file-line breakpoint.
- Line 84:** A hollow red diamond indicates a disabled breakpoint.
- Line 85:** A blue arrow points to the line, indicating it is the current process being simulated.
- Line 88:** A solid red diamond indicates a file-line breakpoint.

The status bar at the bottom right shows "Ln: 85, Col: 0 -- read-only".

Note that files open by default in read-only mode. You can toggle this mode by selecting **Edit > read only**.

## The Source window menu bar

This section provides information on select menu commands available in the Source window. Several commands are also available on a context menu by right-clicking in the body of the window.

### File menu

|                    |                                                                                                                                                           |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Open Design Source | open a dialog that lists all source files for the current design                                                                                          |
| Use Source         | specify an alternative file to use for the current source file; this alternative source mapping exists for the current simulation only                    |
| Source Directory   | add to a list of directories to search for source files; you can set this permanently using the <b>SourceDir</b> variable in the <i>modelsim.tcl</i> file |

### Edit menu

To edit a source file, make sure **read only** is *not* selected on the Edit menu.

|                    |                                                                                                                         |
|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| Clear highlights   | clear highlights that result from double-clicking an error message or a line in a Performance Analyzer report           |
| Comment Selected   | turn the selected lines into comments by inserting the correct language comment character at the beginning of each line |
| Uncomment Selected | removes comment characters from the selected lines                                                                      |
| read only          | toggle the read-only status of the current source file                                                                  |

### View menu

|                         |                                                                                                                |
|-------------------------|----------------------------------------------------------------------------------------------------------------|
| Show line numbers       | toggle line numbers                                                                                            |
| Show language templates | toggle display of the <a href="#">HDL language templates</a> (UM-290) pane                                     |
| Properties              | list a variety of information about the source file; for example, file type, file size, file modification date |

### Tools menu

|          |                                                                                                                                     |
|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| Examine  | display the current value of the selected item; same as the <b>examine</b> (CR-82) command; the item name is shown in the title bar |
| Describe | display information about the selected item; same as the <b>describe</b> command (CR-73); the item name is shown in the title bar   |
| Compile  | compile the currently active source file                                                                                            |

|             |                                                                                                                           |
|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Readers     | list the names of all readers of the selected signal or net                                                               |
| Drivers     | list the names of all drivers of the selected signal or net                                                               |
| Breakpoints | add, edit, or delete file-line and signal breakpoints; see " <a href="#">Creating and managing breakpoints</a> " (UM-284) |
| Options     | set various Source window options; see Options sub-menu below                                                             |

**Options sub-menu**

|                            |                                                                                                                                                                                                                                                        |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Colorize Source            | colorize key words, variables, and comments                                                                                                                                                                                                            |
| Highlight Executable Lines | highlight the line numbers of executable lines                                                                                                                                                                                                         |
| Middle Mouse Button Paste  | enable/disable pasting by pressing the middle-mouse button                                                                                                                                                                                             |
| Verilog Highlighting       | specify Verilog-style colorizing                                                                                                                                                                                                                       |
| VHDL Highlighting          | specify VHDL-style colorizing                                                                                                                                                                                                                          |
| Freeze File                | maintain the same source file in the Source window (useful when you have two Source windows open; one can be updated from the <a href="#">Structure window</a> (UM-230), the other frozen)                                                             |
| Freeze View                | disable updating the source view from other windows                                                                                                                                                                                                    |
| Auto-Indent Mode           | indent code automatically when editing the file                                                                                                                                                                                                        |
| Tab Stops                  | set tab stop distance in Source window (see " <a href="#">Setting tab stops in the Source window</a> " (UM-229))                                                                                                                                       |
| Examine Now                | examine selected item at the current simulation time; this option affects the behavior of the Examine and Describe commands as well as the examine popup; see " <a href="#">Checking item values and descriptions</a> " (UM-228)                       |
| Examine Current Cursor     | examine selected item at the time of the current cursor in the Wave window; this option affects the behavior of the Examine and Describe commands as well as the examine popup; see " <a href="#">Checking item values and descriptions</a> " (UM-228) |

**Window menu**

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Setting file-line breakpoints

You can easily set "[File-line breakpoints](#)" (UM-284) in the Source window using your mouse. Click on a blue line number at the left side of the Source window, and a red diamond denoting a breakpoint will appear. The breakpoints are toggles – click once to create the colored diamond; click again to disable or enable the breakpoint.

To delete the breakpoint completely, click the red diamond with your right mouse button, and select **Remove Breakpoint**. Other options on the context menu include:

- **Disable/Enable Breakpoint**  
Deactivate or activate the selected breakpoint.
- **Edit Breakpoint**  
Open the **File Breakpoint** dialog to change breakpoint arguments; see "[Adding a breakpoint](#)" (UM-286) for a description of the dialog.
- **Edit All Breakpoints**  
Open the **Modify Breakpoints** dialog; see "[Breakpoints dialog](#)" (UM-285).

## Checking item values and descriptions

There are two quick methods to determine the value and description of an item displayed in the Source window:

- select an item, then choose **Tools > Examine** or **Tools > Describe** from the Source window menu
- pause over an item with your mouse pointer to see an examine pop-up

Select **Tools > Options > Examine Now** or **Tools > Options > Examine Current Cursor** to determine at what simulation time the item is examined or described.

You can also invoke the **examine** (CR-82) and/or **describe** (CR-73) command on the command line or in a macro.

## Finding and replacing in the Source window

The Find dialog box allows you to find and replace text strings or regular expressions in the Source window.

Select **Edit > Find** or **Edit > Replace** to bring up the Find dialog box. If you select **Edit > Find**,

the **Replace** field is absent from the dialog.



Enter the value to search for in the **Find** field. If you are doing a replace, enter the appropriate value in the **Replace** field. Optionally specify whether the entries are **case sensitive** and whether to **search backwards** from the current cursor location. Check the **Regular expression** checkbox if you are using regular expressions.

## Setting tab stops in the Source window

You can set temporary tab stops in the Source window by selecting **Tools > Options > Tab Stops**. Follow these steps:

- 1** Select **Tools > Options > Tab Stops** (Source window).
- 2** In the dialog that appears, enter either a single number "n" and units, which sets a tab stop every n units, or enter a list of numbers which sets a tab at each location. Available units and their abbreviations are as follows:

| Units                 | Abbreviations |
|-----------------------|---------------|
| centimeters           | c, cm         |
| millimeters           | m, mm         |
| inches                | i, in         |
| points                | p             |
| pixels (screen units) | u             |
| characters            | char, chars   |

If you don't specify units, they default to characters.

Here are three examples:

- Enter 5 to set a tab stop every 5 characters.
- Enter 10c to set a tab stop every 10 centimeters.
- Enter a list of numbers like the following to set tab stops at specific character locations:  
21 49 77 105 133 161 189 217 245 273 301 329 357 385 413 441 469

**▲ Important:** Do not use quotes or braces in the list (i.e., "21 49" or {21 49}); this will cause the GUI to hang.

If you want to set permanent tab stops, you have to edit the `PrefSource(tabs)` preference variable and then save a `modelsim.tcl` file. See "[Preference variables located in Tcl files](#)" (UM-381) for further details.

## Structure window

The Structure window provides a hierarchical view of the structure of your design. In ModelSim versions 5.5 and later, the information contained in the Structure window is also shown in the structure tabs of the Main window [Workspace](#) (UM-164). The Structure window does not display by default. You can display the Structure window at any time by selecting **View > Structure** (Main window).

An entry is created by each item within the design. When you select a region in the Structure window, it becomes the *current region* and is highlighted. The [Source window](#) (UM-224) and [Signals window](#) (UM-215) change dynamically to reflect the information for that region. This feature provides a useful method for finding the source code for a selected region because the system keeps track of the pathname where the source is located and displays it automatically, without the need for you to provide the pathname.

Also, when you select a region in the Structure window, the [Process window](#) (UM-213) is updated if **In Region** is selected in that window. The Process window will in turn update the [Variables window](#) (UM-233).

### Items you can view

The following items are represented by hierarchy within the Structure window.

#### VHDL items

(indicated by a dark blue square icon)  
component instantiations,  
generate statements, block  
statements, and packages

#### Verilog items

(indicated by a lighter blue circle icon)  
module instantiations, named  
forks, named begins, tasks, and  
functions



### Virtual items

(indicated by an orange diamond icon)

virtual regions; see "[Virtual Objects \(User-defined buses, and more\)](#)" (UM-150) for more information.

You can expand and contract the display to view the hierarchical structure by clicking on the boxes that contain "+" or "-". Clicking "+" expands the hierarchy so the sub-elements of that item can be seen. Clicking "-" contracts the hierarchy.

## Structure window menu bar

This section provides information on select menu commands available in the Signals window. Several commands are also available on a context menu by right-clicking in the right-hand pane of the window (see "[Structure window context menu](#)" (UM-232) for some details).

### File menu

|             |                                                                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Save List   | save the structure tree to a text file viewable with the ModelSim <b>notepad</b> (CR-113)                                                                           |
| Environment | 1) specify that the window contents change when the active dataset is changed; 2) fix the window contents to a specific dataset; or 3) change to a new root context |

### View menu

|      |                                                                               |
|------|-------------------------------------------------------------------------------|
| Sort | sort the structure tree in either ascending, descending, or declaration order |
|------|-------------------------------------------------------------------------------|

### Window menu

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Structure window context menu

Access the following commands by clicking the right mouse button on an entry in the right-hand pane:

|             |                                                                                                                     |
|-------------|---------------------------------------------------------------------------------------------------------------------|
| View Source | opens the source file in the <a href="#">Source window</a> (UM-224); double-clicking will also open the source file |
| Add         | adds the selected item to the Dataflow, List, or Wave window or to the current log file                             |
| Save List   | writes the item names in the Structure tab to a text file                                                           |

## Finding items in the Structure window

The Find dialog box allows you to search for text strings in the Structure window. Select **Edit > Find** (Structure window) to bring up the Find dialog box.

Enter the value to search for in the **Find** field. Specify whether you are looking for an **Instance**, **Entity/Module**, or **Architecture**. Also specify which direction to search.

Check **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find */top/clk* and *clk1*.

Check **Auto Wrap** to continue the search at the beginning of the window.



## Variables window

The Variables window is divided into two window panes. The left pane lists the names of items within the current process. The right pane lists the current value(s) associated with each name. The pathname of the current process is displayed at the bottom of the window.

### Items you can view

The following types of items can be viewed in the Variables window:

VHDL items

constants, generics, and variables

Verilog items

registers and variables

VHDL composite types (arrays and record types) and Verilog vector registers and memories are shown in a hierarchical fashion.

ModelSim indicates hierarchy

with plus (expandable), minus (expanded), and blank (single level) boxes. See "[Tree window hierarchical view](#)" (UM-162) for more information.



To change the value of a VHDL variable, constant, or generic or a Verilog register or variable, move the pointer to the desired name and click to highlight the selection. Select **Edit > Change** (Variables window) to bring up a dialog box that lets you specify a new value. You can enter any value that is valid for the variable. An array value must be specified as a string (without surrounding quotation marks). To modify the values in a record, you need to change each field separately.

Click on a process in the Process window to change the Variables window.

## The Variables window menu bar

This section provides information on select menu commands available in the Variables window.

### File menu

|             |                                                                                                                                                                                                         |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Save List   | save the variable tree to a text file viewable with the ModelSim <a href="#">notepad</a> (CR-113)                                                                                                       |
| Environment | <b>Follow Process Selection:</b> update the window based on the selection in the <a href="#">Process window</a> (UM-213)<br><br><b>Fix to Current Process:</b> maintain the current view, do not update |
| Close       | close this copy of the Variables window                                                                                                                                                                 |

### Edit menu

|        |                                          |
|--------|------------------------------------------|
| Change | change the value of the selected item(s) |
|--------|------------------------------------------|

### View menu

|                |                                                                               |
|----------------|-------------------------------------------------------------------------------|
| Sort           | sort the variables tree in either ascending, descending, or declaration order |
| Justify Values | justify values to the left or right margins of the window pane                |

### Add menu

Add variables to the Wave or List windows or the current WLF file.

### Window menu

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Finding items in the Variables window

To find the specified text string within the Variables window, choose the **Name** or **Value** field to search and the search direction: **Down** or **Up**.



Check **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find /top/clk and clk1.

Check **Auto Wrap** to continue the search at the beginning of the window.

You can also do a quick find from the keyboard. When the Variables window is active, each time you type a letter the highlight will move to the next item whose name begins with that letter.

## Wave window

The Wave window, like the List window, allows you to view the results of your simulation. In the Wave window, however, you can see the results as waveforms and their values.

The Wave window is divided into a number of window panes. All window panes in the Wave window can be resized by clicking and dragging the bar between any two panes.



### Pathname pane

The pathname pane displays signal pathnames. Signals can be displayed with full pathnames, as shown here, or with only the leaf element displayed. You can increase the size of the pane by clicking and dragging on the right border. The selected signal is highlighted.

The white bar along the left margin indicates the selected dataset (see "[Splitting Wave window panes](#)" (UM-243)).

## Value pane

The value pane displays the values of the displayed signals.

The radix for each signal can be symbolic, binary, octal, decimal, unsigned, hexadecimal, ASCII, or default. The default radix can be set by selecting **Simulate > Simulation Options** (Main window) (see "[Setting default simulation options](#)" (UM-281)).

The data in this pane is similar to that shown in the [Signals window](#) (UM-215), except that the values change dynamically whenever a cursor in the waveform pane is moved.

## Waveform pane

The waveform pane displays the waveforms that correspond to the displayed signal pathnames. It also displays up to 20 cursors. Signal values can be displayed in analog step, analog interpolated, analog backstep, literal, logic, and event formats. Each signal can be formatted individually. The default format is logic.

If you rest your mouse pointer on a signal in the waveform pane, a popup displays with information about the signal. You can toggle this popup on and off in the **Wave Window Properties** dialog (see "[Setting Wave window display properties](#)" (UM-251)).

## Cursor panes

There are three cursor panes—the left pane shows the cursor names; the middle pane shows the current simulation time and the value for each cursor; and the right pane shows the absolute time value for each cursor and relative time between cursors. Up to 20 cursors can be displayed. See "[Using time cursors in the Wave window](#)" (UM-255) for more information.

## Items you can view

The following types of items can be viewed in the Wave window

### VHDL items

(indicated by a dark blue square)  
signals, aliases, process variables, and shared variables

### Verilog items

(indicated by a light blue circle)  
nets, registers, variables, and named events

### Virtual items

(indicated by an orange diamond)  
virtual signals, buses, and functions, see; "[Virtual Objects \(User-defined buses, and more\)](#)" (UM-150) for more information

### Comparison items

(indicated by a yellow triangle)

comparison region and comparison signals; see *Chapter 11 - Waveform Compare* for more information

Constants, generics, and parameters are not viewable in the Wave windows.

The data in the item values pane is very similar to the Signals window, except that the values change dynamically whenever a cursor in the waveform pane is moved.

At the bottom of the waveform pane you can see a time line, tick marks, and the time value of each cursor's position. As you click and drag to move a cursor, the time value at the cursor location is updated at the bottom of the cursor.

You can resize the window panes by clicking on the bar between them and dragging the bar to a new location.

Waveform and signal-name formatting are easily changed via the [Format menu](#) (UM-241). You can reuse any formatting changes you make by saving a Wave window format file, see "[Adding items with a Wave window format file](#)" (UM-238).

## Adding items in the Wave window

Before adding items to the Wave window you may want to set the window display properties (see "[Setting Wave window display properties](#)" (UM-251)). You can add items to the Wave window in several ways.

### ***Adding items from other window with drag and drop***

You can drag and drop items into the Wave window from the List, Process, Signals, Source, Structure, or Variables window. Select the items in the first window, then drop them into the Wave window. Depending on what you select, all items or any portion of the design can be added.

### ***Adding items from the command line***

To add specific items to the window, enter (separate the item names with a space):

```
VSIM> add wave <item_name> <item_name>
```

You can add all the items in the current region with this command:

```
VSIM> add wave *
```

Or add all the items in the design with:

```
VSIM> add wave -r /*
```

### ***Adding items with a Wave window format file***

Select **File > Open > Format** and specify a previously saved format file. See "[Saving the Wave window format](#)" (UM-239) for details on how to create a format file.

## Saving the Wave window format

By default all Wave window information is forgotten once you close the Wave window. If you want to restore the Wave window to a previously configured layout, you must save a Wave window format file. Follow these steps:

- 1** Add the items you want to the Wave window.
- 2** Edit and format the items, see "[Editing and formatting items in the Wave window](#)" (UM-246) to create the view you want.
- 3** Save the format to a file by selecting **File > Save > Format** (Wave window).

To use the format file, start with a blank Wave window and run the DO file in one of two ways:

- Invoke the **do** command (CR-75) from the command line:  
`VSIM> do <my_wave_format>`
- Select **File > Open > Format** (Wave window).

► **Note:** Wave window format files are design-specific; use them only with the design you were simulating when they were created.

## The Wave window menu bar

This section provides information on select menu commands available in the Wave window. Many of these commands are also available via a context menu by clicking your right mouse button within the Wave window itself.

### File menu

|                  |                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Open             | Format – run a Wave window format (DO) file previously saved with Save Format; see " <a href="#">Saving the Wave window format</a> " (UM-239)                                                               |
| Save             | Format – save the current Wave window display and signal preferences to a DO (macro) file; see " <a href="#">Saving the Wave window format</a> " (UM-239)<br>Image – saves a bitmap file of the Wave window |
| Page Setup       | configure page setup for printing; see " <a href="#">Printer Page Setup</a> " (UM-263)                                                                                                                      |
| Print Postscript | save or print the waveform display as a Postscript file; see " <a href="#">Saving waveforms</a> " (UM-260) for details                                                                                      |

**Edit menu**

|                                |                                                                                                     |
|--------------------------------|-----------------------------------------------------------------------------------------------------|
| Edit Cursor                    | open a dialog to specify the location of the selected cursor                                        |
| Delete Cursor                  | delete the selected cursor from the window                                                          |
| Delete Window Pane             | delete the selected window pane                                                                     |
| Remove All (Panes and Signals) | removes all signals and additional window panes, leaving the window in its original state           |
| Find                           | find the specified item label within the pathname pane or the specified value within the value pane |

**View menu**

|                    |                                                                                                                                                                                                              |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mouse Mode         | toggle mouse pointer between Select Mode (click left mouse button to select, drag with middle mouse button to zoom) and Zoom Mode (drag with left mouse button to zoom, click middle mouse button to select) |
| Signal Declaration | open the source file in the Source window and highlight the signal declaration for the currently selected signal                                                                                             |
| Cursors            | choose a cursor to go to from a list of available cursors                                                                                                                                                    |
| Bookmarks          | choose a bookmark to go to from a list of available bookmarks                                                                                                                                                |
| Goto Time          | scroll the Wave window so the specified time is in view; "g" hotkey produces the same result                                                                                                                 |
| Sort               | sort the top-level items in the pathname pane; sort with full path or viewed name; use ascending or descending order                                                                                         |
| Justify Values     | justify values to the left or right margins of the window pane                                                                                                                                               |
| Refresh Display    | clear the Wave window, empty the file cache, and rebuild the window from scratch                                                                                                                             |
| Signal Properties  | set properties for the selected item; see " <a href="#">Editing and formatting items in the Wave window</a> " (UM-246)                                                                                       |

**Insert menu**

|             |                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Divider     | insert a divider at the current location                                                                                                              |
| Breakpoint  | add a breakpoint on the selected signal; see " <a href="#">Signal breakpoints</a> " (UM-284)                                                          |
| Bookmark    | add a bookmark with the current zoom range and scroll location; see " <a href="#">Saving zoom range and scroll position with bookmarks</a> " (UM-258) |
| Cursor      | add a cursor to the waveform pane                                                                                                                     |
| Window Pane | split the pathname, values and waveform window panes to provide room for a new waveset                                                                |

**Format menu**

|        |                                                                                |
|--------|--------------------------------------------------------------------------------|
| Radix  | set the selected items' radix                                                  |
| Format | set the waveform format for the selected items – Literal, Logic, Event, Analog |
| Color  | set the color for the selected items from a color palette                      |
| Height | set the waveform height in pixels for the selected items                       |

**Tools menu**

|                    |                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------|
| Breakpoints        | add, edit, and delete signal breakpoints; see " <a href="#">Creating and managing breakpoints</a> " (UM-284)                 |
| Bookmarks          | add, edit, delete, and goto bookmarks; see " <a href="#">Saving zoom range and scroll position with bookmarks</a> " (UM-258) |
| Dataset Snapshot   | enable periodic saving of simulation data to a WLF file                                                                      |
| Combine Signals    | combine the selected items into a user-defined bus; see " <a href="#">Combining items in the Wave window</a> " (UM-244)      |
| Window Preferences | set various display properties; see " <a href="#">Setting Wave window display properties</a> " (UM-251)                      |

**Window menu**

The Window menu is identical in all windows. See "[Window menu](#)" (UM-169) for a description of the commands.

## Using dividers

Dividers serve as a visual aid to signal debugging, allowing you to separate signals and waveforms for easier viewing. Dividing lines can be placed in the pathname and values window panes by selecting **Insert > Divider** (Wave window). Or, you can add a divider using the **-divider** argument to the **add wave** command (CR-41).

Dividing lines can be assigned any name or no name at all. The default name is "New Divider." In the illustration below, two datasets have been separated with a Divider called "gold." Notice that the waveforms in the waveform window pane have been separated by the divider as well.



After you have added a divider, you can move it, change its properties (name and size), or delete it.

**To move a divider** — Click and drag the divider to the location you want.

**To change a divider's name and size** — Click the divider with the right mouse button and select Divider Properties from the pop-up menu.

**To delete a divider** — Select the divider and either press the <Delete> key on your keyboard or select Delete from the pop-up menu.

## Splitting Wave window panes

The pathnames, values, and waveforms panes of the Wave window display can be split to accommodate signals from one or more datasets. Selecting **Insert > Window Pane** (Wave window) creates a space below the selected dataset and makes the new window pane the selected pane. (The selected wave window pane is indicated by a white bar along the left margin of the pane.)

In the illustration below, the Wave window is split, showing the current active simulation with the prefix "sim," and a second view-mode dataset, with the prefix "gold."

For more information on viewing multiple simulations, see *Chapter 7 - WLF files (datasets) and virtuals.*



## Combining items in the Wave window

You can combine signals in the Wave window into busses. A bus is a collection of signals concatenated in a specific order to create a new virtual signal with a specific value. You can also do this from the ModelSim prompt using the **virtual signal** command (CR-198).

To create a bus, select one or more signals in the Wave window and then choose **Tools > Combine Signals**.



The **Combine Selected Signals** dialog box includes these options:

- **Result Name**  
Specifies the name of the newly created bus.
- **Order to combine selected items**  
Specifies the order in which to combine the selected signals. "Top down" specifies that the selected signals are ordered as they appear top-to-bottom in the Wave window. "Bottom up" reverses the order.
- **Order of Result Indexes**  
Specifies in which order the selected signals are indexed in the bus. If set to Ascending, the first signal selected in the Wave window will be assigned an index of 0. If set to Descending, the first signal selected will be assigned the highest index number.
- **Remove selected signals after combining**  
Specifies whether you want to remove the selected signals from the Wave window once the bus is created.

- **Reverse bit order of bus items in the result**

If checked, the bits of each selected signal are reversed in the newly created bus. The order of the signals in the bus is not affected.

- **Flatten arrays**

If checked, ModelSim combines the signals into one big array. If unchecked, ModelSim combines signals together without merging them into one array. The signals become elements of a record and retain their original names. When expanded, the new signal looks just like a group of signals.

- **Flatten records**

If checked, causes elements of a record type signal to be pulled up to the top level. This option is the reverse of "Flatten arrays."

In the illustration below, three signals have been combined to form a new bus called "bus". Note that the component signals are listed in the order in which they were selected in the Wave window. Also note that the value of the bus is made up of the values of its component signals, arranged in a specific order. Virtual objects are indicated by an orange diamond.



#### ***Other virtual items in the Wave window***

See "[Virtual Objects \(User-defined buses, and more\)](#)" (UM-150) for information about other virtual items viewable in the Wave window.

## Displaying drivers of the selected waveform

You can automatically display in the Dataflow window the drivers of a signal selected in the Wave window. You can do this three ways:

- Select a waveform and click the Show Drivers button on the toolbar.
- Select a waveform and select Show Drivers from the shortcut menu
- Double-click a waveform edge (you can enable/disable this option in the display properties dialog; see "[Setting Wave window display properties](#)" (UM-251))



This operation will open the Dataflow window and display the drivers of the signal selected in the Wave window. The Wave pane in the Dataflow window will also open showing the selected signal with a cursor at the selected time. The Dataflow window will show the signal(s) values at the current time cursor position.

## Editing and formatting items in the Wave window

Once you have the items you want in the Wave window, you can edit and format the list in the pathname and values panes to create the view you find most useful. (See also, "[Setting Wave window display properties](#)" (UM-251).)

### **To edit an item:**

Select the item's label in the pathname pane or its waveform in the waveform pane. Move, copy, or remove the item by selecting commands from the Wave window **Edit menu** (UM-240).

You can also **click+drag** to move items within the pathnames and values panes:

- to select several items:  
control+click to add or subtract from the selected group
- to move the selected items:  
re-click and hold on one of the selected items, then drag to the new location

### **To format an item:**

Select the item's label in the pathname pane or its waveform in the waveform pane, then select **View > Signal Properties** (Wave window) or use the selections in the **Format** menu.

When you select **View > Signal Properties** the Wave Signal Properties dialog box opens. It has three tabs: View, Format, and Compare.



The **View** tab includes these options:

- **Display Name**

Specifies a new name (in the pathname pane) for the selected signal.

- **Radix**

Specifies the Radix of the selected signal(s). Setting this to default causes the signal's radix to change whenever the default is modified using the [radix command](#) (CR-126). Item values are not translated if you select Symbolic.

- **Wave Color**

Specifies the waveform color. Select a new color from the color palette, or enter a color name. The Default button in the Colors palette allows you to return the selected item's color back to its default value.

- **Name Color**

Specifies the signal name's color. Select a new color from the color palette, or enter a color name. The Default button in the Colors palette allows you to return the selected item's color back to its default value.



The **Format** tab includes these options:

- **Format: Literal**

Displays the waveform as a box containing the item value (if the value fits the space available). This is the only format that can be used to list a record.

- **Format: Logic**  
Displays values as U, X, 0, 1, Z, W, L, H, or -.
  - **Format: Event**  
Marks each transition during the simulation run.
  - **Format: Analog [Step | Interpolated | Backstep]**  
*Analog Step*  
Displays the waveform in step style.  
*Analog Interpolated*  
Displays the waveform in interpolated style.  
*Analog Backstep*  
Displays the waveform in backstep style. Often used for power calculations.  
*Offset and Scale*  
Allows you to adjust the scale of the item as it is seen on the display. Offset is the number of pixels offset from zero. The scale factor reduces (if less than 1) or increases (if greater than 1) the number of pixels displayed.
- Only the following types are supported in Analog format:
- VHDL types:**
- All vectors - std logic vectors, bit vectors, and vectors derived from these types
  - Scalar integers
  - Scalar reals
  - Scalar times
- Verilog types:**
- All vectors
  - Scalar reals
  - Scalar integers

The signals in the following illustration demonstrate the various signal formats.



- **Height**

Allows you to specify the height (in pixels) of the waveform.

The **Compare** tab includes the same options as those in the Add Signal Options dialog box (see "[Comparison Method tab](#)" (UM-359)).

## Setting Wave window display properties

You can define display properties of the Wave window by selecting **Tools > Window Preferences** (Wave window). You can make these changes permanent by selecting **Tools > Save Preferences** (Main window). See "[Preference variables located in Tcl files](#)" (UM-381) for details on changing window properties permanently.

The dialog box has two tabs—**Display** and **Grid & Timeline**.



The **Display** tab includes the following options:

- **Display Signal Path**

Sets the display to show anything from the full pathname of each signal (e.g., *sim:/top/clk*) to only its leaf element (e.g., *sim:clk*). A non-zero number indicates the number of path elements to be displayed. The default is Full Path.

- **Justify Value**

Specifies whether the signal values will be justified to the left margin or the right margin in the values window pane.

- **Snap Distance**

Specifies the distance the cursor needs to be placed from an item edge to jump to that edge (a 0 specification turns off the snap).

- **Row Margin**

Specifies the distance in pixels between top-level signals.

- **Child Row Margin**

Specifies the distance in pixels between child signals.

- **Waveform Popup Enable**

Toggles on/off the popup that displays when you rest your mouse pointer on a signal or comparison object.

- **Waveform Selection Highlighting Enabled**

Toggles on/off waveform highlighting. When enabled the waveform is highlighted if you select the waveform or its value.

- **Double-Click to Show Drivers (Dataflow Window)**

Toggles on/off double-clicking to show the drivers of the selected waveform. See "["Displaying drivers of the selected waveform"](#) (UM-246) for more details.

- **On Close Warn for Save Format**

Toggles on/off a message that prompts you to save the Wave window format when you close the window. See "["Displaying drivers of the selected waveform"](#) (UM-246) for more details.

- **Dataset Prefix**

Specifies how signals from different datasets are displayed.

*Always Show Dataset Prefixes*

All dataset prefixes will be displayed along with the dataset prefix of the current simulation ("sim").

*Show Dataset Prefixes if 2 or more*

Displays all dataset prefixes if 2 or more datasets are displayed. "sim" is the default prefix for the current simulation.

*Never Show Dataset Prefixes*

No dataset prefixes will be displayed. This selection is useful if you are running only a single simulation.



The **Grid & Timeline** tab is used to configure grid lines and the horizontal axis in the waveform pane. You can also access this tab by right-clicking in the cursor tracks at the bottom of the Wave window and selecting Grid & Timeline Properties. The tab has the following options:

- **Grid Offset**  
Specifies the time (in user time units) of the first grid line. Default is 0.
- **Grid Period**  
Specifies the time (in user time units) between subsequent grid lines. Default is 1.
- **Minimum Grid Spacing**  
Specifies the closest (in pixels) two grid lines can be drawn before intermediate lines will be removed. Default is 40.
- **Timeline Configuration**  
Specifies whether to display simulation time or grid period count on the horizontal axis. Default is to display simulation time.

## Sorting a group of items

Select **View > Sort** to sort the items in the pathname and values panes.

## Setting signal breakpoints

You can set "[Signal breakpoints](#)" (UM-284) in the Wave window. When a signal breakpoint is hit, a message appears in the Main window Transcript stating which signal caused the breakpoint.

To insert a signal breakpoint, right-click a signal and select **Insert Breakpoint**. A breakpoint will be set on the selected signal. See "[Creating and managing breakpoints](#)" (UM-284) for more information.

## Finding items by name or value in the Wave window

The Find dialog box allows you to search for text strings in the Wave window. Select **Edit > Find** (Wave window) to bring up the Find dialog box.

Choose either the Name or Value field to search and enter the value to search for in the Find field. **Find** the item by searching **Down** or **Up** through the Wave window display.

Check **Exact** if you only want to find items that match your search exactly. For example, searching for "clk" without **Exact** will find /top/clk and clk1.

Check **Auto Wrap** to continue the search at the beginning of the window.

The find operation works only within the active pane.



## Using time cursors in the Wave window



When the Wave window is first drawn, there is one cursor located at time zero. Clicking anywhere in the waveform display brings that cursor to the mouse location. You can add cursors to the waveform pane by selecting **Insert > Cursor** (or the Add Cursor button shown below). The selected cursor is drawn as a bold solid line; all other cursors are drawn with thin lines. Remove cursors by selecting them and selecting **Edit > Delete Cursor** (or the Delete Cursor button shown below).

|                                                                                                                                                 |                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|  <b>Insert Cursor</b><br>add a cursor to the waveform window |  <b>Delete Cursor</b><br>delete the selected cursor from the window |
|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|

### Naming cursors

By default cursors are named "Cursor <n>". To rename a cursor, click the name in the left-hand cursor pane with your right mouse button. Type a new name and press the <Enter> key on your keyboard.

### ***Locking cursors***

You can lock a cursor in position so it won't move. Select the cursor you wish to lock and select **Edit > Edit Cursor** (Wave window). In the dialog that appears, check **Lock cursor to specified time** and click OK. The cursor turns red and you can no longer drag it with the mouse.

As a convenience, you can hold down the <shift> key and click-and-drag a locked cursor. Once you let go of the cursor, it will be locked in the new position.

To unlock a cursor, select **Edit > Edit Cursor** and uncheck **Lock cursor to specified time**.

### ***Finding cursors***

The cursor value corresponds to the simulation time of that cursor. Choose a specific cursor view by selecting **View > Cursors**.

You can also access cursors by clicking a name or value in the left-hand cursor pane. Single-clicking selects a cursor; double-clicking jumps to a cursor. Alternatively, you can click a value with your second mouse button and type the value to which you want to scroll.

### ***Making cursor measurements***

Each cursor is displayed with a time box showing the precise simulation time at the bottom. When you have more than one cursor, each time box appears in a separate track at the bottom of the display. ModelSim also adds a delta measurement showing the time difference between two adjacent cursor positions.

If you click in the waveform display, the cursor closest to the mouse position is selected and then moved to the mouse position. Another way to position multiple cursors is to use the mouse in the time box tracks at the bottom of the display. Clicking anywhere in a track selects that cursor and brings it to the mouse position.

Cursors will "snap" to a waveform edge if you click or drag a cursor to within ten pixels of a waveform edge. You can set the snap distance in the Window Preferences dialog (select **Tools > Window Preferences**). You can position a cursor without snapping by dragging in the cursor track below the waveforms.

You can also move cursors to the next transition of a signal with these toolbar buttons:

|                                                                                                                                                                                           |                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <br><b>Find Previous Transition</b><br>locate the previous signal value change for the selected signal | <br><b>Find Next Transition</b><br>locate the next signal value change for the selected signal |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## Examining waveform values

You can use your mouse to display a dialog that shows the value of a waveform at a particular time. You can do this two ways:

- Rest your mouse pointer on a waveform. After a short delay, a dialog will pop-up that displays the value for the time at which your mouse pointer is positioned. If you'd prefer that this popup not display, it can be toggled off in the display properties. See "[Setting Wave window display properties](#)" (UM-251).
- Right-click a waveform and select **Examine**. A dialog displays the value for the time at which you clicked your mouse.

## Zooming - changing the waveform display range

Zooming lets you change the simulation range in the waveform pane. You can zoom using the context menu, toolbar buttons, mouse, keyboard, or commands.

You can access Zoom commands from the **View** menu on the toolbar or by clicking the right mouse button in the waveform pane.

The **Zoom** menu options include:

- **Zoom Full**  
Redraws the display to show the entire simulation from time 0 to the current simulation time.
- **Zoom In**  
Zooms in by a factor of two, increasing the resolution and decreasing the visible range horizontally.
- **Zoom Out**  
Zooms out by a factor of two, decreasing the resolution and increasing the visible range horizontally.
- **Zoom Last**  
Restores the display to where it was before the last zoom operation.
- **Zoom Range**  
Brings up a dialog box that allows you to enter the beginning and ending times for a range of time units to be displayed.

### Zooming with toolbar buttons

These zoom buttons are available on the toolbar:

|                                                                                                                                                                                                    |                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  <b>Zoom In 2x</b><br>zoom in by a factor of two<br>from the current view                                       |  <b>Zoom Out 2x</b><br>zoom out by a factor of<br>two from current view |
|  <b>Zoom Full</b><br>zoom out to view the full<br>range of the simulation<br>from time 0 to the current<br>time |  <b>Zoom Mode</b><br>change mouse pointer to<br>zoom mode; see below    |

### ***Zooming with the mouse***

To zoom with the mouse, first enter zoom mode by selecting **View > Mouse Mode > Zoom Mode** (Wave window). The left mouse button (<Button-1>) then offers 3 zoom options by clicking and dragging in different directions:

- Down-Right or Down-Left: Zoom Area (In)
- Up-Right: Zoom Out
- Up-Left: Zoom Fit

The zoom amount is displayed at the mouse cursor. A zoom operation must be more than 10 pixels to activate.

You can also enter zoom mode temporarily by holding the <Ctrl> key down while in select mode.

With the mouse in the Select Mode, the middle mouse button will perform the above zoom operations.

### ***Zooming keyboard shortcuts***

See "["Wave window mouse and keyboard shortcuts"](#) (UM-260) for a complete list of Wave window keyboard shortcuts.

## **Saving zoom range and scroll position with bookmarks**

Bookmarks allow you to save a particular zoom range and scroll position. This lets you return easily to a specific view later. You save the bookmark with a name, and then access the named bookmark from the Bookmark menu.

Bookmarks are saved in the Wave format file (see "["Adding items with a Wave window format file"](#) (UM-238)) and are restored when the format file is read. There is no limit to the number of bookmarks you can save.

Bookmarks can also be created and managed from the command line. See the **[bookmark add wave](#)** command (CR-48) for details.

To add a bookmark, select **Insert > Bookmark** (Wave window).



The Bookmark Properties dialog includes the following options.

- **Bookmark Name**

A text label to assign to the bookmark. The name will identify the bookmark on the **View > Bookmarks** menu.

- **Zoom Range**

A starting value and ending value that define the zoom range.

- **Top Index**

The item that will display at the top of the Wave window. For instance, if you specify 15, the Wave window will be scrolled down to show the 15th item in the window.

- **Save zoom range with bookmark**

When checked the zoom range will be saved in the bookmark.

- **Save scroll location with bookmark**

When checked the scroll location will be saved in the bookmark.

Once the bookmark is saved, select it by name from the **View > Bookmarks** menu, and the Wave window will be zoomed and scrolled accordingly.

To edit or delete a bookmark, select **Tools > Bookmarks** (Wave window).



The Bookmark Selection dialog includes the following options.

- **Add** (bookmark add wave)

Add a new bookmark.

- **Modify**

Edit the selected bookmark.

- **Delete** (bookmark delete wave)

Delete the selected bookmark.

- **Goto** (bookmark goto wave)

Zoom and scroll the Wave window using the selected bookmark.

## Wave window mouse and keyboard shortcuts

See "[Wave window mouse and keyboard shortcuts](#)" (UM-392).

## Saving waveforms

### *Saving a .eps file*

Select **File > Print Postscript** (Wave window) to save the waveform as a .eps file. The **Write Postscript** dialog box is shown below.



The **Write Postscript** dialog box includes these options:

#### Printer

- **File name**

Enter a filename for the encapsulated Postscript (.eps) file to be created; or browse to a previously created .eps file and use that filename.

#### Signal Selection

- **All signals**

Print all signals.

- **Current View**

Print signals in the current view.

- **Selected**

Print all selected signals.

### Time Range

- **Full Range**

Print all specified signals in the full simulation range.

- **Current view**

Print the specified signals for the viewable time range.

- **Custom**

Print the specified signals for a user-designated **From** and **To** time.

### Setup button

See "[Printer Page Setup](#)" (UM-263)

### **Printing on Windows platforms**

Select **File > Print** (Wave window) to print all or part of the waveform in the current Wave window, or save the waveform as a printer file (a Postscript file for Postscript printers). Printing and writing preferences are controlled by the dialog box shown below.



### Printer

- **Name**

Choose the printer from the drop-down menu. Set printer properties with the **Properties** button.

- **Status**

Indicates the availability of the selected printer.

- **Type**

Printer driver name for the selected printer. The driver determines what type of file is output if "Print to file" is selected.

- **Where**

The printer port for the selected printer.

- **Comment**

The printer comment from the printer properties dialog box.

- **Print to file**

Make this selection to print the waveform to a file instead of a printer. The printer driver determines what type of file is created. Postscript printers create a Postscript (.ps) file, non-Postscript printers create a .prn or printer control language file. To create an encapsulated Postscript file (.eps) use the **File > Print Postscript** menu selection.

#### Signal Selection

- **All signals**

Print all signals.

- **Current View**

Print signals in current view.

- **Selected**

Print all selected signals.

#### Time Range

- **Full Range**

Print all specified signals in the full simulation range.

- **Current view**

Print the specified signals for the viewable time range.

- **Custom**

Print the specified signals for a user-designated **From** and **To** time.

#### Setup button

See "[Printer Page Setup](#)" (UM-263)

### Printer Page Setup

Clicking the Setup button in the Write Postscript or Print dialog box allows you to define the following options (this is the same dialog that opens via **File > Page setup**).



- **Paper Size**

Select your output page size from a number of options; also choose the paper width and height.

- **Units**

Specify whether measurements are in inches or centimeters.

- **Margins**

Specify the page margins; changing the **Margin** will change the **Scale** and **Page** specifications.

- **Label width**

Specify Auto Adjust to accommodate any length label, or set a fixed label width.

- **Cursors**

Turn printing of cursors on or off.

- **Grid**  
Turn printing of grid lines on or off.
- **Color**  
Select full color printing, grayscale, or black and white.
- **Scaling**  
Specify a **Fixed** output time width in nanoseconds per page – the number of pages output is automatically computed; or, select **Fit to** to define the number of pages to be output based on the paper size and time settings; if set, the time-width per page is automatically computed.
- **Orientation**  
Select the output page orientation, **Portrait** or **Landscape**.

## Compiling with the graphic interface

You can use a project or the **Compile Source Files** dialog box to compile VHDL or Verilog designs. For information on compiling in a project, see "[Getting started with projects](#)" (UM-24). To open the Compile Source Files dialog, select **Compile > Compile** (Main window).



From the Compile Source Files dialog box you can:

- select source files to compile in any language combination
- specify the target library for the compiled design units
- select among the compiler options for VHDL Verilog

Select the **Default Options** button to change the compiler options, see "[Setting default compile options](#)" (UM-267) for details. The same Compiler Options dialog box can also be accessed by selecting **Compile > Compile Options** (Main window) or by selecting **Compile Properties** from the context menu in the Project tab.

Select the **Edit Source** button to view or edit a source file via the Compile dialog box. See "[Source window](#)" (UM-224) for additional source file editing information.

## Locating source errors during compilation

If a compiler error occurs during compilation, a red error message is printed in the Main transcript. Double-click on the error message to open the source file in an editable Source window with the error highlighted.



## Setting default compile options

Select **Compile > Compile Options** (Main window) to bring up the Compiler Options dialog.

**Important:** Note that changes made in the **Compiler Options** dialog box become the default for all future simulations.

### VHDL compiler options tab



The VHDL compiler options tab includes the following options:

- **Language Syntax**

Specifies which version of the 1076 standard to use when compiling. The default for versions 5.8 and later is 2002. You can also set this with arguments to the **vcom** command (CR-167) or by editing the **VHDL standard** (UM-380) variable in the *modelsim.ini* file. Changing the setting in the *modelsim.ini* file will make the setting permanent.

- **Use explicit declarations only**

Used to ignore an error in packages supplied by some other EDA vendors; directs the

compiler to resolve ambiguous function overloading in favor of the explicit function definition. Same as the **-explicit** argument to the **vcom** command (CR-167). Edit the **Explicit** (UM-370) variable in the *modelsim.ini* file to set a permanent default.

Although it is not intuitively obvious, the = operator is overloaded in the **std\_logic\_1164** package. All enumeration data types in VHDL get an “implicit” definition for the = operator. So while there is no explicit = operator, there is an implicit one. This implicit declaration can be hidden by an explicit declaration of = in the same package (LRM Section 10.3). However, if another version of the = operator is declared in a different package than that containing the enumeration declaration, and both operators become visible through **use** clauses, neither can be used without explicit naming, for example:

```
ARITHMETIC."="(left, right)
```

This option allows the explicit = operator to hide the implicit one.

- **Disable loading messages**

Disables loading messages in the Main window. Same as the **-quiet** argument for the **vcom** command (CR-167). Edit the **Quiet** (UM-371) variable in the *modelsim.ini* file to set a permanent default.

- **Show source lines with errors**

Causes the compiler to display the relevant lines of code in the transcript. Same as the **-source** argument to the **vcom** command (CR-167). Edit the **Show\_source** (UM-371) variable in the *modelsim.ini* file to set a permanent default.

- **Disable all optimizations**

Instructs the compiler to remove all optimizations. Same as the **-O0** argument to the **vcom** command (CR-167).

Check for:

- **Synthesis**

Turns on limited synthesis-rule compliance checking. Checks only signals used (read) by a process; also, checks understand only combinational logic, not clocked logic. Edit the **CheckSynthesis** (UM-370) variable in the *modelsim.ini* file to set a permanent default.

- **Vital Compliance**

Toggle Vital compliance checking. Edit the **NoVitalCheck** (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**Report Warnings on:****• Unbound component**

Flags any component instantiation in the VHDL source code that has no matching entity in a library that is referenced in the source code, either directly or indirectly. Edit the [Show\\_Warning1](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• Process without a WAIT statement**

Flags any process that does not contain a wait statement or a sensitivity list. Edit the [Show\\_Warning2](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• Null range**

Flags any null range, such as 0 down to 4. Edit the [Show\\_Warning3](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• No space in time literal (e.g. 5ns)**

Flags any time literal that is missing a space between the number and the time unit. Edit the [Show\\_Warning4](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• Multiple drivers on unresolved signals**

Flags any unresolved signals that have multiple drivers. Edit the [Show\\_Warning5](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**Optimize for:****• StdLogic1164**

Causes the compiler to perform special optimizations for speeding up simulation when the multi-value logic package `std_logic_1164` is used. Unless you have modified the `std_logic_1164` package, this option should always be checked. Edit the [Optimize\\_1164](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• Vital**

Toggle acceleration of the Vital packages. Edit the [NoVital](#) (UM-371) variable in the *modelsim.ini* file to set a permanent default.

**• Other VHDL options**

Enter any other valid `vcom` arguments. See the `vcom` command (CR-167) in the *ModelSim Command Reference* for a complete list.

**Verilog compiler options tab**

- **Enable runtime hazard checks**

Enables the run-time hazard checking code. Same as the **-hazards** argument to the **vlog** command (CR-204). Edit the **Hazard** (UM-370) variable in the *modelsim.ini* file to set a permanent default.

- **Convert identifiers to upper-case**

Converts regular Verilog identifiers to uppercase. Allows case insensitivity for module names. Same as the **-u** argument to the **vlog** command (CR-204). Edit the **UpCase** (UM-370) variable in the *modelsim.ini* file to set a permanent default.

- **Verilog 1995 Compatible**

Some requirements in Verilog 2001 conflict with requirements in the 1995 LRM. Use of this option ensures that code that was valid according to the 1995 LRM can still be compiled. Same as the **-vlog95compat** argument to the **vlog** command (CR-204). Edit the **vlog95compat** (UM-370) variable in the *modelsim.ini* file to set a permanent default.

- **Disable loading messages**

Disables loading messages in the Main window. Same as the **-quiet** argument for the **vlog** command (CR-204). Edit the **Quiet** (UM-371) variable in the *modelsim.ini* file to set a permanent default.

- **Show source lines with errors**

Causes the compiler to display the relevant lines of code in the transcript. Same as the **-source** argument to the **vlog** command (CR-204). Edit the **Show\_source** (UM-371) variable in the *modelsim.ini* file to set a permanent default.

- **Disable all optimizations**

Instructs the compiler to remove all optimizations. Same as the **-O0** argument to the **vlog** command (CR-204).

#### Other Verilog Options:

Specify any valid **vlog** command (CR-204) arguments. When you specify Other Verilog Options, they are saved into a file called *vlog.opt*. If you do this while a project is open, an OptionFile entry is written into your project file. If you do this when a project is not open, an OptionFile entry is written into the *modelsim.ini* file that you are currently using.

- **Library Search**

Specifies the Verilog source library directory to search for undefined modules. Same as the **-y <library\_directory>** argument for the **vlog** command (CR-204).

- **Extension**

Specifies the suffix of files in the library directory. Multiple suffixes can be used. Same as the **+libext+<suffix>** argument for the **vlog** command (CR-204).

- **Library File**

Specifies the Verilog source library file to search for undefined modules. Same as the **-v <library\_file>** argument for the **vlog** command (CR-204).

- **Include Directory**

Specifies a directory for files included with the **'include filename'** compiler directive. Same as the **+incdir+<directory>** argument for the **vlog** command (CR-204).

- **Macro**

Defines a macro to execute during compilation. Same as the compiler directive: **'define macro\_name macro\_text'**. Also the same as the **+define+<macro\_name> [ =<macro\_text> ]** argument for the **vlog** command (CR-204).

## Simulating with the graphic interface

You can use the Library tab in the workspace or the **Simulate** dialog box to simulate a compiled design. To simulate from the Library tab, simply double-click a design unit. To open the **Simulate** dialog, select **Simulate > Simulate** (Main window).

Six tabs - **Design**, **VHDL**, **Verilog**, **Libraries**, **SDF**, and **Options** - allow you to select various simulation options. You can switch between tabs to modify settings, then begin simulation by selecting the **OK** button.

### Design tab



The **Design** tab includes these options:

- **Simulate**

Specifies the design unit(s) to simulate. You can simulate your Verilog top-level module(s) or VHDL top-level design unit in one of two ways:

- Type a design unit name (configuration, module, or entity) into the field, separate additional names with a space. Specify library/design units with the following syntax:

```
[<library_name>.]<design_unit>
```

- Select a design unit from the list. You can select multiple design units from the list by using the control key when you click.

- **Resolution**

(-t [<multiplier>]<time\_unit>)

The drop-down menu sets the simulator time units.

Simulator time units can be expressed as any of the following:

| <b>Simulation time units</b> |              |
|------------------------------|--------------|
| 1fs, 10fs, or 100fs          | femtoseconds |
| 1ps, 10ps, or 100ps          | picoseconds  |
| 1ns, 10ns, or 100ns          | nanoseconds  |
| 1us, 10us, or 100us          | microseconds |
| 1ms, 10ms, or 100ms          | milliseconds |
| 1sec, 10sec, or 100sec       | seconds      |

See also, "[Simulator resolution limit](#)" (UM-63).

## VHDL tab



The **VHDL** tab includes these options:

### Generics

The **Add** button opens a dialog box (shown below) that allows you to specify the value of generics within the current simulation; generics are then added to the **Generics** list. You can also select a generic on the listing to **Delete** or **Edit**.

### From the **Specify a Generic** dialog box

you can set the following options.

- **Generic Name (-g <Name>=<Value>)**  
The name of the generic parameter. Type it in as it appears in the VHDL source (case is ignored).
- **Generic Value**  
Specifies a value for all generics in the design with the given name (above) that have not received explicit values in generic maps (such as top-level generics and generics that



would otherwise receive their default value). The value must be appropriate for the declared data type of the generic. No spaces are allowed in the specification (except within quotes) when specifying a string value.

- **Override Instance - specific Values (-G <Name>=<Value>)**

Select to override generics that received explicit values in generic maps. The name and value are specified as above. The use of this switch is indicated in the **Override** column of the **Generics** list.

#### VITAL

- **Disable Timing Checks (+notimingchecks)**

Disables timing checks generated by VITAL models.

- **Use Vital 2.2b SDF Mapping (-vital2.2b)**

Selects SDF mapping for VITAL 2.2b (default is Vital95).

- **Disable Glitch Generation (-noglitch)**

Disables VITAL glitch generation.

#### TEXTIO files

- **STD\_INPUT (-std\_input <filename>)**

Specifies the file to use for the VHDL textio STD\_INPUT file. Use the **Browse** button to locate a file within your directories.

- **STD\_OUTPUT (-std\_output <filename>)**

Specifies the file to use for the VHDL textio STD\_OUTPUT file. Use the **Browse** button to locate a file within your directories.

## Verilog tab



The **Verilog** tab includes these options:

### Pulse Options

- **Disable pulse error and warning messages** (+no\_pulse\_msg)  
Disables path pulse error warning messages.
- **Rejection Limit** (+pulse\_r/<percent>)  
Sets the module path pulse rejection limit as a percentage of the path delay.
- **Error Limit** (+pulse\_e/<percent>)  
Sets the module path pulse error limit as a percentage of the path delay.

### Other Options

- **Enable Hazard Checking** (-hazards)  
Enables hazard checking in Verilog modules.
- **Disable Timing Checks in Specify Blocks** (+notimingchecks)  
Disables the timing check system tasks (\$setup, \$hold,...) in specify blocks.
- **Delay Selection** (+mindelays | +typdelays | +maxdelays)  
Use the drop-down menu to select timing for min:typ:max expressions.
- **User Defined Arguments** (+<plusarg>)  
Arguments are preceded with "+", making them accessible through the Verilog PLI routine **mc\_scan\_plusargs**. The values specified in this field must have a "+" preceding them or ModelSim may parse them incorrectly.

## Libraries tab



The **Libraries** tab includes these options:

- **Search Libraries (-L)**  
Specifies the libraries to search for design units instantiated from Verilog.
- **Search Libraries First (-Lf)**  
Same as Search Libraries but these libraries are searched before 'uselib'.

## SDF tab



The **SDF** (Standard Delay Format) tab includes these options:

### SDF Files

Click the **Add** button to specify the SDF files to load for the current simulation; files are then added to the **SDF Files** list. You may also select a file on the listing to **Delete** or **Modify** (opens the dialog box below).



From the **Add SDF Entry** dialog box you can set the following options.

- **SDF file** ([<region>] = <sdf\_filename>)Specifies the SDF file to use for annotation. Use the **Browse** button to locate a file within your directories.
- **Apply to region** ([<region>] = <sdf\_filename>)Specifies the design region to use with the selected SDF options.
- **Delay** (-sdfmin | -sdftyp | -sdfmax)The drop-down menu selects delay timing (min, typ, or max) to be used from the specified SDF file. See also, "["Specifying SDF files for simulation"](#) (UM-314).

#### SDF options

- **Disable SDF warnings** (-sdfnowarn)Select to disable warnings from the SDF reader.
- **Reduce SDF errors to warnings** (-sdfnoerror)Change SDF errors to warnings so the simulation can continue.
- **Multi-Source Delay** (-multisource\_delay <sdf\_option>)Select **max**, **min**, or **latest** delay. Controls how multiple PORT or INTERCONNECT constructs that terminate at the same port are handled. By default, the Module Input Port Delay (MIPD) is set to the **max** value encountered in the SDF file. Alternatively, you can choose the **min** or **latest** of the values.

## Options tab



The **Options** tab includes these options:

- **Enable code coverage** (-coverage)  
Turn on collection of Code Coverage statistics. You must also specify which type of statistics you want when you compile the design.
- **Treat non-existent VHDL files ...** (-absentisempty)  
Cause VHDL files opened for read that target non-existent files to be treated as empty, rather than ModelSim issuing fatal error messages.
- **Do not share file descriptors...** (-nofileshare)  
By default ModelSim shares a file descriptor for all VHDL files opened for write or append that have identical names. This option turns off file descriptor sharing.
- **WLF File** (-wlf <filename>)  
Specify the name of the wave log format (WLF) file to create. The default is vsim.wlf.
- **Assert File** (-assertfile <filename>)  
Designate an alternative file for recording assertion messages. By default assertion messages are output to the file specified by the TranscriptFile variable in the *modelsim.ini* file (see "[Creating a transcript file](#)" (UM-378)).
- **Other options**  
Specify any other **vsim** command (CR-213) arguments.

## Setting default simulation options

Select **Simulate > Simulation Options** (Main window) to bring up the **Simulation Options** dialog box shown below. Changes made in the **Simulation Options** dialog box are the default for the current simulation only. Options can be saved as the default for future simulations by editing the simulator control variables in the *modelsim.ini* file; the variables to edit are noted in the text below.

### **Defaults tab**



The **Defaults** tab includes these options:

- **Default Radix**

Sets the default radix for the current simulation run. You can also use the **radix** (CR-126) command to set the same temporary default. A permanent default can be set by editing the **DefaultRadix** (UM-373) variable in the *modelsim.ini* file. The chosen radix is used for all commands (**force** (CR-90), **examine** (CR-82), **change** (CR-56) are examples) and for displayed values in the Signals, Variables, Dataflow, List, and Wave windows.

- **Suppress Warnings**

Selecting **From Synopsys Packages** suppresses warnings generated within the accelerated Synopsys std\_arith packages. Edit the **StdArithNoWarnings** (UM-376) variable in the *modelsim.ini* file to set a permanent default.

Selecting **From IEEE Numeric Std Packages** suppresses warnings generated within the accelerated numeric\_std and numeric\_bit packages. Edit the **NumericStdNoWarnings** (UM-375) variable in the *modelsim.ini* file to set a permanent default.

- **Default Run**

Sets the default run length for the current simulation. Edit the **RunLength** (UM-375) variable in the *modelsim.ini* file to set a permanent default.

- **Iteration Limit**

Sets a limit on the number of deltas within the same simulation time unit to prevent infinite looping. Edit the [IterationLimit](#) (UM-374) variable in the *modelsim.ini* file to set a permanent iteration limit default.

- **Default Force Type**

Selects the default force type for the current simulation. Edit the [DefaultForceKind](#) (UM-373) variable in the *modelsim.ini* file to set a permanent default.

### **Assertions tab**



The **Assertions** tab includes these options:

- **Break on Assertion**

Selects the assertion severity that will stop simulation. Edit the [BreakOnAssertion](#) (UM-373) variable in the *modelsim.ini* file to set a permanent default.

- **Ignore Assertions For**

Selects the assertion type to ignore for the current simulation. Multiple selections are possible. Edit the [IgnoreFailure](#), [IgnoreError](#), [IgnoreWarning](#), and [IgnoreNote](#) (UM-374) variables in the *modelsim.ini* file to set permanent defaults.

When an assertion type is ignored, no message will be printed, nor will the simulation halt (even if break on assertion is set for that type).

► **Note:** Assertions that appear within an instantiation or configuration port map clause conversion function will not stop the simulation regardless of the severity level of the assertion.

***WLF Files tab***

The **WLF Files** tab includes these options:

- **WLF File Size Limit**

Limits the WLF file by size (as closely as possible) to the specified number of megabytes. If both size and time limits are specified, the most restrictive is used. Setting it to 0 results in no limit. Edit the [WLFSIZELIMIT](#) (UM-377) variable in the *modelsim.ini* file to set a permanent default.

- **WLF File Time Limit**

Limits the WLF file by size (as closely as possible) to the specified amount of time. If both time and size limits are specified, the most restrictive is used. Setting it to 0 results in no limit. Edit the [WLFTIMELIMIT](#) (UM-377) variable in the *modelsim.ini* file to set a permanent default.

- **WLF Attributes**

Specifies whether to compress WLF files and whether to delete the WLF file when the simulation ends. You would typically only disable compression for troubleshooting purposes. Edit the [WLFCOMPRESS](#) (UM-376) variable in the *modelsim.ini* file to set a permanent default for compression. Edit the [WLFDLTIONQUIT](#) (UM-377) variable in the *modelsim.ini* file to set a permanent default for WLF file deletion.

- **Design Hierarchy**

Specifies whether to save all design hierarchy in the WLF file or only regions containing logged signals. Edit the [WLFSAVEALLREGIONS](#) (UM-377) variable in the *modelsim.ini* file to set a permanent default.

## Creating and managing breakpoints

ModelSim supports both signal (i.e., when conditions) and file-line breakpoints. Breakpoints can be set from multiple locations in the GUI or from the command line.

### Signal breakpoints

Signal breakpoints (when conditions) instruct ModelSim to perform actions when the specified conditions are met. For example, you can break on a signal value or at a specific simulator time (see the [when](#) command (CR-228) for additional details). When a breakpoint is hit, a message in the Main window transcript identifies the signal that caused the breakpoint.

#### ***Setting signal breakpoints from the command line***

You use the [when](#) command (CR-228) to set a signal breakpoint from the VSIM> prompt. See the *Command Reference* for further details.

#### ***Setting signal breakpoints from the GUI***

Signal breakpoints are most easily set in the [Signals window](#) (UM-215) and the [Wave window](#) (UM-236). Right-click a signal and select **Insert Breakpoint** from the context menu. A breakpoint is set on that signal and will be listed in the **Breakpoints** dialog.

Alternatively you can set signal breakpoints from the [Breakpoints dialog](#) (UM-285).

### File-line breakpoints

File-line breakpoints are set on executable lines in your source files. When the line is hit, the simulator stops.

#### ***Setting file-line breakpoints from the command line***

You use the [bp](#) command (CR-52) to set a file-line breakpoint from the VSIM> prompt. See the *Command Reference* for further details.

#### ***Setting file-line breakpoints from the GUI***

File-line breakpoints are most easily set using your mouse in the [Source window](#) (UM-224). Click on a blue line number at the left side of the Source window, and a red diamond denoting a breakpoint will appear. The breakpoints are toggles – click once to create the colored diamond; click again to disable or enable the breakpoint. To delete the breakpoint completely, click the red diamond with your right mouse button, and select **Remove Breakpoint**.

Alternatively you can set file-line breakpoints from the [Breakpoints dialog](#) (UM-285).

## Breakpoints dialog

The Breakpoints dialog box allows you to create and manage both [Signal breakpoints](#) (UM-284) and [File-line breakpoints](#) (UM-284). Select **Tools > Breakpoints** from the Main, Signals, Source, or Wave windows to open the dialog.



The **Breakpoints** dialog includes these options:

- **Breakpoints**

List of all existing breakpoints. Breakpoints set from anywhere in the GUI, or from the command line, are listed. A red 'X' through the hand icon means the breakpoint is currently disabled.

- **Add**

Create a new signal or file-line breakpoint. See below for more details.

- **Modify**

Change properties of an existing breakpoint. See below for more details.

- **Disable/Enable**

De-activate or activate the selected breakpoint.

- **Delete**

Delete the selected breakpoint.

- **Label**

Text label of the selected breakpoint.

- **Condition**  
The condition under which the breakpoint will be hit.
- **Command**  
The command that will be executed when the breakpoint is hit.

### ***Adding a breakpoint***

Click Add to add a new breakpoint, and you will see the Add Breakpoint dialog.



Choose whether to create a signal breakpoint or a file-line breakpoint and then select Next. Depending on which type of breakpoint you're creating, you'll see one of the two dialogs below. These are the same dialogs you'll see if you modify an existing breakpoint.



The **Signals Breakpoint** dialog includes these options:

- **Breakpoint Label**  
Specify an optional text label for the breakpoint.
- **Breakpoint Condition**  
Specify condition(s) to be met for the command(s) to be executed. See the **when** command (CR-228) for more information on creating the condition statement.

- **Breakpoint Commands**

Specify command(s) to be executed when the condition is met. Any ModelSim or Tcl command or series of commands are valid, with one exception – the **run** command (CR-133) cannot be used.



The **File Breakpoint** dialog includes these options:

- **File**

Specify the file in which to set the breakpoint.

- **Line**

Specify the line number on which to set the breakpoint. Note that breakpoints can be set only on executable lines.

- **Instance Name**

Specify a region in which to apply the breakpoint. If left blank the breakpoint affects every instance in the design.

- **Breakpoint Condition**

Specify a condition that determines whether the breakpoint is hit.

- **Breakpoint Commands**

Specify command(s) to be executed when the breakpoint is hit. Any ModelSim or Tcl command or series of commands are valid, with one exception – the **run** command (CR-133) cannot be used.

## Miscellaneous tools and add-ons

Several miscellaneous tools and add-ons are available from ModelSim menus. Follow the links below for more information.

- [The GUI Expression Builder](#) (UM-288)  
**Edit > Search > Search for Expression > Builder** (List or Wave window)  
 Helps you build logical expressions for use in Wave and List window searches and several simulator commands. For expression format syntax see "["GUI\\_expression\\_format"](#)" (CR-20).
- [HDL language templates](#) (UM-290)  
**View > Show language templates** (Source window)  
 Helps you write VHDL or Verilog code.

### The GUI Expression Builder

The GUI Expression Builder is a feature of the Wave and List Signal Search dialog boxes, and the List trigger properties dialog box. It aids in building a search expression that follows the "["GUI\\_expression\\_format"](#)" (CR-20).

To locate the Builder:

- select **Edit > Search** (List or Wave window)
- select the **Search for Expression** option in the resulting dialog box
- select the **Builder** button



The Expression Builder dialog box provides an array of buttons that help you build a GUI expression. For instance, rather than typing in a signal name, you can select the signal in the associated Wave or List window and press Insert Reference Signal in the Expression

Builder. The result will be the full signal name added to the expression field. All Expression Builder buttons correspond to the "["Expression syntax"](#)" (CR-21).

***To search for when a signal reaches a particular value***

Select the signal in the Wave window and click **Insert Selected Signal** and ==. Then, click the value buttons or type a value.

***To evaluate only on clock edges***

Click the **&&** button to AND this condition with the rest of the expression. Then select the clock in the Wave window and click **Insert Selected Signal** and **'rising'**. You can also select the falling edge or both edges.

***Operators***

Other buttons will add operators of various kinds (see "["Expression syntax"](#)" (CR-21)), or you can type them in.

## HDL language templates

ModelSim language templates help you write VHDL or Verilog code. They are a collection of wizards, menus, and dialogs that produce code for new designs, language constructs, logic blocks, etc.

**Important:** The language templates are not intended to replace thorough knowledge of coding. They are intended as an interactive "reference" for creating small sections of code. If you are unfamiliar with VHDL or Verilog, you should attend a training class or consult one of the many books available on HDL languages.

To use the templates, either open an existing HDL file in the **Source window** (UM-224), or select **File > New (Source window)** to create a new file. Once the file is open, select **View > Show language templates**. This displays a pane that shows the available templates.



The templates that appear depend on the type of file you create. For example Module and Primitive templates are available for Verilog files, and Entity and Architecture templates are available for VHDL files.

Double-click an item in the list to begin creating code. Some of the items bring up wizards while others insert code into your HDL file. The dialog below is part of the wizard for creating a new design. Simply follow the directions in the wizards.



Code inserted into your source file may contain yellow or gray highlighted "fields". Yellow highlighting identifies an object that needs a name. Double-click the yellow object to enter a name. Note that all yellow objects with the same label (e.g., "configuration\_name" below) will change to whatever name you enter. This ensures matching fields remain in synch.



Gray highlighting indicates that a context menu with additional commands is available. In the example below, right-clicking "configuration\_declarative\_part" gives you three options for continuing the definition of the Configuration.



The first menu item is always "DELETE." This allows you to remove unwanted objects from the HDL code, such as optional fields.

#### **Keyboard shortcut**

<control - p> edits a yellow field and expands a gray field at the current cursor location.

# 9 - Signal Spy

---

## Chapter contents

|                                          |        |
|------------------------------------------|--------|
| <a href="#">Introduction</a>             | UM-294 |
| <a href="#">Designed for testbenches</a> | UM-294 |
| <a href="#">init_signal_driver</a>       | UM-295 |
| <a href="#">init_signal_spy</a>          | UM-298 |
| <a href="#">signal_force</a>             | UM-300 |
| <a href="#">signal_release</a>           | UM-302 |
| <a href="#">\$init_signal_driver</a>     | UM-304 |
| <a href="#">\$init_signal_spy</a>        | UM-307 |
| <a href="#">\$signal_force</a>           | UM-309 |
| <a href="#">\$signal_release</a>         | UM-311 |

This chapter describes the Signal Spy<sup>TM</sup> procedures and system tasks. These allow you to monitor, drive, force, and release hierarchical items in VHDL or mixed designs.

## Introduction

The Verilog language allows access to any signal from any other hierarchical block without having to route it via the interface. This means you can use hierarchical notation to either assign or determine the value of a signal in the design hierarchy from a testbench. This capability fails when a Verilog testbench attempts to reference a signal in a VHDL block or reference a signal in a Verilog block through a VHDL level of hierarchy.

This limitation exists because VHDL does not allow hierarchical notation. In order to reference internal hierarchical signals, you have to resort to defining signals in a global package and then utilize those signals in the hierarchical blocks in question. But, this requires that you keep making changes depending on the signals that you want to reference.

The Signal Spy procedures and system tasks overcome the aforementioned limitations. They allow you to monitor (spy), drive, force, or release hierarchical objects in a VHDL or mixed design.

The VHDL procedures are provided via the "[Util package](#)" (UM-73) within the *modelsim\_lib* library. To access the procedures you would add lines like the following to your VHDL code:

```
library modelsim_lib;
use modelsim_lib.util.all;
```

The Verilog tasks are available as built-in "[System tasks](#)" (UM-106). The table below shows the VHDL procedures and their corresponding Verilog system tasks.

| VHDL procedures                             | Verilog system tasks          |
|---------------------------------------------|-------------------------------|
| <a href="#">init_signal_driver</a> (UM-295) | \$init_signal_driver (UM-304) |
| <a href="#">init_signal_spy</a> (UM-298)    | \$init_signal_spy (UM-307)    |
| <a href="#">signal_force</a> (UM-300)       | \$signal_force (UM-309)       |
| <a href="#">signal_release</a> (UM-302)     | \$signal_release (UM-311)     |

## Designed for testbenches

Signal Spy limits the portability of your code. HDL code with Signal Spy procedures or tasks works only in ModelSim, not other simulators. We therefore recommend using Signal Spy only in testbenches, where portability is less of a concern, and the need for such a tool is more applicable.

## init\_signal\_driver

The init\_signal\_driver() procedure drives the value of a VHDL signal or Verilog net (called the *src\_object*) onto an existing VHDL signal or Verilog net (called the *dest\_object*). This allows you to drive signals or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench).

The init\_signal\_driver procedure drives the value onto the destination signal just as if the signals were directly connected in the HDL code. Any existing or subsequent drive or force of the destination signal, by some other means, will be considered with the init\_signal\_driver value in the resolution of the signal.

### Call only once

The init\_signal\_driver procedure creates a persistent relationship between the source and destination signals. Hence, you need to call init\_signal\_driver only once for a particular pair of signals. Once init\_signal\_driver is called, any change on the source signal will be driven on the destination signal until the end of the simulation.

Thus, we recommend that you place all init\_signal\_driver calls in a VHDL process. You need to code the VHDL process correctly so that it is executed only once. The VHDL process should not be sensitive to any signals and should contain only init\_signal\_driver calls and a simple wait statement. The process will execute once and then wait forever. See the example below.

### Syntax

```
init_signal_driver(src_object, dest_object, delay, delay_type, verbose)
```

### Returns

Nothing

## Arguments

| Name        | Type     | Description                                                                                                                                                                                                                                                                                                              |
|-------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| src_object  | string   | Required. A full hierarchical path (or relative path with reference to the calling block) to a VHDL signal or Verilog net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or "..". The path must be contained within double quotes.           |
| dest_object | string   | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or "..". The path must be contained within double quotes. |
| delay       | time     | Optional. Specifies a delay relative to the time at which the src_object changes. The delay can be an inertial or transport delay. If no delay is specified, then a delay of zero is assumed.                                                                                                                            |
| delay_type  | del_mode | Optional. Specifies the type of delay that will be applied. The value must be either mti_inertial or mti_transport. The default is mti_inertial.                                                                                                                                                                         |
| verbose     | integer  | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the src_object is driving the dest_object. Default is 0, no message.                                                                                                                                  |

## Related procedures

[init\\_signal\\_spy](#) (UM-298), [signal\\_force](#) (UM-300), [signal\\_release](#) (UM-302)

## Limitations

- When driving a Verilog net, the only *delay\_type* allowed is inertial. If you set the delay type to *mti\_transport*, the setting will be ignored and the delay type will be *mti\_inertial*.
- Any delays that are set to a value less than the simulator resolution will be rounded to the nearest resolution unit; no special warning will be issued.

## Example

```

library IEEE, modelsim_lib;
use IEEE.std_logic_1164.all;
use modelsim_lib.util.all;

entity testbench is
end;

architecture only of testbench is
    signal clk0 : std_logic;

begin

    gen_clk0 : process
    begin
        clk0 <= '1' after 0 ps, '0' after 20 ps;
        wait for 40 ps;
    end process gen_clk0;

    drive_sig_process : process
    begin
        init_signal_driver("clk0", "/testbench/uut/blk1/clk", open, open, 1);
        init_signal_driver("clk0", "/testbench/uut/blk2/clk", 100 ps,
                           mti_transport);
        wait;
    end process drive_sig_process;

    ...
end;

```

The above example creates a local clock (*clk0*) and connects it to two clocks within the design hierarchy. The .../blk1/clk will match local *clk0* and a message will be displayed. The *open* entries allow the default delay and delay\_type while setting the verbose parameter to a 1. The .../blk2/clk will match the local *clk0* but be delayed by 100 ps.

## init\_signal\_spy

The init\_signal\_spy() procedure mirrors the value of a VHDL signal or Verilog register/net (called the src\_object) onto an existing VHDL signal or Verilog register/net (called the dest\_object). This allows you to reference signals, registers, or nets at any level of hierarchy from within a VHDL architecture (e.g., a testbench).

The init\_signal\_spy procedure only sets the value onto the destination signal and does not drive or force the value. Any existing or subsequent drive or force of the destination signal, by some other means, will override the value that was set by init\_signal\_spy.

### Call only once

The init\_signal\_spy procedure creates a persistent relationship between the source and destination signals. Hence, you need to call init\_signal\_spy once for a particular pair of signals. Once init\_signal\_spy is called, any change on the source signal will mirror on the destination signal until the end of the simulation.

Thus, we recommend that you place all init\_signal\_spy calls in a VHDL process. You need to code the VHDL process correctly so that it is executed only once. The VHDL process should not be sensitive to any signals and should contain only init\_signal\_spy calls and a simple wait statement. The process will execute once and then wait forever, which is the desired behavior. See the example below.

### Syntax

```
init_signal_spy(src_object, dest_object, verbose)
```

### Returns

Nothing

### Arguments

| Name       | Type   | Description                                                                                                                                                                                                                                                                                                            |
|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| src_object | string | Required. A full hierarchical path (or relative path with reference to the calling block) to a VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |

| Name        | Type    | Description                                                                                                                                                                                                                                                                                                                  |
|-------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string  | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog register. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |
| verbose     | integer | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the src_object's value is mirrored onto the dest_object. Default is 0, no message.                                                                                                                        |

## Related functions

[init\\_signal\\_driver](#) (UM-295), [signal\\_force](#) (UM-300), [signal\\_release](#) (UM-302)

## Limitations

- When mirroring the value of a Verilog register/net onto a VHDL signal, the VHDL signal must be of type bit, bit\_vector, std\_logic, or std\_logic\_vector.
- Verilog memories (arrays of registers) are not supported.

## Example

```

library ieee, modelsim_lib;
use ieee.std_logic_1164.all
use modelsim_lib.util.all;
entity top is
end;

architecture only of top is
  signal top_sig1 : std_logic;
begin
  ...
  spy_process : process
  begin
    init_signal_spy("/top/uut/inst1/sig1","/top_sig1",1);
    wait;
  end process spy_process;
  ...
end;

```

In this example, the value of */top/uut/inst1/sig1* will be mirrored onto */top\_sig1*.

## signal\_force

The signal\_force() procedure forces the value specified onto an existing VHDL signal or Verilog register or net (called the dest\_object). This allows you to force signals, registers, or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench).

A signal\_force works the same as the **force** command (CR-90) with the exception that you cannot issue a repeating force. The force will remain on the signal until a signal\_release, a force or release command, or a subsequent signal\_force is issued. Signal\_force can be called concurrently or sequentially in a process.

### Syntax

```
signal_force( dest_object, value, rel_time, force_type, cancel_period,
    verbose )
```

### Returns

Nothing

### Arguments

| Name        | Type      | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string    | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |
| value       | string    | Required. Specifies the value to which the dest_object is to be forced. The specified value must be appropriate for the type.                                                                                                                                                                                                    |
| rel_time    | time      | Optional. Specifies a time relative to the current simulation time for the force to occur. The default is 0.                                                                                                                                                                                                                     |
| force_type  | forcetype | Optional. Specifies the type of force that will be applied. The value must be one of the following; default, deposit, drive, or freeze. The default is "default" (which is "freeze" for unresolved objects or "drive" for resolved objects). See the <b>force</b> command (CR-90) for further details on force type.             |

| Name          | Type    | Description                                                                                                                                                                                                                                                                                                         |
|---------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cancel_period | time    | Optional. Cancels the signal_force command after the specified period of time units. Cancellation occurs at the last simulation delta cycle of a time unit. A value of zero cancels the force at the end of the current time period. Default is -1 ms. A negative value means that the force will not be cancelled. |
| verbose       | integer | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the value is being forced on the dest_object at the specified time. Default is 0, no message.                                                                                                    |

## Related functions

[init\\_signal\\_driver](#) (UM-295), [init\\_signal\\_spy](#) (UM-298), [signal\\_release](#) (UM-302)

## Limitations

You cannot force bits or slices of a register; you can force only the entire register.

## Example

```

library IEEE, modelsim_lib;
use IEEE.std_logic_1164.all;
use modelsim_lib.util.all;

entity testbench is
end;

architecture only of testbench is
begin

    force_process : process
    begin
        signal_force("/testbench/uut/b1k1/reset", "1", 0 ns, freeze, open, 1);
        signal_force("/testbench/uut/b1k1/reset", "0", 40 ns, freeze, 2 ms, 1);
        wait;
    end process force_process;

    ...

end;

```

The above example forces *reset* to a "1" from time 0 ns to 40 ns. At 40 ns, *reset* is forced to a "0", 2 ms after the second signal\_force call was executed.

If you want to skip parameters so that you can specify subsequent parameters, you need to use the keyword "open" as a placeholder for the skipped parameter(s). The first signal\_force procedure illustrates this, where an "open" for the cancel\_period parameter means that the default value of -1 ms is used.

## signal\_release

The signal\_release() procedure releases any force that was applied to an existing VHDL signal or Verilog register/net (called the dest\_object). This allows you to release signals, registers or nets at any level of the design hierarchy from within a VHDL architecture (e.g., a testbench).

A signal\_release works the same as the **noforce** command (CR-110). Signal\_release can be called concurrently or sequentially in a process.

### Syntax

```
signal_release( dest_object, verbose )
```

### Returns

Nothing

### Arguments

| Name        | Type    | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string  | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |
| verbose     | integer | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the signal is being released and the time of the release. Default is 0, no message.                                                                                                                           |

### Related functions

[init\\_signal\\_driver](#) (UM-295), [init\\_signal\\_spy](#) (UM-298), [signal\\_force](#) (UM-300)

### Limitations

- You cannot release a bit or slice of a register; you can release only the entire register.

## Example

```
library IEEE, modelsim_lib;
use IEEE.std_logic_1164.all;
use modelsim_lib.util.all;

entity testbench is
end;

architecture only of testbench is

signal release_flag : std_logic;

begin

stim_design : process
begin
...
wait until release_flag = '1';
signal_release("/testbench/dut/blk1/data", 1);
signal_release("/testbench/dut/blk1/clk", 1);
...
end process stim_design;

...
end;
```

The above example releases any forces on the signals *data* and *clk* when the signal *release\_flag* is a "1". Both calls will send a message to the transcript stating which signal was released and when.

## \$init\_signal\_driver

The \$init\_signal\_driver() system task drives the value of a VHDL signal or Verilog net (called the src\_object) onto an existing VHDL signal or Verilog register/net (called the dest\_object). This allows you to drive signals or nets at any level of the design hierarchy from within a Verilog module (e.g., a testbench).

The \$init\_signal\_driver system task drives the value onto the destination signal just as if the signals were directly connected in the HDL code. Any existing or subsequent drive or force of the destination signal, by some other means, will be considered with the \$init\_signal\_driver value in the resolution of the signal.

### Call only once

The \$init\_signal\_driver system task creates a persistent relationship between the source and destination signals. Hence, you need to call \$init\_signal\_driver only once for a particular pair of signals. Once \$init\_signal\_driver is called, any change on the source signal will be driven on the destination signal until the end of the simulation.

Thus, we recommend that you place all \$init\_signal\_driver calls in a Verilog initial block. See the example below.

### Syntax

```
$init_signal_driver(src_object, dest_object, delay, delay_type, verbose)
```

### Returns

Nothing

### Arguments

| Name        | Type   | Description                                                                                                                                                                                                                                                                                                             |
|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| src_object  | string | Required. A full hierarchical path (or relative path with reference to the calling block) to a VHDL signal or Verilog net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes.           |
| dest_object | string | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |

| Name       | Type                   | Description                                                                                                                                                                                   |
|------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| delay      | integer, real, or time | Optional. Specifies a delay relative to the time at which the src_object changes. The delay can be an inertial or transport delay. If no delay is specified, then a delay of zero is assumed. |
| delay_type | integer                | Optional. Specifies the type of delay that will be applied. The value must be either 0 (inertial) or 1 (transport). The default is 0.                                                         |
| verbose    | integer                | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the src_object is driving the dest_object. Default is 0, no message.       |

## Related procedures

[\\$init\\_signal\\_spy](#) (UM-307), [\\$signal\\_force](#) (UM-309), [\\$signal\\_release](#) (UM-311)

## Limitations

- When driving a Verilog net, the only *delay\_type* allowed is inertial. If you set the delay type to 1 (transport), the setting will be ignored, and the delay type will be inertial.
- Any delays that are set to a value less than the simulator resolution will be rounded to the nearest resolution unit; no special warning will be issued.
- Verilog memories (arrays of registers) are not supported.

## Example

```
'timescale 1 ps / 1 ps

module testbench;

reg clk0;

initial begin
    clk0 = 1;
    forever begin
        #20 clk0 = ~clk0;
    end
end

initial begin
    $init_signal_driver("clk0", "/testbench/uut/blk1/clk", , , 1);
    $init_signal_driver("clk0", "/testbench/uut/blk2/clk", 100, 1);
end

...
endmodule
```

The above example creates a local clock (*clk0*) and connects it to two clocks within the design hierarchy. The .../blk1/clk will match local *clk0* and a message will be displayed. The .../blk2/clk will match the local *clk0* but be delayed by 100 ps. For the second call to work, the .../blk2/clk must be a VHDL based signal, because if it were a Verilog net a 100 ps inertial delay would consume the 40 ps clock period. Verilog nets are limited to only inertial delays and thus the setting of 1 (transport delay) would be ignored.

## \$init\_signal\_spy

The \$init\_signal\_spy() system task mirrors the value of a VHDL signal or Verilog register/net (called the `src_object`) onto an existing VHDL signal or Verilog register/net (called the `dest_object`). This allows you to reference signals, registers, or nets at any level of hierarchy from within a Verilog module (e.g., a testbench).

The \$init\_signal\_spy system task only sets the value onto the destination signal and does not drive or force the value. Any existing or subsequent drive or force of the destination signal, by some other means, will override the value set by \$init\_signal\_spy.

### Call only once

The \$init\_signal\_spy system task creates a persistent relationship between the source and the destination signal. Hence, you need to call \$init\_signal\_spy only once for a particular pair of signals. Once \$init\_signal\_spy is called, any change on the source signal will mirror on the destination signal until the end of the simulation. Thus, we recommend that you place all \$init\_signal\_spy calls in a Verilog initial block. See the example below.

### Syntax

```
$init_signal_spy(src_object, dest_object, verbose)
```

### Returns

Nothing

### Arguments

| Name                    | Type   | Description                                                                                                                                                                                                                                                                                                            |
|-------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>src_object</code> | string | Required. A full hierarchical path (or relative path with reference to the calling block) to a VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |

| Name        | Type    | Description                                                                                                                                                                                                                                                                                                        |
|-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string  | Required. A full hierarchical path (or relative path with reference to the calling block) to a Verilog register or VHDL signal. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |
| verbose     | integer | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the src_object's value is mirrored onto the dest_object. Default is 0, no message.                                                                                                              |

## Related tasks

[\\$init\\_signal\\_driver](#) (UM-304), [\\$signal\\_force](#) (UM-309), [\\$signal\\_release](#) (UM-311)

## Limitations

- When mirroring the value of a VHDL signal onto a Verilog register, the VHDL signal must be of type bit, bit\_vector, std\_logic, or std\_logic\_vector.
- Verilog memories (arrays of registers) are not supported.

## Example

```
module testbench;
...
reg top_sig1;
...
initial
begin
    $init_signal_spy("/top/uut/inst1/sig1","/top_sig1", 1);
end
...
endmodule
```

In this example, the value of `/top/uut/inst1/sig1` will be mirrored onto `/top_sig1`.

## \$signal\_force

The \$signal\_force() system task forces the value specified onto an existing VHDL signal or Verilog register/net (called the dest\_object). This allows you to force signals, registers, or nets at any level of the design hierarchy from within a Verilog module (e.g., a testbench).

A \$signal\_force works the same as the **force** command (CR-90) with the exception that you cannot issue a repeating force. The force will remain on the signal until a \$signal\_release, a force or release command, or a subsequent \$signal\_force is issued. \$signal\_force can be called concurrently or sequentially in a process.

### Syntax

```
$signal_force( dest_object, value, rel_time, force_type, cancel_period,
    verbose )
```

### Returns

Nothing

### Arguments

| Name        | Type                   | Description                                                                                                                                                                                                                                                                                                                          |
|-------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string                 | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes.     |
| value       | string                 | Required. Specifies the value to which the dest_object is to be forced. The specified value must be appropriate for the type.                                                                                                                                                                                                        |
| rel_time    | integer, real, or time | Optional. Specifies a time relative to the current simulation time for the force to occur. The default is 0.                                                                                                                                                                                                                         |
| force_type  | integer                | Optional. Specifies the type of force that will be applied. The value must be one of the following; 0 (default), 1 (deposit), 2 (drive), or 3 (freeze). The default is "default" (which is "freeze" for unresolved objects or "drive" for resolved objects). See the <b>force</b> command (CR-90) for further details on force type. |

| Name          | Type                | Description                                                                                                                                                                                                                                                                                                        |
|---------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| cancel_period | integer, real, time | Optional. Cancels the \$signal_force command after the specified period of time units. Cancellation occurs at the last simulation delta cycle of a time unit. A value of zero cancels the force at the end of the current time period. Default is -1. A negative value means that the force will not be cancelled. |
| verbose       | integer             | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the value is being forced on the dest_object at the specified time. Default is 0, no message.                                                                                                   |

## Related functions

[\\$init\\_signal\\_driver](#) (UM-304), [\\$init\\_signal\\_spy](#) (UM-307), [\\$signal\\_release](#) (UM-311)

## Limitations

- You cannot force bits or slices of a register; you can force only the entire register.
- Verilog memories (arrays of registers) are not supported.

## Example

```

`timescale 1 ns / 1 ns

module testbench;

initial
begin
    $signal_force("/testbench/uut/b1k1/reset", "1", 0, 3, , 1);
    $signal_force("/testbench/uut/b1k1/reset", "0", 40, 3, 200000, 1);
end

...
endmodule

```

The above example forces *reset* to a "1" from time 0 ns to 40 ns. At 40 ns, *reset* is forced to a "0", 200000 ns after the second \$signal\_force call was executed.

## \$signal\_release

The \$signal\_release() system task releases any force that was applied to an existing VHDL signal or Verilog register/net (called the dest\_object). This allows you to release signals, registers, or nets at any level of the design hierarchy from within a Verilog module (e.g., a testbench).

A \$signal\_release works the same as the [noforce](#) command (CR-110). \$signal\_release can be called concurrently or sequentially in a process.

### Syntax

```
$signal_release( dest_object, verbose )
```

### Returns

Nothing

### Arguments

| Name        | Type    | Description                                                                                                                                                                                                                                                                                                                      |
|-------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dest_object | string  | Required. A full hierarchical path (or relative path with reference to the calling block) to an existing VHDL signal or Verilog register/net. Use the path separator to which your simulation is set (i.e., "/" or "."). A full hierarchical path must begin with a "/" or ".". The path must be contained within double quotes. |
| verbose     | integer | Optional. Possible values are 0 or 1. Specifies whether you want a message reported in the Transcript stating that the signal is being released and the time of the release. Default is 0, no message.                                                                                                                           |

### Related functions

[\\$init\\_signal\\_driver](#) (UM-304), [\\$init\\_signal\\_spy](#) (UM-307), [\\$signal\\_force](#) (UM-309)

### Limitations

- You cannot release a bit or slice of a register; you can release only the entire register.

## Example

```
module testbench;  
  
    reg release_flag;  
  
    always @(posedge release_flag) begin  
        $signal_release("/testbench/dut/blk1/data", 1);  
        $signal_release("/testbench/dut/blk1/clk", 1);  
    end  
  
    ...  
  
endmodule
```

The above example releases any forces on the signals *data* and *clk* when the register *release\_flag* transitions to a "1". Both calls will send a message to the transcript stating which signal was released and when.

# 10 - Standard Delay Format (SDF) Timing Annotation

---

## Chapter contents

|                                                                      |        |
|----------------------------------------------------------------------|--------|
| Specifying SDF files for simulation . . . . .                        | UM-314 |
| Instance specification . . . . .                                     | UM-314 |
| SDF specification with the GUI . . . . .                             | UM-315 |
| Errors and warnings . . . . .                                        | UM-315 |
| VHDL VITAL SDF . . . . .                                             | UM-316 |
| SDF to VHDL generic matching . . . . .                               | UM-316 |
| Resolving errors . . . . .                                           | UM-317 |
| Verilog SDF . . . . .                                                | UM-318 |
| The \$sdf_annotate system task . . . . .                             | UM-318 |
| SDF to Verilog construct matching . . . . .                          | UM-319 |
| Optional edge specifications . . . . .                               | UM-322 |
| Optional conditions . . . . .                                        | UM-323 |
| Rounded timing values . . . . .                                      | UM-323 |
| Interconnect delays . . . . .                                        | UM-325 |
| Disabling timing checks . . . . .                                    | UM-325 |
| Troubleshooting . . . . .                                            | UM-326 |
| Specifying the wrong instance . . . . .                              | UM-326 |
| Mistaking a component or module name for an instance label . . . . . | UM-327 |
| Forgetting to specify the instance . . . . .                         | UM-327 |

This chapter discusses ModelSim's implementation of SDF (Standard Delay Format) timing annotation. Included are sections on VITAL SDF and Verilog SDF, plus troubleshooting.

Verilog and VHDL VITAL timing data can be annotated from SDF files by using the simulator's built-in SDF annotator.

### ***SDF and ModelSim***

SDF timing annotations can be applied only to your FPGA vendor's libraries; all other libraries will simulate without annotation.

## Specifying SDF files for simulation

ModelSim supports SDF versions 1.0 through 3.0. The simulator's built-in SDF annotator automatically adjusts to the version of the file. Use the following **vsim** (CR-213) command-line options to specify the SDF files, the desired timing values, and their associated design instances:

```
-sdfmin [<instance>=<filename>
-sdftyp [<instance>=<filename>
-sdfmax [<instance>=<filename>
```

Any number of SDF files can be applied to any instance in the design by specifying one of the above options for each file. Use **-sdfmin** to select minimum, **-sdftyp** to select typical, and **-sdfmax** to select maximum timing values from the SDF file.

### Instance specification

The instance paths in the SDF file are relative to the instance to which the SDF is applied. Usually, this instance is an ASIC or FPGA model instantiated under a testbench. For example, to annotate maximum timing values from the SDF file *myasic.sdf* to an instance *u1* under a top-level named *testbench*, invoke the simulator as follows:

```
vsim -sdfmax /testbench/u1=myasic.sdf testbench
```

If the instance name is omitted then the SDF file is applied to the top-level. *This is usually incorrect* because in most cases the model is instantiated under a testbench or within a larger system level simulation. In fact, the design can have several models, each having its own SDF file. In this case, specify an SDF file for each instance. For example,

```
vsim -sdfmax /system/u1=asic1.sdf -sdfmax /system/u2=asic2.sdf system
```

## SDF specification with the GUI

As an alternative to the command-line options, you can specify SDF files in the **Simulate** dialog box under the SDF tab.



You can access this dialog by invoking the simulator without any arguments or by selecting **Simulate > Simulate** (Main window). See the GUI chapter for a description of this dialog.

For Verilog designs, you can also specify SDF files by using the **\$sdf\_annotation** system task. See "[The \\$sdf\\_annotation system task](#)" (UM-318) for more details.

## Errors and warnings

Errors issued by the SDF annotator while loading the design prevent the simulation from continuing, whereas warnings do not. Use the **-sdfnoerror** option with **vsim** (CR-213) to change SDF errors to warnings so that the simulation can continue. Warning messages can be suppressed by using **vsim** with either the **-sdfnowarn** or **+nosdfwarn** options.

Another option is to use the **SDF** tab from the **Simulate** dialog box (shown above). Select **Disable SDF warnings** (**-sdfnowarn +nosdfwarn**) to disable warnings, or select **Reduce SDF errors to warnings** (**-sdfnoerror**) to change errors to warnings.

See "[Troubleshooting](#)" (UM-326) for more information on errors and warnings and how to avoid them.

## VHDL VITAL SDF

VHDL SDF annotation works on VITAL cells only. The IEEE 1076.4 VITAL ASIC Modeling Specification describes how cells must be written to support SDF annotation. Once again, the designer does not need to know the details of this specification because the library provider has already written the VITAL cells and tools that create compatible SDF files. However, the following summary may help you understand simulator error messages. For additional VITAL specification information, see "["VITAL specification and source code"](#) (UM-71).

### SDF to VHDL generic matching

An SDF file contains delay and timing constraint data for cell instances in the design. The annotator must locate the cell instances and the placeholders (VHDL generics) for the timing data. Each type of SDF timing construct is mapped to the name of a generic as specified by the VITAL modeling specification. The annotator locates the generic and updates it with the timing value from the SDF file. It is an error if the annotator fails to find the cell instance or the named generic. The following are examples of SDF constructs and their associated generic names:

| SDF construct                        | Matching VHDL generic name  |
|--------------------------------------|-----------------------------|
| (IOPATH a y (3))                     | tpd_a_y                     |
| (IOPATH (posedge clk) q (1) (2))     | tpd_clk_q_posedge           |
| (INTERCONNECT u1/y u2/a (5))         | tipd_a                      |
| (SETUP d (posedge clk) (5))          | tsetup_d_clk_noedge_posedge |
| (HOLD (negedge d) (posedge clk) (5)) | thold_d_clk_negedge_posedge |
| (SETUPHOLD d clk (5) (5))            | tsetup_d_clk & thold_d_clk  |
| (WIDTH (COND (reset==1'b0) clk) (5)) | tpw_clk_reset_eq_0          |

## Resolving errors

If the simulator finds the cell instance but not the generic then an error message is issued. For example,

```
** Error (vsim-SDF-3240) myasic.sdf(18):
Instance '/testbench/dut/u1' does not have a generic named 'tpd_a_y'
```

In this case, make sure that the design is using the appropriate VITAL library cells. If it is, then there is probably a mismatch between the SDF and the VITAL cells. You need to find the cell instance and compare its generic names to those expected by the annotator. Look in the VHDL source files provided by the cell library vendor.

If none of the generic names look like VITAL timing generic names, then perhaps the VITAL library cells are not being used. If the generic names do look like VITAL timing generic names but don't match the names expected by the annotator, then there are several possibilities:

- The vendor's tools are not conforming to the VITAL specification.
- The SDF file was accidentally applied to the wrong instance. In this case, the simulator also issues other error messages indicating that cell instances in the SDF could not be located in the design.
- The vendor's library and SDF were developed for the older VITAL 2.2b specification. This version uses different name mapping rules. In this case, invoke **vsim** (CR-213) with the **-vital2.2b** option:

```
vsim -vital2.2b -sdfmax /testbench/u1=myasic.sdf testbench
```

For more information on resolving errors see "["Troubleshooting"](#)" (UM-326).

## Verilog SDF

Verilog designs can be annotated using either the simulator command-line options or the **\$sdf\_annotation** system task (also commonly used in other Verilog simulators). The command-line options annotate the design immediately after it is loaded, but before any simulation events take place. The **\$sdf\_annotation** task annotates the design at the time it is called in the Verilog source code. This provides more flexibility than the command-line options.

### The **\$sdf\_annotation** system task

The syntax for **\$sdf\_annotation** is:

#### **Syntax**

```
$sdf_annotation
([ "<sdffile>" ], [<instance>], ["<config_file>"], ["<log_file>"],
["<mtm_spec>"], ["<scale_factor>"], ["<scale_type>"]);
```

#### **Arguments**

"<sdffile>"

String that specifies the SDF file. Required.

<instance>

Hierarchical name of the instance to be annotated. Optional. Defaults to the instance where the **\$sdf\_annotation** call is made.

"<config\_file>"

String that specifies the configuration file. Optional. Currently not supported, this argument is ignored.

"<log\_file>"

String that specifies the logfile. Optional. Currently not supported, this argument is ignored.

"<mtm\_spec>"

String that specifies the delay selection. Optional. The allowed strings are "minimum", "typical", "maximum", and "tool\_control". Case is ignored and the default is "tool\_control". The "tool\_control" argument means to use the delay specified on the command line by +mindelays, +typdelays, or +maxdelays (defaults to +typdelays).

"<scale\_factor>"

String that specifies delay scaling factors. Optional. The format is "<min\_mult>:<typ\_mult>:<max\_mult>". Each multiplier is a real number that is used to scale the corresponding delay in the SDF file.

"<scale\_type>"

String that overrides the <mtm\_spec> delay selection. Optional. The <mtm\_spec> delay selection is always used to select the delay scaling factor, but if a <scale\_type> is specified, then it will determine the min/typ/max selection from the SDF file. The allowed strings are "from\_min", "from\_minimum", "from\_typ", "from\_typical", "from\_max", "from\_maximum", and "from\_mtm". Case is ignored, and the default is "from\_mtm", which means to use the <mtm\_spec> value.

### **Examples**

Optional arguments can be omitted by using commas or by leaving them out if they are at the end of the argument list. For example, to specify only the SDF file and the instance to which it applies:

```
$sdf_annotate("myasic.sdf", testbench.u1);
```

To also specify maximum delay values:

```
$sdf_annotate("myasic.sdf", testbench.u1, , , "maximum");
```

## **SDF to Verilog construct matching**

The annotator matches SDF constructs to corresponding Verilog constructs in the cells. Usually, the cells contain path delays and timing checks within specify blocks. For each SDF construct, the annotator locates the cell instance and updates each specify path delay or timing check that matches. An SDF construct can have multiple matches, in which case each matching specify statement is updated with the SDF timing value. SDF constructs are matched to Verilog constructs as follows:

**IOPATH** is matched to specify path delays or primitives:

| <b>SDF</b>                       | <b>Verilog</b>          |
|----------------------------------|-------------------------|
| (IOPATH (posedge clk) q (3) (4)) | (posedge clk => q) = 0; |
| (IOPATH a y (3) (4))             | buf u1 (y, a);          |

The IOPATH construct usually annotates path delays. If the module contains no path delays, then all primitives that drive the specified output port are annotated.

**INTERCONNECT** and **PORT** are matched to input ports:

| <b>SDF</b>                   | <b>Verilog</b> |
|------------------------------|----------------|
| (INTERCONNECT u1.y u2.a (5)) | input a;       |
| (PORT u2.a (5))              | inout a;       |

Both of these constructs identify a module input or inout port and create an internal net that is a delayed version of the port. This is called a Module Input Port Delay (MIPD). All primitives, specify path delays, and specify timing checks connected to the original port are reconnected to the new MIPD net.

**PATHPULSE** and **GLOBALPATHPULSE** are matched to specify path delays:

| <b>SDF</b>                      | <b>Verilog</b> |
|---------------------------------|----------------|
| (PATHPULSE a y (5) (10))        | (a => y) = 0;  |
| (GLOBALPATHPULSE a y (30) (60)) | (a => y) = 0;  |

If the input and output ports are omitted in the SDF, then all path delays are matched in the cell.

**DEVICE** is matched to primitives or specify path delays:

| SDF            | Verilog                     |
|----------------|-----------------------------|
| (DEVICE y (5)) | and u1(y, a, b);            |
| (DEVICE y (5)) | (a => y) = 0; (b => y) = 0; |

If the SDF cell instance is a primitive instance, then that primitive's delay is annotated. If it is a module instance, then all specify path delays are annotated that drive the output port specified in the DEVICE construct (all path delays are annotated if the output port is omitted). If the module contains no path delays, then all primitives that drive the specified output port are annotated (or all primitives that drive any output port if the output port is omitted).

**SETUP** is matched to \$setup and \$setuphold:

| SDF                         | Verilog                            |
|-----------------------------|------------------------------------|
| (SETUP d (posedge clk) (5)) | \$setup(d, posedge clk, 0);        |
| (SETUP d (posedge clk) (5)) | \$setuphold(posedge clk, d, 0, 0); |

**HOLD** is matched to \$hold and \$setuphold:

| SDF                        | Verilog                            |
|----------------------------|------------------------------------|
| (HOLD d (posedge clk) (5)) | \$hold(posedge clk, d, 0);         |
| (HOLD d (posedge clk) (5)) | \$setuphold(posedge clk, d, 0, 0); |

**SETUPHOLD** is matched to \$setup, \$hold, and \$setuphold:

| SDF                                 | Verilog                            |
|-------------------------------------|------------------------------------|
| (SETUPHOLD d (posedge clk) (5) (5)) | \$setup(d, posedge clk, 0);        |
| (SETUPHOLD d (posedge clk) (5) (5)) | \$hold(posedge clk, d, 0);         |
| (SETUPHOLD d (posedge clk) (5) (5)) | \$setuphold(posedge clk, d, 0, 0); |

**RECOVERY** is matched to \$recovery:

| SDF                                          | Verilog                                    |
|----------------------------------------------|--------------------------------------------|
| (RECOVERY (negedge reset) (posedge clk) (5)) | \$recovery(negedge reset, posedge clk, 0); |

**REMOVAL** is matched to \$removal:

| SDF                                         | Verilog                                   |
|---------------------------------------------|-------------------------------------------|
| (REMOVAL (negedge reset) (posedge clk) (5)) | \$removal(negedge reset, posedge clk, 0); |

**RECREM** is matched to \$recovery, \$removal, and \$recrem:

| SDF                                            | Verilog                                    |
|------------------------------------------------|--------------------------------------------|
| (RECREM (negedge reset) (posedge clk) (5) (5)) | \$recovery(negedge reset, posedge clk, 0); |
| (RECREM (negedge reset) (posedge clk) (5) (5)) | \$removal(negedge reset, posedge clk, 0);  |
| (RECREM (negedge reset) (posedge clk) (5) (5)) | \$recrem(negedge reset, posedge clk, 0);   |

**SKEW** is matched to \$skew:

| SDF                                      | Verilog                                |
|------------------------------------------|----------------------------------------|
| (SKEW (posedge clk1) (posedge clk2) (5)) | \$skew(posedge clk1, posedge clk2, 0); |

**WIDTH** is matched to \$width:

| SDF                       | Verilog                  |
|---------------------------|--------------------------|
| (WIDTH (posedge clk) (5)) | \$width(posedge clk, 0); |

**PERIOD** is matched to \$period:

| SDF                        | Verilog                   |
|----------------------------|---------------------------|
| (PERIOD (posedge clk) (5)) | \$period(posedge clk, 0); |

**NOCHANGE** is matched to \$nochange:

| SDF                                     | Verilog                                |
|-----------------------------------------|----------------------------------------|
| (NOCHANGE (negedge write) addr (5) (5)) | \$nochange(negedge write, addr, 0, 0); |

## Optional edge specifications

Timing check ports and path delay input ports can have optional edge specifications. The annotator uses the following rules to match edges:

- A match occurs if the SDF port does not have an edge.
- A match occurs if the specify port does not have an edge.
- A match occurs if the SDF port edge is identical to the specify port edge.
- A match occurs if explicit edge transitions in the specify port edge overlap with the SDF port edge.

These rules allow SDF annotation to take place even if there is a difference between the number of edge-specific constructs in the SDF file and the Verilog specify block. For example, the Verilog specify block may contain separate setup timing checks for a falling and rising edge on data with respect to clock, while the SDF file may contain only a single setup check for both edges:

| SDF                              | Verilog                                |
|----------------------------------|----------------------------------------|
| (SETUP data (posedge clock) (5)) | \$setup(posedge data, posedge clk, 0); |
| (SETUP data (posedge clock) (5)) | \$setup(negedge data, posedge clk, 0); |

In this case, the cell accommodates more accurate data than can be supplied by the tool that created the SDF file, and both timing checks correctly receive the same value.

Likewise, the SDF file may contain more accurate data than the model can accommodate.

| SDF                                        | Verilog                        |
|--------------------------------------------|--------------------------------|
| (SETUP (posedge data) (posedge clock) (4)) | \$setup(data, posedge clk, 0); |
| (SETUP (negedge data) (posedge clock) (6)) | \$setup(data, posedge clk, 0); |

In this case, both SDF constructs are matched and the timing check receives the value from the last one encountered.

Timing check edge specifiers can also use explicit edge transitions instead of posedge and negedge. However, the SDF file is limited to posedge and negedge. For example,

| SDF                              | Verilog                             |
|----------------------------------|-------------------------------------|
| (SETUP data (posedge clock) (5)) | \$setup(data, edge[01, 0x] clk, 0); |

The explicit edge specifiers are 01, 0x, 10, 1x, x0, and x1. The set of [01, 0x, x1] is equivalent to posedge, while the set of [10, 1x, x0] is equivalent to negedge. A match occurs if any of the explicit edges in the specify port match any of the explicit edges implied by the SDF port.

## Optional conditions

Timing check ports and path delays can have optional conditions. The annotator uses the following rules to match conditions:

- A match occurs if the SDF does not have a condition.
- A match occurs for a timing check if the SDF port condition is semantically equivalent to the specify port condition.
- A match occurs for a path delay if the SDF condition is lexically identical to the specify condition.

Timing check conditions are limited to very simple conditions, therefore the annotator can match the expressions based on semantics. For example,

| SDF                                                | Verilog                                      |
|----------------------------------------------------|----------------------------------------------|
| (SETUP data (COND (reset!=1) (posedge clock)) (5)) | \$setup(data, posedge clk && (reset==0), 0); |

The conditions are semantically equivalent and a match occurs. In contrast, path delay conditions may be complicated and semantically equivalent conditions may not match. For example,

| SDF                                  | Verilog                                         |
|--------------------------------------|-------------------------------------------------|
| (COND (r1    r2) (IOPATH clk q (5))) | if (r1    r2) (clk => q) = 5; // matches        |
| (COND (r1    r2) (IOPATH clk q (5))) | if (r2    r1) (clk => q) = 5; // does not match |

The annotator does not match the second condition above because the order of r1 and r2 are reversed.

## Rounded timing values

The SDF **TIMESCALE** construct specifies time units of values in the SDF file. The annotator rounds timing values from the SDF file to the time precision of the module that is annotated. For example, if the SDF TIMESCALE is 1ns and a value of .016 is annotated to a path delay in a module having a time precision of 10ps (from the timescale directive), then the path delay receives a value of 20ps. The SDF value of 16ps is rounded to 20ps. Interconnect delays are rounded to the time precision of the module that contains the annotated MIPD.

## SDF for mixed VHDL and Verilog designs

Annotation of a mixed VHDL and Verilog design is very flexible. VHDL VITAL cells and Verilog cells can be annotated from the same SDF file. This flexibility is available only by using the simulator's SDF command-line options. The Verilog `$sdf_annotate` system task can annotate Verilog cells only. See the [vsim](#) command (CR-213) for more information on SDF command-line options.

## Interconnect delays

An interconnect delay represents the delay from the output of one device to the input of another. ModelSim can model single interconnect delays or multisource interconnect delays for Verilog, VHDL/VITAL, or mixed designs. See the **vsim** command for more information on the relevant command-line arguments.

Timing checks are performed on the interconnect delayed versions of input ports. This may result in misleading timing constraint violations, because the ports may satisfy the constraint while the delayed versions may not. If the simulator seems to report incorrect violations, be sure to account for the effect of interconnect delays.

## Disabling timing checks

ModelSim offers a number of options for disabling timing checks on a "global" or individual basis. The table below provides a summary of those options. See the command and argument descriptions in the *ModelSim Command Reference* for more details.

| Command and argument        | Effect                                                                                                                                   |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>vlog +notimingchecks</b> | disables timing check system tasks for all instances in the specified Verilog design                                                     |
| <b>vlog +nospecify</b>      | disables specify path delays and timing checks for all instances in the specified Verilog design                                         |
| <b>vsim +no_neg_tchk</b>    | disables negative timing check limits by setting them to zero for all instances in the specified design                                  |
| <b>vsim +no_notifier</b>    | disables the toggling of the notifier register argument of the timing check system tasks for all instances in the specified design       |
| <b>vsim +no_tchk_msg</b>    | disables error messages issued by timing check system tasks when timing check violations occur for all instances in the specified design |
| <b>vsim +notimingchecks</b> | disables Verilog and VITAL timing checks for all instances in the specified design                                                       |

# Troubleshooting

## Specifying the wrong instance

By far, the most common mistake in SDF annotation is to specify the wrong instance to the simulator's SDF options. The most common case is to leave off the instance altogether, which is the same as selecting the top-level design unit. This is generally wrong because the instance paths in the SDF are relative to the ASIC or FPGA model, which is usually instantiated under a top-level testbench. See "[Instance specification](#)" (UM-314) for an example.

A common example for both VHDL and Verilog testbenches is provided below. For simplicity, the test benches do nothing more than instantiate a model that has no ports.

### VHDL testbench

```
entity testbench is end;

architecture only of testbench is
    component myasic
        end component;
begin
    dut : myasic;
end;
```

### Verilog testbench

```
module testbench;
    myasic dut();
endmodule
```

The name of the model is *myasic* and the instance label is *dut*. For either testbench, an appropriate simulator invocation might be:

```
vsim -sdfmax /testbench/dut=myasic.sdf testbench
```

Optionally, you can leave off the name of the top-level:

```
vsim -sdfmax /dut=myasic.sdf testbench
```

The important thing is to select the instance for which the SDF is intended. If the model is deep within the design hierarchy, an easy way to find the instance name is to first invoke the simulator without SDF options, open the structure window, navigate to the model instance, select it, and enter the **environment** command (CR-81). This command displays the instance name that should be used in the SDF command-line option.

## Mistaking a component or module name for an instance label

Another common error is to specify the component or module name rather than the instance label. For example, the following invocation is wrong for the above testbenches:

```
vsim -sdfmax /testbench/myasic=myasic.sdf testbench
```

This results in the following error message:

```
** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/myasic'.
```

## Forgetting to specify the instance

If you leave off the instance altogether, then the simulator issues a message for each instance path in the SDF that is not found in the design. For example,

```
vsim -sdfmax myasic.sdf testbench
```

Results in:

```
** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/u1'

** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/u2'

** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/u3'

** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/u4'

** Error (vsim-SDF-3250) myasic.sdf(0):
Failed to find INSTANCE '/testbench/u5'

** Warning (vsim-SDF-3432) myasic.sdf:
This file is probably applied to the wrong instance.

** Warning (vsim-SDF-3432) myasic.sdf:
Ignoring subsequent missing instances from this file.
```

After annotation is done, the simulator issues a summary of how many instances were not found and possibly a suggestion for a qualifying instance:

```
** Warning (vsim-SDF-3440) myasic.sdf:
Failed to find any of the 358 instances from this file.

** Warning (vsim-SDF-3442) myasic.sdf:
Try instance '/testbench/dut'. It contains all instance paths from this
file.
```

The simulator recommends an instance only if the file was applied to the top-level and a qualifying instance is found one level down.

Also see "[Resolving errors](#)" (UM-317) for specific VHDL VITAL SDF troubleshooting.



# 11 - Value Change Dump (VCD) Files

---

## Chapter contents

|                                                                        |        |
|------------------------------------------------------------------------|--------|
| <a href="#">Creating a VCD file</a>                                    | UM-330 |
| <a href="#">Flow for four-state VCD file</a>                           | UM-330 |
| <a href="#">Flow for extended VCD file</a>                             | UM-330 |
| <a href="#">Case sensitivity</a>                                       | UM-330 |
| <a href="#">Using extended VCD as stimulus</a>                         | UM-331 |
| <a href="#">Simulating with input values from a VCD file</a>           | UM-331 |
| <a href="#">Replacing instances with output values from a VCD file</a> | UM-332 |
| <a href="#">ModelSim VCD commands and VCD tasks</a>                    | UM-334 |
| <a href="#">Compressing files with VCD tasks</a>                       | UM-335 |
| <a href="#">A VCD file from source to output</a>                       | UM-336 |
| <a href="#">VHDL source code</a>                                       | UM-336 |
| <a href="#">VCD simulator commands</a>                                 | UM-336 |
| <a href="#">VCD output</a>                                             | UM-337 |
| <a href="#">Capturing port driver data</a>                             | UM-340 |
| <a href="#">Supported TSSI states</a>                                  | UM-340 |
| <a href="#">Strength values</a>                                        | UM-341 |
| <a href="#">Port identifier code</a>                                   | UM-341 |
| <a href="#">Example VCD output from vcd dumpports</a>                  | UM-342 |

This chapter describes how to use VCD files in ModelSim. The VCD file format is specified in the IEEE 1364 standard. It is an ASCII file containing header information, variable definitions, and variable value changes. VCD is in common use for Verilog designs, and is controlled by VCD system task calls in the Verilog source code. ModelSim provides command equivalents for these system tasks and extends VCD support to VHDL designs. The ModelSim commands can be used on VHDL, Verilog, or mixed designs.

If you need vendor-specific ASIC design-flow documentation that incorporates VCD, please contact your ASIC vendor.

## Creating a VCD file

There are two flows in ModelSim for creating a VCD file. One flow produces a four-state VCD file with variable changes in 0, 1, x, and z with no strength information; the other produces an extended VCD file with variable changes in all states and strength information and port driver data.

Both flows will also capture port driver changes unless filtered out with optional command-line arguments.

### Flow for four-state VCD file

First, compile and load the design:

```
% cd ~/modeltech/examples
% vlib work
% vlog counter.v tcounter.v
% vsim test_counter
```

Next, with the design loaded, specify the VCD file name with the **vcd file** command (CR-159) and add items to the file with the **vcd add** command (CR-149):

```
VSIM 1> vcd file myvcdfile.vcd
VSIM 2> vcd add /test_counter/dut/*
VSIM 3> run
VSIM 4> quit -f
```

There will now be a VCD file in the working directory.

### Flow for extended VCD file

First, compile and load the design:

```
% cd ~/modeltech/examples
% vlib work
% vlog counter.v tcounter.v
% vsim test_counter
```

Next, with the design loaded, specify the VCD file name and items to add with the **vcd dumpports** command (CR-152):

```
VSIM 1> vcd dumpports -file myvcdfile.vcd /test_counter/dut/*
VSIM 3> run
VSIM 4> quit -f
```

There will now be an extended VCD file in the working directory.

### Case sensitivity

VHDL is not case sensitive so ModelSim converts all signal names to lower case when it produces a VCD file. Conversely, Verilog designs are case sensitive so ModelSim maintains case when it produces a VCD file.

# Using extended VCD as stimulus

You can use an extended VCD file as stimulus to re-simulate your design. There are two ways to do this: 1) simulate the top level of a design unit with the input values from an extended VCD file; and 2) specify one or more instances in a design to be replaced with the output values from the associated VCD file.

## Simulating with input values from a VCD file

When simulating with inputs from an extended VCD file, you can simulate only one design unit at a time. In other words, you can apply the VCD file inputs only to the top level of the design unit for which you captured port data.

The general procedure includes two steps:

- 1 Create a VCD file for a single design unit using the **vcddumpports** command (CR-152).
- 2 Resimulate the single design unit using the **-vcdstim** argument to **vsim** (CR-213). Note that **-vcdstim** works only with VCD files that were created by a ModelSim simulation.

### *Example 1 — Verilog counter*

First, create the VCD file for the single instance using **vcddumpports**:

```
% cd ~/modeltech/examples
% vlib work
% vlog counter.v tcounter.v
% vsim test_counter
VSIM 1> vcd dumpports -file counter.vcd /test_counter/dut/*
VSIM 2> run
VSIM 3> quit -f
```

Next, rerun the counter without the testbench, using the **-vcdstim** argument:

```
% vsim -vcdstim counter.vcd counter
VSIM 1> add wave /*
VSIM 2> run 200
```

### *Example 2 — VHDL adder*

First, create the VCD file using **vcddumpports**:

```
% cd ~/modeltech/examples
% vlib work
% vcom gates.vhd adder.vhd stimulus.vhd
% vsim testbench2
VSIM 1> vcd dumpports -file addern.vcd /testbench2/uut/*
VSIM 2> run 1000
VSIM 3> quit -f
```

Next, rerun the adder without the testbench, using the **-vcdstim** argument:

```
% vsim -vcdstim addern.vcd addern -gn=8 -do "add wave /*; run 1000"
```

***Example 3 — Mixed-HDL design***

First, create three VCD files, one for each module:

```
% cd ~/modeltech/examples/mixedHDL
% vlib work
% vlog cache.v memory.v proc.v
% vcom util.vhd set.vhd top.vhd
% vsim top
VSIM 1> vcd dumports -file proc.vcd /top/p/*
VSIM 2> vcd dumports -file cache.vcd /top/c/*
VSIM 3> vcd dumports -file memory.vcd /top/m/*
VSIM 4> run 1000
VSIM 5> quit -f
```

Next, rerun each module separately, using the captured VCD stimulus:

```
% vsim -vcdstim proc.vcd proc -do "add wave /*; run 1000"
VSIM 1> quit -f

% vsim -vcdstim cache.vcd cache -do "add wave /*; run 1000"
VSIM 1> quit -f

% vsim -vcdstim memory.vcd memory -do "add wave /*; run 1000"
VSIM 1> quit -f
```

**Replacing instances with output values from a VCD file**

Replacing instances with output values from a VCD file lets you simulate without the instance's source or even the compiled object. The general procedure includes two steps:

- 1 Create VCD files for one or more instances in your design using the **vcd dumports** command (CR-152). If necessary, use the **-vcdstim** switch to handle port order problems (see below).
- 2 Re-simulate your design using the **-vcdstim <instance>=<filename>** argument to **vsim** (CR-213). Note that this works only with VCD files that were created by a ModelSim simulation.

***Example***

In the following example, the three instances */top/p*, */top/c*, and */top/m* are replaced in simulation by the output values found in the corresponding VCD files.

First, create VCD files for all instances you want to replace:

```
vcd dumports -vcdstim -file proc.vcd /top/p/*
vcd dumports -vcdstim -file cache.vcd /top/c/*
vcd dumports -vcdstim -file memory.vcd /top/m/*
run 1000
```

Next, simulate your design and map the instances to the VCD files you created:

```
vsim top -vcdstim /top/p=proc.vcd -vcdstim /top/c=cache.vcd
-vcdstim /top/m=memory.vcd
```

### ***Port order issues***

The **-vcdstim** argument to the **vcd dumpports** command ensures the order that port names appear in the VCD file matches the order that they are declared in the instance's module or entity declaration. Consider the following module declaration:

```
module proc(clk, addr, data, rw, strb, rdy);
    input  clk, rdy;
    output addr, rw, strb;
    inout  data;
```

The order of the ports in the module line (`clk, addr, data, ...`) does not match the order of those ports in the input, output, and inout lines (`clk, rdy, addr, ...`). In this case the **-vcdstim** argument to the **vcd dumpports** command needs to be used.

In cases where the order is the same, you do not need to use the **-vcdstim** argument to **vcd dumpports**. Also, module declarations of the form:

```
module proc(input clk, output addr, inout data, ...)
```

do not require use of the argument.

## ModelSim VCD commands and VCD tasks

ModelSim VCD commands map to IEEE Std 1364 VCD system tasks and appear in the VCD file along with the results of those commands. The table below maps the VCD commands to their associated tasks.

| VCD commands                   | VCD system tasks |
|--------------------------------|------------------|
| <b>vcd add</b> (CR-149)        | \$dumpvars       |
| <b>vcd checkpoint</b> (CR-150) | \$dumpall        |
| <b>vcd file</b> (CR-159)▲      | \$dumpfile       |
| <b>vcd flush</b> (CR-162)      | \$dumpflush      |
| <b>vcd limit</b> (CR-163)      | \$dumplimit      |
| <b>vcd off</b> (CR-164)        | \$dumpoff        |
| <b>vcd on</b> (CR-165)         | \$dumpon         |

ModelSim versions 5.5 and later also support extended VCD (dumports system tasks). The table below maps the VCD dumports commands to their associated tasks.

| VCD dumports commands             | VCD system tasks |
|-----------------------------------|------------------|
| <b>vcd dumports</b> (CR-152)      | \$dumports       |
| <b>vcd dumportsall</b> (CR-154)   | \$dumportsall    |
| <b>vcd dumportsflush</b> (CR-155) | \$dumportsflush  |
| <b>vcd dumportslimit</b> (CR-156) | \$dumportslimit  |
| <b>vcd dumpportsoff</b> (CR-157)  | \$dumpportsoff   |
| <b>vcd dumpportson</b> (CR-158)   | \$dumpportson    |

ModelSim supports multiple VCD files. This functionality is an extension of the IEEE Std 1364 specification. The tasks behave the same as the IEEE equivalent tasks such as \$dumpfile, \$dumpvar, etc. The difference is that \$fdumpfile can be called multiple times to create more than one VCD file, and the remaining tasks require a filename argument to associate their actions with a specific file.

| VCD commands                              | VCD system tasks |
|-------------------------------------------|------------------|
| <b>vcd add</b> (CR-149) -file <filename>  | \$fdumpvars      |
| <b>vcd checkpoint</b> (CR-150) <filename> | \$fdumpall       |
| <b>vcd files</b> (CR-160) <filename>▲     | \$fdumpfile      |
| <b>vcd flush</b> (CR-162) <filename>      | \$fdumpflush     |

| VCD commands                         | VCD system tasks |
|--------------------------------------|------------------|
| <b>vcd limit</b> (CR-163) <filename> | \$fdumplimit     |
| <b>vcd off</b> (CR-164) <filename>   | \$fdumpoff       |
| <b>vcd on</b> (CR-165) <filename>    | \$fdumpon        |

▲ **Important:** Note that two commands (**vcd file** and **vcd files**) are available to specify a filename and state mapping for a VCD file. **Vcd file** allows for only one VCD file and exists for backwards compatibility with ModelSim versions prior to 5.5. **Vcd files** allows for creation of multiple VCD files and is the preferred command to use in ModelSim versions 5.5 and later.

## Compressing files with VCD tasks

ModelSim can produce compressed VCD files using the **gzip** compression algorithm. Since we cannot change the syntax of the system tasks, we act on the extension of the output file name. If you specify a **.gz** extension on the filename, ModelSim will compress the output.

## A VCD file from source to output

The following example shows the VHDL source, a set of simulator commands, and the resulting VCD output.

### VHDL source code

The design is a simple shifter device represented by the following VHDL source code:

```

library IEEE;
use IEEE.STD_LOGIC_1164.all;

entity SHIFTER_MOD is
    port (CLK, RESET, data_in : IN STD_LOGIC;
          Q : INOUT STD_LOGIC_VECTOR(8 downto 0));
END SHIFTER_MOD ;

architecture RTL of SHIFTER_MOD is
begin
    process (CLK,RESET)
    begin
        if (RESET = '1') then
            Q <= (others => '0') ;
        elsif (CLK'event and CLK = '1') then
            Q <= Q(Q'left - 1 downto 0) & data_in ;
        end if ;
    end process ;
end ;

```

### VCD simulator commands

At simulator time zero, the designer executes the following commands:

```

vcd file output.vcd
vcd add -r *
force reset 1 0
force data_in 0 0
force clk 0 0
run 100
force clk 1 0, 0 50 -repeat 100
run 100
vcd off
force reset 0 0
force data_in 1 0
run 100
vcd on
run 850
force reset 1 0
run 50
vcd checkpoint
quit -sim

```

## VCD output

The VCD file created as a result of the preceding scenario would be called *output.vcd*. The following pages show how it would look.

### ***VCD output***

```
$date
    Thu Sep 18 11:07:43 2003
$end
$version
    ModelSim Version 5.8
$end
$timescale
    1ns
$end
$scope module shifter_mod $end
$var wire 1 ! clk $end
$var wire 1 " reset $end
$var wire 1 # data_in $end
$var wire 1 $ q [8] $end
$var wire 1 % q [7] $end
$var wire 1 & q [6] $end
$var wire 1 ' q [5] $end
$var wire 1 ( q [4] $end
$var wire 1 ) q [3] $end
$var wire 1 * q [2] $end
$var wire 1 + q [1] $end
$var wire 1 , q [0] $end
$upscope $end
$enddefinitions $end
#0
$dumpvars
0!
1"
0#
0$
0%
0&
0'
0(
0)
0*
0+
0,
$end
#100
1!
#150
0!
#200
1!
$dumpoff
x!
x"
x#
x$
x%
x&
x'
x(

```

```
x)
x*
x+
x,
$end
#300
$dumpon
1!
0"
1#
0$
0%
0&
0'
0(
0)
0*
0+
1,
$end
#350
0!
#400
1!
1+
#450
0!
#500
1!
1*
#550
0!
#600
1!
1)
#650
0!
#700
1!
1(
#750
0!
#800
1!
1'
#850
0!
#900
1!
1&
#950
0!
#1000
1!
1%
#1050
0!
#1100
1!
1$
#1150
```

```
0 !
1 "
0 ,
0+
0*
0 )
0(
0'
0&
0%
0$#
#1200
1!
$dumpall
1!
1"
1#
0$#
0%
0&
0'
0(
0)
0*
0+
0,
$end
```

## Capturing port driver data

Some ASIC vendors' toolkits read a VCD file format that provides details on port drivers. This information can be used, for example, to drive a tester. See the ASIC vendor's documentation for toolkit specific information.

In ModelSim use the **vcf dumpports** command (CR-152) to create a VCD file that captures port driver data.

Port driver direction information is captured as TSSI states in the VCD file. Each time an external or internal port driver changes values, a new value change is recorded in the VCD file with the following format:

```
p<TSSI state> <0 strength> <1 strength> <identifier_code>
```

### Supported TSSI states

The supported <TSSI states> are:

| Input (testfixture)                 | Output (dut)                        |
|-------------------------------------|-------------------------------------|
| D low                               | L low                               |
| U high                              | H high                              |
| N unknown                           | X unknown                           |
| Z tri-state                         | T tri-state                         |
| d low (two or more drivers active)  | l low (two or more drivers active)  |
| u high (two or more drivers active) | h high (two or more drivers active) |

| Unknown direction                                         |
|-----------------------------------------------------------|
| 0 low (both input and output are driving low)             |
| 1 high (both input and output are driving high)           |
| ? unknown (both input and output are driving unknown)     |
| F three-state (input and output unconnected)              |
| A unknown (input driving low and output driving high)     |
| a unknown (input driving low and output driving unknown)  |
| B unknown (input driving high and output driving low)     |
| b unknown (input driving high and output driving unknown) |
| C unknown (input driving unknown and output driving low)  |
| c unknown (input driving unknown and output driving high) |

| <b>Unknown direction</b>                  |
|-------------------------------------------|
| f unknown (input and output three-stated) |

## Strength values

The <strength> values are based on Verilog strengths:

| <b>Strength</b> | <b>VHDL std_logic mappings</b> |
|-----------------|--------------------------------|
| 0 highz         | 'Z'                            |
| 1 small         |                                |
| 2 medium        |                                |
| 3 weak          |                                |
| 4 large         |                                |
| 5 pull          | 'W','H','L'                    |
| 6 strong        | 'U','X','0','1','-'            |
| 7 supply        |                                |

## Port identifier code

The <identifier\_code> is an integer preceded by < that starts at zero and is incremented for each port in the order the ports are specified. Also, the variable type recorded in the VCD header is "port".

## Example VCD output from vcd dumpports

The following is an example VCD file created with the **vcd dumpports** command.

```
$comment
    File created using the following command:
        vcd file myvcdfile.vcd -dumpports
$end
$date
    Thu Sep 18 07:35:58 2003
$end
$version
    dumpports ModelSim Version 5.8
$end
$timescale
    1ns
$end
$scope module test_counter $end
$scope module dut $end
$var port 1 <0 count [7] $end
$var port 1 <1 count [6] $end
$var port 1 <2 count [5] $end
$var port 1 <3 count [4] $end
$var port 1 <4 count [3] $end
$var port 1 <5 count [2] $end
$var port 1 <6 count [1] $end
$var port 1 <7 count [0] $end
$var port 1 <8 clk $end
$var port 1 <9 reset $end
$upscope $end
$upscope $end
$enddefinitions $end
#0
$dumpports
pX 6 6 <7
pX 6 6 <6
pX 6 6 <5
pX 6 6 <4
pX 6 6 <3
pX 6 6 <2
pX 6 6 <1
pX 6 6 <0
pD 6 0 <9
pD 6 0 <8
$end
#5
pU 0 6 <9
#8
pL 6 0 <7
pL 6 0 <6
pL 6 0 <5
pL 6 0 <4
pL 6 0 <3
pL 6 0 <2
pL 6 0 <1
pL 6 0 <0
#9
pD 6 0 <9
#10
pU 0 6 <8
#12
```

```
pH 0 6 <7  
#20  
pD 6 0 <8  
#30  
pU 0 6 <8  
#32  
pL 6 0 <7  
pH 0 6 <6  
#40  
pD 6 0 <8  
#50  
pU 0 6 <8  
#52  
pH 0 6 <7  
#60  
pD 6 0 <8  
#70  
pU 0 6 <8  
#72  
pL 6 0 <7  
pL 6 0 <6  
pH 0 6 <5  
#80  
pD 6 0 <8  
#90  
pU 0 6 <8  
#92  
pH 0 6 <7  
#100  
pD 6 0 <8  
$vcddclose  
#100  
$end
```



# 12 - Tcl and macros (DO files)

---

## Chapter contents

|                                                               |        |
|---------------------------------------------------------------|--------|
| Tcl features within ModelSim . . . . .                        | UM-346 |
| Tcl References . . . . .                                      | UM-346 |
| Tcl commands . . . . .                                        | UM-347 |
| Tcl command syntax . . . . .                                  | UM-348 |
| if command syntax . . . . .                                   | UM-350 |
| set command syntax . . . . .                                  | UM-351 |
| Command substitution . . . . .                                | UM-352 |
| Command separator . . . . .                                   | UM-352 |
| Multiple-line commands . . . . .                              | UM-352 |
| Evaluation order . . . . .                                    | UM-352 |
| Tcl relational expression evaluation . . . . .                | UM-352 |
| Variable substitution . . . . .                               | UM-353 |
| System commands . . . . .                                     | UM-353 |
| List processing . . . . .                                     | UM-354 |
| ModelSim Tcl commands . . . . .                               | UM-354 |
| ModelSim Tcl time commands . . . . .                          | UM-355 |
| Tcl examples . . . . .                                        | UM-357 |
| Macros (DO files) . . . . .                                   | UM-359 |
| Creating DO files . . . . .                                   | UM-359 |
| Using Parameters with DO files . . . . .                      | UM-359 |
| Making macro parameters optional . . . . .                    | UM-360 |
| Useful commands for handling breakpoints and errors . . . . . | UM-361 |
| Error action in DO files . . . . .                            | UM-361 |

This chapter provides an overview of Tcl (tool command language) as used with ModelSim. Macros in ModelSim are simply Tcl scripts that contain ModelSim and, optionally, Tcl commands.

Tcl is a scripting language for controlling and extending ModelSim. Within ModelSim you can develop implementations from Tcl scripts without the use of C code. Because Tcl is interpreted, development is rapid; you can generate and execute Tcl scripts on the fly without stopping to recompile or restart ModelSim. In addition, if ModelSim does not provide the command you need, you can use Tcl to create your own commands.

## Tcl features within ModelSim

Using Tcl with ModelSim gives you these features:

- command history (like that in C shells)
- full expression evaluation and support for all C-language operators
- a full range of math and trig functions
- support of lists and arrays
- regular expression pattern matching
- procedures
- the ability to define your own commands
- command substitution (that is, commands may be nested)
- robust scripting language for macros

## Tcl References

Two books about Tcl are *Tcl and the Tk Toolkit* by John K. Ousterhout, published by Addison-Wesley Publishing Company, Inc., and *Practical Programming in Tcl and Tk* by Brent Welch published by Prentice Hall. You can also consult the following online references:

- Select **Help > Tcl Man Pages** (Main window).
- The Model Technology web site lists a variety of Tcl resources:  
[www.model.com/resources/tcltk.asp](http://www.model.com/resources/tcltk.asp)

## Tcl commands

For complete information on Tcl commands, select **Help > Tcl Man Pages** (Main window). Also see "[Preference variables located in Tcl files](#)" (UM-381) for information on Tcl variables.

ModelSim command names that conflict with Tcl commands have been renamed or have been replaced by Tcl commands. See the list below:

| <b>Previous ModelSim command</b> | <b>Command changed to (or replaced by)</b>                                                                       |
|----------------------------------|------------------------------------------------------------------------------------------------------------------|
| continue                         | <a href="#">run</a> (CR-133) with the <b>-continue</b> option                                                    |
| format list   wave               | <a href="#">write format</a> (CR-241) with either list or wave specified                                         |
| if                               | replaced by the Tcl <b>if</b> command, see " <a href="#">if command syntax</a> " (UM-350) for more information   |
| list                             | <a href="#">add list</a> (CR-38)                                                                                 |
| nolist   nowave                  | <a href="#">delete</a> (CR-72) with either list or wave specified                                                |
| set                              | replaced by the Tcl <b>set</b> command, see " <a href="#">set command syntax</a> " (UM-351) for more information |
| source                           | <a href="#">vsource</a> (CR-227)                                                                                 |
| wave                             | <a href="#">add wave</a> (CR-41)                                                                                 |

## Tcl command syntax

The following eleven rules define the syntax and semantics of the Tcl language. Additional details on [if command syntax](#) (UM-350) and [set command syntax](#) (UM-351) follow.

- 1 A Tcl script is a string containing one or more commands. Semi-colons and newlines are command separators unless quoted as described below. Close brackets ("]") are command terminators during command substitution (see below) unless quoted.
- 2 A command is evaluated in two steps. First, the Tcl interpreter breaks the command into words and performs substitutions as described below. These substitutions are performed in the same way for all commands. The first word is used to locate a command procedure to carry out the command, then all of the words of the command are passed to the command procedure. The command procedure is free to interpret each of its words in any way it likes, such as an integer, variable name, list, or Tcl script. Different commands interpret their words differently.
- 3 Words of a command are separated by white space (except for newlines, which are command separators).
- 4 If the first character of a word is a double-quote ("") then the word is terminated by the next double-quote character. If semi-colons, close brackets, or white space characters (including newlines) appear between the quotes then they are treated as ordinary characters and included in the word. Command substitution, variable substitution, and backslash substitution are performed on the characters between the quotes as described below. The double-quotes are not retained as part of the word.
- 5 If the first character of a word is an open brace ("{") then the word is terminated by the matching close brace ("}"). Braces nest within the word: for each additional open brace there must be an additional close brace (however, if an open brace or close brace within the word is quoted with a backslash then it is not counted in locating the matching close brace). No substitutions are performed on the characters between the braces except for backslash-newline substitutions described below, nor do semi-colons, newlines, close brackets, or white space receive any special interpretation. The word will consist of exactly the characters between the outer braces, not including the braces themselves.
- 6 If a word contains an open bracket ("[") then Tcl performs command substitution. To do this it invokes the Tcl interpreter recursively to process the characters following the open bracket as a Tcl script. The script may contain any number of commands and must be terminated by a close bracket ("]"). The result of the script (i.e. the result of its last command) is substituted into the word in place of the brackets and all of the characters between them. There may be any number of command substitutions in a single word. Command substitution is not performed on words enclosed in braces.

- 7** If a word contains a dollar-sign ("\$") then Tcl performs variable substitution: the dollar-sign and the following characters are replaced in the word by the value of a variable. Variable substitution may take any of the following forms:

`$name`

Name is the name of a scalar variable; the name is terminated by any character that isn't a letter, digit, or underscore.

`$name(index)`

Name gives the name of an array variable and index gives the name of an element within that array. Name must contain only letters, digits, and underscores. Command substitutions, variable substitutions, and backslash substitutions are performed on the characters of index.

`$ {name}`

Name is the name of a scalar variable. It may contain any characters whatsoever except for close braces.

There may be any number of variable substitutions in a single word. Variable substitution is not performed on words enclosed in braces.

- 8** If a backslash ("\") appears within a word then backslash substitution occurs. In all cases but those described below the backslash is dropped and the following character is treated as an ordinary character and included in the word. This allows characters such as double quotes, close brackets, and dollar signs to be included in words without triggering special processing. The following table lists the backslash sequences that are handled specially, along with the value that replaces each sequence.

|                                         |                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>\a</code>                         | Audible alert (bell) (0x7).                                                                                                                                                                                                                                                                                                                                                                      |
| <code>\b</code>                         | Backspace (0x8).                                                                                                                                                                                                                                                                                                                                                                                 |
| <code>\f</code>                         | Form feed (0xc).                                                                                                                                                                                                                                                                                                                                                                                 |
| <code>\n</code>                         | Newline (0xa).                                                                                                                                                                                                                                                                                                                                                                                   |
| <code>\r</code>                         | Carriage-return (0xd).                                                                                                                                                                                                                                                                                                                                                                           |
| <code>\t</code>                         | Tab (0x9).                                                                                                                                                                                                                                                                                                                                                                                       |
| <code>\v</code>                         | Vertical tab (0xb).                                                                                                                                                                                                                                                                                                                                                                              |
| <code>\&lt;newline&gt;whiteSpace</code> | A single space character replaces the backslash, newline, and all spaces and tabs after the newline. This backslash sequence is unique in that it is replaced in a separate pre-pass before the command is actually parsed. This means that it will be replaced even when it occurs between braces, and the resulting space will be treated as a word separator if it isn't in braces or quotes. |
| <code>\\"</code>                        | Backslash ("\").                                                                                                                                                                                                                                                                                                                                                                                 |
| <code>\ooo</code>                       | The digits ooo (one, two, or three of them) give the octal value of the character.                                                                                                                                                                                                                                                                                                               |

|      |                                                                                                             |
|------|-------------------------------------------------------------------------------------------------------------|
| \xhh | The hexadecimal digits hh give the hexadecimal value of the character. Any number of digits may be present. |
|------|-------------------------------------------------------------------------------------------------------------|

Backslash substitution is not performed on words enclosed in braces, except for backslash-newline as described above.

- 9 If a hash character ("#") appears at a point where Tcl is expecting the first character of the first word of a command, then the hash character and the characters that follow it, up through the next newline, are treated as a comment and ignored. The comment character only has significance when it appears at the beginning of a command.
- 10 Each character is processed exactly once by the Tcl interpreter as part of creating the words of a command. For example, if variable substitution occurs then no further substitutions are performed on the value of the variable; the value is inserted into the word verbatim. If command substitution occurs then the nested command is processed entirely by the recursive call to the Tcl interpreter; no substitutions are performed before making the recursive call and no additional substitutions are performed on the result of the nested script.
- 11 Substitutions do not affect the word boundaries of a command. For example, during variable substitution the entire value of the variable becomes part of a single word, even if the variable's value contains spaces.

## if command syntax

The Tcl **if** command executes scripts conditionally. Note that in the syntax below the "?" indicates an optional argument.

### Syntax

```
if expr1 ?then? body1 elseif expr2 ?then? body2 elseif ... ?else? ?bodyN?
```

### Description

The **if** command evaluates *expr1* as an expression. The value of the expression must be a boolean (a numeric value, where 0 is false and anything else is true, or a string value such as **true** or **yes** for true and **false** or **no** for false); if it is true then *body1* is executed by passing it to the Tcl interpreter. Otherwise *expr2* is evaluated as an expression and if it is true then *body2* is executed, and so on. If none of the expressions evaluates to true then *bodyN* is executed. The **then** and **else** arguments are optional "noise words" to make the command easier to read. There may be any number of **elseif** clauses, including zero. *BodyN* may also be omitted as long as **else** is omitted too. The return value from the command is the result of the body script that was executed, or an empty string if none of the expressions was non-zero and there was no *bodyN*.

## set command syntax

The Tcl **set** command reads and writes variables. Note that in the syntax below the "?" indicates an optional argument.

### Syntax

```
set varName ?value?
```

### Description

Returns the value of variable *varName*. If *value* is specified, then sets the value of *varName* to *value*, creating a new variable if one doesn't already exist, and returns its value. If *varName* contains an open parenthesis and ends with a close parenthesis, then it refers to an array element: the characters before the first open parenthesis are the name of the array, and the characters between the parentheses are the index within the array. Otherwise *varName* refers to a scalar variable. Normally, *varName* is unqualified (does not include the names of any containing namespaces), and the variable of that name in the current namespace is read or written. If *varName* includes namespace qualifiers (in the array name if it refers to an array element), the variable in the specified namespace is read or written.

If no procedure is active, then *varName* refers to a namespace variable (global variable if the current namespace is the global namespace). If a procedure is active, then *varName* refers to a parameter or local variable of the procedure unless the **global** command was invoked to declare *varName* to be global, or unless a Tcl **variable** command was invoked to declare *varName* to be a namespace variable.

## Command substitution

Placing a command in square brackets [ ] will cause that command to be evaluated first and its results returned in place of the command. An example is:

```
set a 25
set b 11
set c 3
echo "the result is [expr ($a + $b)/$c]"
```

will output:

```
"the result is 12"
```

This feature allows VHDL variables and signals, and Verilog nets and registers to be accessed using:

```
[examine -<radix> name]
```

The %name substitution is no longer supported. Everywhere %name could be used, you now can use [examine -value -<radix> name] which allows the flexibility of specifying command options. The radix specification is optional.

## Command separator

A semicolon character (;) works as a separator for multiple commands on the same line. It is not required at the end of a line in a command sequence.

## Multiple-line commands

With Tcl, multiple-line commands can be used within macros and on the command line. The command line prompt will change (as in a C shell) until the multiple-line command is complete.

In the example below, note the way the opening brace '{' is at the end of the if and else lines. This is important because otherwise the Tcl scanner won't know that there is more coming in the command and will try to execute what it has up to that point, which won't be what you intend.

```
if { [exa sig_a] == "0011ZZ" } {
    echo "Signal value matches"
    do macro_1.do
} else {
    echo "Signal value fails"
    do macro_2.do
}
```

## Evaluation order

An important thing to remember when using Tcl is that anything put in curly brackets {} is not evaluated immediately. This is important for if-then-else statements, procedures, loops, and so forth.

## Tcl relational expression evaluation

When you are comparing values, the following hints may be useful:

- Tcl stores all values as strings, and will convert certain strings to numeric values when appropriate. If you want a literal to be treated as a numeric value, don't quote it.

```
if {[exa var_1] == 345}...
```

The following will also work:

```
if {[exa var_1] == "345"}...
```

- However, if a literal cannot be represented as a number, you *must* quote it, or Tcl will give you an error. For instance:

```
if {[exa var_2] == 001Z}...
```

will give an error.

```
if {[exa var_2] == "001Z"}...
```

will work okay.

- Don't quote single characters in single quotes:

```
if {[exa var_3] == 'X'}...
```

will give an error

```
if {[exa var_3] == "X"}...
```

will work okay.

- For the equal operator, you must use the C operator "==" . For not-equal, you must use the C operator "!=".

## Variable substitution

When a \$<var\_name> is encountered, the Tcl parser will look for variables that have been defined either by ModelSim or by you, and substitute the value of the variable.

► **Note:** Tcl is case sensitive for variable names.

To access environment variables, use the construct:

```
$env(<var_name>)  
echo My user name is $env(USER)
```

Environment variables can also be set using the env array:

```
set env(SHELL) /bin/csh
```

See "[Simulator state variables](#)" (UM-384) for more information about ModelSim-defined variables.

## System commands

To pass commands to the DOS window, use the Tcl **exec** command:

```
echo The date is [exec date]
```

## List processing

In Tcl a "list" is a set of strings in curly braces separated by spaces. Several Tcl commands are available for creating lists, indexing into lists, appending to lists, getting the length of lists and shifting lists. These commands are:

| Command syntax                                       | Description                                                                                                                              |
|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| <b>lappend</b> var_name val1 val2 ...                | appends val1, val2, etc. to list var_name                                                                                                |
| <b>lindex</b> list_name index                        | returns the index-th element of list_name; the first element is 0                                                                        |
| <b>linsert</b> list_name index val1 val2 ...         | inserts val1, val2, etc. just before the index-th element of list_name                                                                   |
| <b>list</b> val1, val2 ...                           | returns a Tcl list consisting of val1, val2, etc.                                                                                        |
| <b>llength</b> list_name                             | returns the number of elements in list_name                                                                                              |
| <b>lrange</b> list_name first last                   | returns a sublist of list_name, from index first to index last; first or last may be "end", which refers to the last element in the list |
| <b>lreplace</b> list_name first last val1, val2, ... | replaces elements first through last with val1, val2, etc.                                                                               |

Two other commands, **lsearch** and **lsort**, are also available for list manipulation. See the Tcl man pages ([Help > Tcl Man Pages](#)) for more information on these commands.

## ModelSim Tcl commands

These additional commands enhance the interface between Tcl and ModelSim. Only brief descriptions are provided here; for more information and command syntax see the *ModelSim Command Reference*.

| Command                  | Description                                                                                            |
|--------------------------|--------------------------------------------------------------------------------------------------------|
| <b>alias</b> (CR-45)     | creates a new Tcl procedure that evaluates the specified commands; used to create a user-defined alias |
| <b>find</b> (CR-86)      | locates incrTcl classes and objects                                                                    |
| <b>lshift</b> (CR-97)    | takes a Tcl list as argument and shifts it in-place one place to the left, eliminating the 0th element |
| <b>lsublist</b> (CR-98)  | returns a sublist of the specified Tcl list that matches the specified Tcl glob pattern                |
| <b>printenv</b> (CR-121) | echoes to the Main window the current names and values of all environment variables                    |

## ModelSim Tcl time commands

ModelSim Tcl time commands make simulator-time-based values available for use within other Tcl procedures.

Time values may optionally contain a units specifier where the intervening space is also optional. If the space is present, the value must be quoted (e.g. 10ns, "10 ns"). Time values without units are taken to be in the UserTimeScale. Return values are always in the current Time Scale Units. All time values are converted to a 64-bit integer value in the current Time Scale. This means that values smaller than the current Time Scale will be truncated to 0.

### Conversions

| Command                        | Description                                                                                                   |
|--------------------------------|---------------------------------------------------------------------------------------------------------------|
| intToTime <intHi32> <intLo32>  | converts two 32-bit pieces (high and low order) into a 64-bit quantity (Time in ModelSim is a 64-bit integer) |
| RealToTime <real>              | converts a <real> number to a 64-bit integer in the current Time Scale                                        |
| scaleTime <time> <scaleFactor> | returns the value of <time> multiplied by the <scaleFactor> integer                                           |

### Relations

| Command               | Description                         |
|-----------------------|-------------------------------------|
| eqTime <time> <time>  | evaluates for equal                 |
| neqTime <time> <time> | evaluates for not equal             |
| gtTime <time> <time>  | evaluates for greater than          |
| gteTime <time> <time> | evaluates for greater than or equal |
| ltTime <time> <time>  | evaluates for less than             |
| lteTime <time> <time> | evaluates for less than or equal    |

All relation operations return 1 or 0 for true or false respectively and are suitable return values for TCL conditional expressions. For example,

```
if {[eqTime $Now 1750ns]} {
    ...
}
```

## Arithmetic

| Command               | Description             |
|-----------------------|-------------------------|
| addTime <time> <time> | add time                |
| divTime <time> <time> | 64-bit integer divide   |
| mulTime <time> <time> | 64-bit integer multiply |
| subTime <time> <time> | subtract time           |

## Tcl examples

This is an example of using the Tcl **while** loop to copy a list from variable *a* to variable *b*, reversing the order of the elements along the way:

```
set b [list]
set i [expr {[llength $a] - 1}]
while {$i >= 0} {
    lappend b [lindex $a $i]
    incr i -1
}
```

This example uses the Tcl **for** command to copy a list from variable *a* to variable *b*, reversing the order of the elements along the way:

```
set b [list]
for {set i [expr {[llength $a] - 1}]} {$i >= 0} {incr i -1} {
    lappend b [lindex $a $i]
}
```

This example uses the Tcl **foreach** command to copy a list from variable *a* to variable *b*, reversing the order of the elements along the way (the foreach command iterates over all of the elements of a list):

```
set b [list]
foreach i $a { set b [linsert $b 0 $i] }
```

This example shows a list reversal as above, this time aborting on a particular element using the Tcl **break** command:

```
set b [list]
foreach i $a {
    if {$i = "ZZZ"} break
    set b [linsert $b 0 $i]
}
```

This example is a list reversal that skips a particular element by using the Tcl **continue** command:

```
set b [list]
foreach i $a {
    if {$i = "ZZZ"} continue
    set b [linsert $b 0 $i]
}
```

This next example specifies the compiler arguments and lets you compile any number of files.

```
set Files [list]
set nbrArgs $argc
for {set x 1} {$x <= $nbrArgs} {incr x} {
    set lappend Files $1
    shift
}
eval vcom -93 -explicit -noaccel $Files
```

This example is an enhanced version of the last one. The additional code determines whether the files are VHDL or Verilog and uses the appropriate compiler and arguments

depending on the file type. Note that the macro assumes your VHDL files have a *.vhd* file extension.

```
set vhdfFiles [list]
set vFiles [list]
set nbrArgs $argc
for {set x 1} {$x <= $nbrArgs} {incr x} {
    if {[string match *.vhd $1]} {
        lappend vhdfFiles $1
    } else {
        lappend vFiles $1
    }
    shift
}
if {[llength $vhdfFiles] > 0} {
    eval vcom -93 -explicit -noaccel $vhdfFiles
}
if {[llength $vFiles] > 0} {
    eval vlog $vFiles
}
```

## Macros (DO files)

ModelSim macros (also called DO files) are simply scripts that contain ModelSim and, optionally, Tcl commands. You invoke these scripts with the **Tools > Execute Macro** (Main window) menu selection or the **do** command (CR-75).

### Creating DO files

You can create DO files, like any other Tcl script, by typing the required commands in any editor and saving the file. Alternatively, you can save the Main window transcript as a DO file (see "[Saving the Main window transcript file](#)" (UM-165)).

The following is a simple DO file that was saved from the Main window transcript. It is used in the dataset exercise in the ModelSim Tutorial. This DO file adds several signals to the Wave window, provides stimulus to those signals, and then advances the simulation.

```
add wave ld
add wave rst
add wave clk
add wave d
add wave q
force -freeze clk 0 0, 1 {50 ns} -r 100
force rst 1
force rst 0 10
force ld 0
force d 1010
run 1700
force ld 1
run 100
force ld 0
run 400
force rst 1
run 200
force rst 0 10
run 1500
```

### Using Parameters with DO files

You can increase the flexibility of DO files by using parameters. Parameters specify values that are passed to the corresponding parameters \$1 through \$9 in the macro file. For example say the macro "*testfile*" contains the line **bp** \$1 \$2. The command below would place a breakpoint in the source file named *design.vhd* at line 127:

```
do testfile design.vhd 127
```

There is no limit on the number of parameters that can be passed to macros, but only nine values are visible at one time. You can use the **shift** command (CR-138) to see the other parameters.

## Making macro parameters optional

If you want to make macro parameters optional (i.e., be able to specify fewer parameter values with the do command than the number of parameters referenced in the macro), you must use the `argc` (UM-384) simulator state variable. The `argc` simulator state variable returns the number of parameters passed. The examples below show several ways of using `argc`.

### **Example 1**

This macro specifies the files to compile and handles 0-2 compiler arguments as parameters. If you supply more arguments, ModelSim generates a message.

```
switch $argc {
    0 {vcom file1.vhd file2.vhd file3.vhd }
    1 {vcom $1 file1.vhd file2.vhd file3.vhd }
    2 {vcom $1 $2 file1.vhd file2.vhd file3.vhd }
    default {echo Too many arguments. The macro accepts 0-2 args. }
}
```

### **Example 2**

This macro specifies the compiler arguments and lets you compile any number of files.

```
variable Files ""
set nbrArgs $argc
for {set x 1} {$x <= $nbrArgs} {incr x} {
    set Files [concat $Files $1]
    shift
}
eval vcom -93 -explicit -noaccel $Files
```

### **Example 3**

This macro is an enhanced version of the one shown in example 2. The additional code determines whether the files are VHDL or Verilog and uses the appropriate compiler and arguments depending on the file type. Note that the macro assumes your VHDL files have a .vhd file extension.

```
variable vhdfFiles ""
variable vFiles ""
set nbrArgs $argc
set vhdfFilesExist 0
set vFilesExist 0
for {set x 1} {$x <= $nbrArgs} {incr x} {
    if {[string match *.vhd $1]} {
        set vhdfFiles [concat $vhdfFiles $1]
        set vhdfFilesExist 1
    } else {
        set vFiles [concat $vFiles $1]
        set vFilesExist 1
    }
    shift
}
if {$vhdfFilesExist == 1} {
    eval vcom -93 -explicit -noaccel $vhdfFiles
}
if {$vFilesExist == 1} {
    eval vlog -fast -forcecode $vFiles
}
```

## Useful commands for handling breakpoints and errors

If you are executing a macro when your simulation hits a breakpoint or causes a run-time error, ModelSim interrupts the macro and returns control to the command line. The following commands may be useful for handling such events. (Any other legal command may be executed as well.)

| command                              | result                                                                                                                        |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| <b>run</b> (CR-133) <b>-continue</b> | continue as if the breakpoint had not been executed, completes the <b>run</b> (CR-133) that was interrupted                   |
| <b>onbreak</b> (CR-116)              | specify a command to run when you hit a breakpoint within a macro                                                             |
| <b>onElabError</b> (CR-117)          | specify a command to run when an error is encountered during elaboration                                                      |
| <b>onerror</b> (CR-118)              | specify a command to run when an error is encountered within a macro                                                          |
| <b>status</b> (CR-141)               | get a traceback of nested macro calls when a macro is interrupted                                                             |
| <b>abort</b> (CR-36)                 | terminate a macro once the macro has been interrupted or paused                                                               |
| <b>pause</b> (CR-119)                | cause the macro to be interrupted; the macro can be resumed by entering a <b>resume</b> command (CR-132) via the command line |

- **Note:** You can also set the **OnErrorDefaultAction** Tcl variable (see "[Preference variables located in Tcl files](#)" (UM-381)) in the *pref.tcl* file to dictate what action ModelSim takes when an error occurs.

## Error action in DO files

If a command in a macro returns an error, ModelSim does the following:

- 1 If an **onerror** (CR-118) command has been set in the macro script, ModelSim executes that command.
- 2 If no **onerror** command has been specified in the script, ModelSim checks the **OnErrorDefaultAction** Tcl variable. If the variable is defined, its action will be invoked.
- 3 If neither 1 or 2 is true, the macro aborts.

## Using the Tcl source command with DO files

Either the **do** command or Tcl **source** command can execute a DO file, but they behave differently.

With the **source** command, the DO file is executed exactly as if the commands in it were typed in by hand at the prompt. Each time a breakpoint is hit the Source window is updated to show the breakpoint. This behavior could be inconvenient with a large DO file containing many breakpoints.

When a **do** command is interrupted by an error or breakpoint, it does not update any windows, and keeps the DO file "locked". This keeps the Source window from flashing, scrolling, and moving the arrow when a complex DO file is executed. Typically an **onbreak resume** command is used to keep the macro running as it hits breakpoints. Add an **onbreak abort** command to the DO file if you want to exit the macro and update the Source window.

# A - ModelSim variables

---

## Appendix contents

|                                                             |        |
|-------------------------------------------------------------|--------|
| Variable settings report . . . . .                          | UM-364 |
| Personal preferences . . . . .                              | UM-364 |
| Returning to the original ModelSim defaults . . . . .       | UM-365 |
| Environment variables . . . . .                             | UM-365 |
| Creating environment variables in Windows . . . . .         | UM-367 |
| Referencing environment variables within ModelSim . . . . . | UM-368 |
| Removing temp files (VSOUT) . . . . .                       | UM-368 |
| Preference variables located in INI files . . . . .         | UM-369 |
| [Library] library path variables . . . . .                  | UM-369 |
| [vlog] Verilog compiler control variables . . . . .         | UM-370 |
| [vcom] VHDL compiler control variables . . . . .            | UM-370 |
| [vsim] simulator control variables . . . . .                | UM-372 |
| Commonly used INI variables . . . . .                       | UM-378 |
| Preference variables located in Tcl files . . . . .         | UM-381 |
| Variable precedence . . . . .                               | UM-383 |
| Simulator state variables . . . . .                         | UM-384 |
| Referencing simulator state variables . . . . .             | UM-384 |
| Special considerations for the now variable . . . . .       | UM-385 |

This appendix documents the following types of ModelSim variables:

- **environment variables**

Variables referenced and set according to operating system conventions. Environment variables prepare the ModelSim environment prior to simulation.

- **ModelSim preference variables**

Variables used to control compiler or simulator functions and modify the appearance of the ModelSim GUI.

- **simulator state variables**

Variables that provide feedback on the state of the current simulation.

## Variable settings report

The **report** command (CR-128) returns a list of current settings for either the simulator state, or simulator control variables. Use the following commands at either the ModelSim or VSIM prompt:

```
report simulator state
report simulator control
```

The simulator control variables reported by the **report simulator control** command can be set interactively using the Tcl **set** command (UM-351).

## Personal preferences

There are several preferences stored by ModelSim on a personal basis, independent of *modelsim.ini* or *modelsim.tcl* files. These preferences are stored in the Windows Registry under **HKEY\_CURRENT\_USER\Software\Model Technology Incorporated\ModelSim**. Among these preferences are:

- **mti\_ask\_LBViewTypes, mti\_ask\_LBViewPath, mti\_ask\_LBViewLoadable**  
Settings for the **Customize Library View** dialog. Determine the view of the Library tab in the Main window workspace.
- **mti\_pane\_cnt, mti\_pane\_size, pane\_#, pane\_percent**  
Determine layout of various panes in the Main window.
- **open\_workspace**  
Setting for whether or not to display the Main window workspace.
- **pinit**  
Project Initialization state (one of: Welcome | OpenLast | NoWelcome). This determines whether the Welcome To ModelSim dialog box appears when you invoke the tool.
- **project\_history**  
Project History.
- **printersetup**  
All setup parameters related to Printing (i.e., current printer, etc.).
- **transcriptpercent**  
The size of the Main window transcript pane. Expressed as a percentage of the width of the Main window.

The **HKEY\_CURRENT\_USER** key is unique for each user Login on Windows NT.

## Returning to the original ModelSim defaults

If you would like to return ModelSim's interface to its original state, simply rename or delete the existing *modelsim.tcl* and *modelsim.ini* files. ModelSim will use *pref.tcl* for GUI preferences and make a copy of <install\_dir>/modeltech/*modelsim.ini* to use the next time ModelSim is invoked without an existing project (if you start a new project the new MPF file will use the settings in the new *modelsim.ini* file).

## Environment variables

Before compiling or simulating, several environment variables may be set to provide the functions described in the table below. The variables are in the *autoexec.bat* file on Windows 98/Me machines, and set through the System control panel on NT/2000/XP machines. The LM\_LICENSE\_FILE variable is required; all others are optional.

| Variable         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DOPATH           | <p>used by ModelSim to search for DO files (macros); consists of a colon-separated (semi-colon for Windows) list of paths to directories; this environment variable can be overridden by the DOPATH Tcl preference variable</p> <p>The DOPATH environment variable isn't accessible when you invoke <b>vsim</b> from a Unix shell or from a Windows command prompt. It is accessible once ModelSim or <b>vsim</b> is invoked. If you need to invoke from a shell or command line and use the DOPATH environment variable, use the following syntax:</p> <pre>vsim -do "do &lt;ofile_name&gt;" &lt;design_unit&gt;</pre> |
| EDITOR           | specifies the editor to invoke with the <b>edit</b> command (CR-79)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| HOME             | used by ModelSim to look for an optional graphical preference file and optional location map file; see: " <a href="#">Preference variables located in INI files</a> " (UM-369)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LM_LICENSE_FILE  | used by the ModelSim license file manager to find the location of the license file; may be a colon-separated (semi-colon for Windows) set of paths, including paths to other vendor license files; REQUIRED                                                                                                                                                                                                                                                                                                                                                                                                             |
| MODEL_TECH       | set by all ModelSim tools to the directory in which the binary executable resides; <b>DO NOT SET THIS VARIABLE!</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| MODEL_TECH_TCL   | used by ModelSim to find Tcl libraries for Tcl/Tk 8.3 and vsim; may also be used to specify a startup DO file; defaults to /modeltech/..tcl; may be set to an alternate path                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| MGC_LOCATION_MAP | used by ModelSim tools to find source files based on easily reallocated "soft" paths; optional; see the Tcl variables: <b>SourceDir</b> and <b>SourceMap</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| MODELSIM         | used by all ModelSim tools to find the <i>modelsim.ini</i> file; consists of a path including the file name. An alternative use of this variable is to set it to the path of a project file (<Project_Root_Dir>/<Project_Name>.mpf). This allows you to use project settings with command line tools. However, if you do this, the .mpf file will replace <i>modelsim.ini</i> as the initialization file for all ModelSim tools.                                                                                                                                                                                        |

| Variable        | Description                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODELSIM_TCL    | used by ModelSim to look for an optional graphical preference file; can be a semi-colon separated (Windows) list of file paths                                                                                                                                                                                                                                     |
| MTI_COSIM_TRACE | creates an <i>mti_trace_cosim</i> file containing debugging information about FLI/PLI/VPI function calls; set to any value before invoking the simulator.                                                                                                                                                                                                          |
| MTI_TF_LIMIT    | limits the size of the VSOUT temp file (generated by the ModelSim kernel); the value of the variable is the size of k-bytes; TMPDIR (below) controls the location of this file, STDOUT controls the name; default = 10, 0 = no limit; does <i>not</i> control the size of the transcript file                                                                      |
| MTI_USELIB_DIR  | specifies the directory into which object libraries are compiled when using the <b>-compile_uselibs</b> argument to the <b>vlog</b> command (CR-204)                                                                                                                                                                                                               |
| NOMMAP          | if set to 1, disables memory mapping in ModelSim; this should be used only when running on Linux 7.1; it will decrease the speed with which ModelSim reads files                                                                                                                                                                                                   |
| PLIOBJS         | used by ModelSim to search for PLI object files for loading; consists of a space-separated list of file or path names                                                                                                                                                                                                                                              |
| STDOUT          | the VSOUT temp file (generated by the simulator kernel) is deleted when the simulator exits; the file is not deleted if you specify a filename for VSOUT with STDOUT; specifying a name and location (use TMPDIR) for the VSOUT file will also help you locate and delete the file in event of a crash (an unnamed VSOUT file is not deleted after a crash either) |
| TMP             | specifies the path to a <code>tempnam()</code> generated file (VSOUT) containing all <code>stdout</code> from the simulation kernel                                                                                                                                                                                                                                |

## Creating environment variables in Windows

In addition to the predefined variables shown above, you can define your own environment variables. This example shows a user-defined library path variable that can be referenced by the **vmap** command to add library mapping to the *modelsim.ini* file.

### **Using Windows 98/Me**

Open and edit the *autoexec.bat* file by adding this line:

```
set MY_PATH=\temp\work
```

Restart Windows to initialize the new variable.

### **Using Windows NT/2000/XP**

Right-click the **My Computer** icon and select **Properties**, then select the **Environment** tab (in Windows 2000/XP select the Advanced tab and then Environment Variables). Add the new variable with this data—Variable:**MY\_PATH** and Value:**\temp\work**.

Click **Set** and **Apply** to initialize the variable.

### **Library mapping with environment variables**

Once the **MY\_PATH** variable is set, you can use it with the **vmap** command (CR-212) to add library mappings to the current *modelsim.ini* file.

If you're using the **vmap** command from a DOS prompt type:

```
vmap MY_VITAL %MY_PATH%
```

If you're using **vmap** from the ModelSim/VSIM prompt type:

```
vmap MY_VITAL \$MY_PATH
```

If you used DOS **vmap**, this line will be added to the *modelsim.ini*:

```
MY_VITAL = c:\temp\work
```

If **vmap** is used from the ModelSim/VSIM prompt, the *modelsim.ini* file will be modified with this line:

```
MY_VITAL = $MY_PATH
```

You can easily add additional hierarchy to the path. For example,

```
vmap MORE_VITAL %MY_PATH%\more_path\and_more_path
vmap MORE_VITAL \$MY_PATH\more_path\and_more_path
```

The "\$" character in the examples above is Tcl syntax that precedes a variable. The "\" character is an escape character that keeps the variable from being evaluated during the execution of **vmap**.

## Referencing environment variables within ModelSim

There are two ways to reference environment variables within ModelSim. Environment variables are allowed in a **FILE** variable being opened in VHDL. For example,

```
use std.textio.all;
entity test is end;
architecture only of test is
begin
    process
        FILE in_file : text is in "$ENV_VAR_NAME";
    begin
        wait;
    end process;
end;
```

Environment variables may also be referenced from the ModelSim command line or in macros using the Tcl **env** array mechanism:

```
echo $env(ENV_VAR_NAME)
```

- ▶ **Note:** Environment variable expansion *does not* occur in files that are referenced via the **-f** argument to **vcom**, **vlog**, or **vsim**.

## Removing temp files (VSOUT)

The **VSOUT** temp file is the communication mechanism between the simulator kernel and the ModelSim GUI. In normal circumstances the file is deleted when the simulator exits. If ModelSim crashes, however, the temp file must be deleted manually. Specifying the location of the temp file with **TMPDIR** (above) will help you locate and remove the file.

## Preference variables located in INI files

ModelSim initialization (INI) files contain control variables that specify reference library paths and compiler and simulator settings. The default initialization file is *modelsim.ini* and is located in your install directory.

To set these variables, edit the initialization file directly with any text editor. The syntax for variables in the file is:

```
<variable> = <value>
```

Comments within the file are preceded with a semicolon ( ; ).

The following tables list the variables by section, and in order of their appearance within the INI file:

| INI file sections                                                  |
|--------------------------------------------------------------------|
| <a href="#">[Library] library path variables (UM-369)</a>          |
| <a href="#">[vlog] Verilog compiler control variables (UM-370)</a> |
| <a href="#">[vcom] VHDL compiler control variables (UM-370)</a>    |
| <a href="#">[vsim] simulator control variables (UM-372)</a>        |

### [Library] library path variables

| Variable name     | Value range                                       | Purpose                                                                                                                                 |
|-------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| ieee              | any valid path; may include environment variables | sets the path to the library containing IEEE and Synopsys arithmetic packages; the default is \$MODEL_TECH/../ieee                      |
| modelsim_lib      | any valid path; may include environment variables | sets the path to the library containing Model Technology VHDL utilities such as Signal Spy; the default is \$MODEL_TECH/../modelsim_lib |
| std               | any valid path; may include environment variables | sets the path to the VHDL STD library; the default is \$MODEL_TECH/../std                                                               |
| std_developerskit | any valid path; may include environment variables | sets the path to the libraries for MGC standard developer's kit; the default is \$MODEL_TECH/../std_developerskit                       |
| synopsys          | any valid path; may include environment variables | sets the path to the accelerated arithmetic packages; the default is \$MODEL_TECH/../synopsys                                           |
| verilog           | any valid path; may include environment variables | sets the path to the library containing VHDL/Verilog type mappings; the default is \$MODEL_TECH/../verilog                              |
| vital2000         | any valid path; may include environment variables | sets the path to the VITAL 2000 library; the default is \$MODEL_TECH/../vital2000                                                       |

| Variable name | Value range                                       | Purpose                                                                                                                                                                                                         |
|---------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| others        | any valid path; may include environment variables | points to another <i>modelsim.ini</i> file whose library path variables will also be read; the pathname must include "modelsim.ini"; only one others variable can be specified in any <i>modelsim.ini</i> file. |

**[vlog] Verilog compiler control variables**

| Variable name         | Value range | Purpose                                                                                                      | Default |
|-----------------------|-------------|--------------------------------------------------------------------------------------------------------------|---------|
| Hazard                | 0, 1        | if 1, turns on Verilog hazard checking (order-dependent accessing of global variables)                       | off (0) |
| Incremental           | 0, 1        | if 1, turns on incremental compilation of modules                                                            | off (0) |
| NoDebug               | 0, 1        | if 1, turns off inclusion of debugging info within design units                                              | off (0) |
| Quiet                 | 0, 1        | if 1, turns off "loading..." messages                                                                        | off (0) |
| Show_Lint             | 0, 1        | if 1, turns on lint-style checking                                                                           | off (0) |
| Show_BadOptionWarning | 0, 1        | if 1, generates a warning whenever an unknown plus argument is encountered                                   | off (0) |
| Show_source           | 0, 1        | if 1, shows source line containing error                                                                     | off (0) |
| vlog95compat          | 0, 1        | if 1, disables System Verilog and Verilog 2001 support and makes compiler compatible with IEEE Std 1364-1995 | off (0) |

**[vcom] VHDL compiler control variables**

| Variable name     | Value range | Purpose                                                                                                                                                                                  | Default |
|-------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| CheckSynthesis    | 0, 1        | if 1, turns on limited synthesis rule compliance checking; checks only signals used (read) by a process; also, understands only combinational logic, not clocked logic                   | off (0) |
| Explicit          | 0, 1        | if 1, turns on resolving of ambiguous function overloading in favor of the "explicit" function declaration (not the one automatically created by the compiler for each type declaration) | on (1)  |
| IgnoreVitalErrors | 0, 1        | if 1, ignores VITAL compliance checking errors                                                                                                                                           | off (0) |
| NoCaseStaticError | 0, 1        | if 1, changes case statement static errors to warnings                                                                                                                                   | off (0) |

| <b>Variable name</b>              | <b>Value range</b> | <b>Purpose</b>                                                                                                | <b>Default</b> |
|-----------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------|----------------|
| NoDebug                           | 0, 1               | if 1, turns off inclusion of debugging info within design units                                               | off (0)        |
| NoIndexCheck                      | 0, 1               | if 1, run time index checks are disabled                                                                      | off (0)        |
| NoOthersStaticError               | 0, 1               | if 1, disables errors caused by aggregates that are not locally static                                        | off (0)        |
| NoRangeCheck                      | 0, 1               | if 1, disables run time range checking                                                                        | off (0)        |
| NoVital                           | 0, 1               | if 1, turns off acceleration of the VITAL packages                                                            | off (0)        |
| NoVitalCheck                      | 0, 1               | if 1, turns off VITAL compliance checking                                                                     | off (0)        |
| Optimize_1164                     | 0, 1               | if 0, turns off optimization for the IEEE std_logic_1164 package                                              | on (1)         |
| PedanticErrors                    | 0, 1               | if 1, overrides NoCaseStaticError and NoOthersStaticError                                                     | off(0)         |
| Quiet                             | 0, 1               | if 1, turns off "loading..." messages                                                                         | off (0)        |
| RequireConfigForAllDefaultBinding | 0, 1               | if 1, instructs the compiler not to generate a default binding during compilation                             | off (0)        |
| Show_source                       | 0, 1               | if 1, shows source line containing error                                                                      | off (0)        |
| Show_VitalChecksWarnings          | 0, 1               | if 0, turns off VITAL compliance-check warnings                                                               | on (1)         |
| Show_Warning1                     | 0, 1               | if 0, turns off unbound-component warnings                                                                    | on (1)         |
| Show_Warning2                     | 0, 1               | if 0, turns off process-without-a-wait-statement warnings                                                     | on (1)         |
| Show_Warning3                     | 0, 1               | if 0, turns off null-range warnings                                                                           | on (1)         |
| Show_Warning4                     | 0, 1               | if 0, turns off no-space-in-time-literal warnings                                                             | on (1)         |
| Show_Warning5                     | 0, 1               | if 0, turns off multiple-drivers-on-unresolved-signal warnings                                                | on (1)         |
| VHDL93                            | 0, 1, 2            | if 0, enables support for VHDL-1987; if 1, enables support for VHDL-1993; if 2, enables support for VHDL-2002 | 2              |

**[vsim] simulator control variables**

| <b>Variable name</b>   | <b>Value range</b>        | <b>Purpose</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Default</b>                                                     |
|------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| AssertFile             | any valid filename        | alternative file for storing VHDL or PSL assertion messages                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | transcript                                                         |
| AssertionFormat        | see next column           | defines format of VHDL assertion messages; fields include:<br>%S - severity level<br>%R - report message<br>%T - time of assertion<br>%D - delta<br>%I - instance or region pathname (if available)<br>%i - instance pathname with process<br>%O - process name<br>%K - kind of item path points to; returns Instance, Signal, Process, or Unknown<br>%P - instance or region path without leaf process<br>%F - file<br>%L - line number of assertion, or if from subprogram, line from which call is made<br>%% - print '%' character | "** %S:<br>%R\n Time:<br>%T<br>Iteration:<br>%D%I\n"               |
| AssertionFormatBreak   | see AssertionFormat above | defines format of messages for VHDL assertions that trigger a breakpoint; see AssertionFormat for options                                                                                                                                                                                                                                                                                                                                                                                                                              | "** %S:<br>%R\n Time: %T<br>Iteration:<br>%D %K: %i<br>File: %F\n" |
| AssertionFormatNote    | see AssertionFormat above | defines format of messages for VHDL Note assertions; see AssertionFormat for options; if undefined, AssertionFormat is used unless assertion causes a breakpoint in which case AssertionFormatBreak is used                                                                                                                                                                                                                                                                                                                            | "** %S:<br>%R\n Time: %T<br>Iteration:<br>%D%I\n"                  |
| AssertionFormatWarning | see AssertionFormat above | defines format of messages for VHDL Warning assertions; see AssertionFormat for options; if undefined, AssertionFormat is used unless assertion causes a breakpoint in which case AssertionFormatBreak is used                                                                                                                                                                                                                                                                                                                         | "** %S:<br>%R\n Time: %T<br>Iteration:<br>%D%I\n"                  |
| AssertionFormatError   | see AssertionFormat above | defines format of messages for VHDL Error assertions; see AssertionFormat for options; if undefined, AssertionFormat is used unless assertion causes a breakpoint in which case AssertionFormatBreak is used                                                                                                                                                                                                                                                                                                                           | "** %S:<br>%R\n Time: %T<br>Iteration:<br>%D %K: %i<br>File: %F\n" |

| <b>Variable name</b>   | <b>Value range</b>                                                    | <b>Purpose</b>                                                                                                                                                                                                           | <b>Default</b>                                                    |
|------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| AssertionFormatFail    | see AssertionFormat above                                             | defines format of messages for VHDL Fail assertions; see AssertionFormat for options; if undefined, AssertionFormat is used unless assertion causes a breakpoint in which case AssertionFormatBreak is used              | "** %S:<br>%R\nTime: %T<br>Iteration:<br>%D %K: %i<br>File: %F\n" |
| AssertionFormatFatal   | see AssertionFormat above                                             | defines format of messages for VHDL Fatal assertions; see AssertionFormat for options; if undefined, AssertionFormat is used unless assertion causes a breakpoint in which case AssertionFormatBreak is used             | "** %S:<br>%R\nTime: %T<br>Iteration:<br>%D %K: %i<br>File: %F\n" |
| BreakOnAssertion       | 0-4                                                                   | defines severity of VHDL assertion that causes a simulation break (0 = note, 1 = warning, 2 = error, 3 = failure, 4 = fatal); this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)   | 3                                                                 |
| CheckpointCompressMode | 0, 1                                                                  | if 1, checkpoint files are written in compressed format; this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)                                                                        | on (1)                                                            |
| CommandHistory         | any valid filename                                                    | sets the name of a file in which to store the Main window command history                                                                                                                                                | commented out ( ; )                                               |
| ConcurrentFileLimit    | any positive integer                                                  | controls the number of VHDL files open concurrently; this number should be less than the current limit setting for max file descriptors; 0 = unlimited                                                                   | 40                                                                |
| DatasetSeparator       | any character except those with special meaning (i.e., \, {, }, etc.) | the dataset separator for fully-rooted contexts, for example sim:/top; must not be the same character as PathSeparator                                                                                                   | :                                                                 |
| DefaultForceKind       | freeze, drive, or deposit                                             | defines the kind of force used when not otherwise specified; this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)                                                                    | drive for resolved signals;<br>freeze for unresolved signals      |
| DefaultRadix           | symbolic, binary, octal, decimal, unsigned, hexadecimal, ascii        | a numeric radix may be specified as a name or number (i.e., binary can be specified as binary or 2; octal as octal or 8; etc.); this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351) | symbolic                                                          |

| Variable name         | Value range                                                                                   | Purpose                                                                                                                                                          | Default          |
|-----------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| DefaultRestartOptions | one or more of:<br>-force,<br>-noassertions,<br>-nobreakpoint,<br>-nolist, -nolog,<br>-nowave | sets default behavior for the restart command                                                                                                                    | commented out (; |
| DelayFileOpen         | 0, 1                                                                                          | if 1, open VHDL87 files on first read or write, else open files when elaborated; this variable can be set interactively with the Tcl <b>set</b> command (UM-351) | off (0)          |
| GenerateFormat        | Any non-quoted string containing at a minimum a %s followed by a %d                           | controls the format of a generate statement label (don't quote it)                                                                                               | %s__%d           |
| IgnoreError           | 0,1                                                                                           | if 1, ignore assertion errors; this variable can be set interactively with the Tcl <b>set</b> command (UM-351)                                                   | off (0)          |
| IgnoreFailure         | 0,1                                                                                           | if 1, ignore assertion failures; this variable can be set interactively with the Tcl <b>set</b> command (UM-351)                                                 | off (0)          |
| IgnoreNote            | 0,1                                                                                           | if 1, ignore assertion notes; this variable can be set interactively with the Tcl <b>set</b> command (UM-351)                                                    | off (0)          |
| IgnoreWarning         | 0,1                                                                                           | if 1, ignore assertion warnings; this variable can be set interactively with the Tcl <b>set</b> command (UM-351)                                                 | off (0)          |
| IterationLimit        | positive integer                                                                              | limit on simulation kernel iterations allowed without advancing time; this variable can be set interactively with the Tcl <b>set</b> command (UM-351)            | 5000             |

| <b>Variable name</b> | <b>Value range</b>                                                    | <b>Purpose</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>Default</b>      |
|----------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| License              | any single <license_option>                                           | if set, controls ModelSim license file search; license options include:<br>nomgc - excludes MGC licenses<br>nomti - excludes MTI licenses<br>noqueue - do not wait in license queue if no licenses are available<br>plus - only use PLUS license<br>vlog - only use VLOG license<br>vhdl - only use VHDL license<br>viewsim - accepts a simulation license rather than being queued for a viewer license<br><br>see also the <a href="#">vsim</a> command (CR-213)<br><license_option> | search all licenses |
| NumericStdNoWarnings | 0, 1                                                                  | if 1, warnings generated within the accelerated numeric_std and numeric_bit packages are suppressed; this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)                                                                                                                                                                                                                                                                                          | off (0)             |
| PathSeparator        | any character except those with special meaning (i.e., \, {, }, etc.) | used for hierarchical pathnames; must not be the same character as DatasetSeparator; this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)                                                                                                                                                                                                                                                                                                          | /                   |
| Resolution           | fs, ps, ns, us, ms, or sec with optional prefix of 1, 10, or 100      | simulator resolution; no space between value and units (i.e., 10fs, not 10 fs); overridden by the -t argument to <a href="#">vsim</a> (CR-213); if your delays get truncated, set the resolution smaller; this value must be less than or equal to the UserTimeUnit (described below)                                                                                                                                                                                                  | ps                  |
| RunLength            | positive integer                                                      | default simulation length in units specified by the UserTimeUnit variable; this variable can be set interactively with the Tcl <a href="#">set</a> command (UM-351)                                                                                                                                                                                                                                                                                                                    | 100                 |
| Show3DMem            | 0, 1                                                                  | controls whether or not arrays of 3 or more dimensions are listed as memories in the Memory window; this variable can be set with the Tcl <a href="#">set</a> command (UM-351)                                                                                                                                                                                                                                                                                                         | on (1)              |
| ShowIntMem           | 0, 1                                                                  | controls whether or not integer arrays are listed as memories in the Memory window; this variable can be set with the Tcl <a href="#">set</a> command (UM-351)                                                                                                                                                                                                                                                                                                                         | on (1)              |

| Variable name       | Value range                                   | Purpose                                                                                                                                                                                                                                                                                                                     | Default          |
|---------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| ShowEnumMem         | 0, 1                                          | controls whether or not enumerated type arrays (other than std_logic-based arrays) are listed as memories in the Memory window; this variable can be set with the Tcl <b>set</b> command (UM-351)                                                                                                                           | on (1)           |
| Startup             | = do <DO filename>; any valid macro (do) file | specifies the ModelSim startup macro; see the <b>do</b> command (CR-75)                                                                                                                                                                                                                                                     | commented out (; |
| StdArithNoWarnings  | 0, 1                                          | if 1, warnings generated within the accelerated Synopsys std_arith packages are suppressed; this variable can be set interactively with the Tcl <b>set</b> command                                                                                                                                                          | off (0)          |
| TranscriptFile      | any valid filename                            | file for saving command transcript; environment variables may be included in the pathname                                                                                                                                                                                                                                   | transcript       |
| UnbufferedOutput    | 0, 1                                          | controls VHDL and Verilog files open for write; 0 = Buffered, 1 = Unbuffered                                                                                                                                                                                                                                                | 0                |
| UseCsupV2           | 0, 1                                          | instructs <b>vsim</b> to use <i>/usr/lib/libCsup_v2.sl</i> for shared object loading; for use only on HP-UX 11.00 when you have compiled FLI/PLI/VPI C++ code with aCC's -AA option                                                                                                                                         | off (0)          |
| UserTimeUnit        | fs, ps, ns, us, ms, sec, or default           | specifies scaling for the Wave window and the default time units to use for commands such as <b>force</b> (CR-90) and <b>run</b> (CR-133); should generally be set to default, in which case it takes the value of the Resolution variable; this variable can be set interactively with the Tcl <b>set</b> command (UM-351) | default          |
| Veriuser            | one or more valid shared object names         | list of dynamically loadable objects for Verilog PLI/VPI applications; see <i>Chapter 6 - Verilog PLI / VPI</i>                                                                                                                                                                                                             | commented out (; |
| WaveSignalNameWidth | 0, positive integer                           | controls the number of visible hierarchical regions of a signal name shown in the <b>Wave window</b> (UM-236); the default value of zero displays the full name, a setting of one or above displays the corresponding level(s) of hierarchy                                                                                 | 0                |
| WLFCompress         | 0, 1                                          | turns WLF file compression on (1) or off (0)                                                                                                                                                                                                                                                                                | 1                |

| <b>Variable name</b> | <b>Value range</b>                          | <b>Purpose</b>                                                                                                                                                                                                        | <b>Default</b> |
|----------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| WLFDeleteOnQuit      | 0, 1                                        | specifies whether a WLF file should be deleted when the simulation ends; if set to 0, the file is not deleted; if set to 1, the file is deleted                                                                       | 0              |
| WLFOptimize          | 0, 1                                        | specifies whether the viewing of waveforms is optimized; default is enabled; WLF files created prior to ModelSim version 5.8 cannot take advantage of the optimization                                                | 1              |
| WLFSaveAllRegions    | 0, 1                                        | specifies whether to save all design hierarchy in the WLF file (1) or only regions containing logged signals (0)                                                                                                      | 0              |
| WLFSIZELimit         | 0 - positive integer of MB                  | WLF file size limit; limits WLF file by size (as closely as possible) to the specified number of megabytes; if both size and time limits are specified the most restrictive is used; setting to 0 results in no limit | 0              |
| WLFTimeLimit         | 0 - positive integer, time unit is optional | WLF file time limit; limits WLF file by time (as closely as possible) to the specified amount of time. If both time and size limits are specified the most restrictive is used; setting to 0 results in no limit      | 0              |

## Commonly used INI variables

Several of the more commonly used *modelsim.ini* variables are further explained below.

### ***Environment variables***

You can use environment variables in your initialization files. Use a dollar sign (\$) before the environment variable name. For example:

```
[Library]
work = $HOME/work_lib
test_lib = ./TESTNUM/work
...
[vsim]
IgnoreNote = $IGNORE_ASSERTS
IgnoreWarning = $IGNORE_ASSERTS
IgnoreError = 0
IgnoreFailure = 0
```

There is one environment variable, MODEL\_TECH, that you cannot — and should not — set. MODEL\_TECH is a special variable set by Model Technology software. Its value is the name of the directory from which the VCOM or VLOG compilers or VSIM simulator was invoked. MODEL\_TECH is used by the other Model Technology tools to find the libraries.

### ***Hierarchical library mapping***

By adding an "others" clause to your *modelsim.ini* file, you can have a hierarchy of library mappings. If the ModelSim tools don't find a mapping in the *modelsim.ini* file, then they will search only the library section of the initialization file specified by the "others" clause. For example:

```
[Library]
asic_lib = /cae/asic_lib
work = my_work
others = /install_dir/modeltech/modelsim.ini
```

Since the file referred to by the "others" clause may itself contain an "others" clause, you can use this feature to chain a set of hierarchical INI files for library mappings.

### ***Creating a transcript file***

A feature in the system initialization file allows you to keep a record of everything that occurs in the transcript: error messages, assertions, commands, command outputs, etc. To do this, set the value for the TranscriptFile line in the *modelsim.ini* file to the name of the file in which you would like to record the ModelSim history.

```
; Save the command window contents to this file
TranscriptFile = trnscrpt
```

### ***Using a startup file***

The system initialization file allows you to specify a command or a *do* file that is to be executed after the design is loaded. For example:

```
; VSIM Startup command
Startup = do mystartup.do
```

The line shown above instructs ModelSim to execute the commands in the macro file named *mystartup.do*.

```
; VSIM Startup command
Startup = run -all
```

The line shown above instructs VSIM to run until there are no events scheduled.

See the [do](#) command (CR-75) for additional information on creating do files.

### ***Turning off assertion messages***

You can turn off assertion messages from your VHDL code by setting a switch in the *modelsim.ini* file. This option was added because some utility packages print a huge number of warnings.

```
[vsim]
IgnoreNote = 1
IgnoreWarning = 1
IgnoreError = 1
IgnoreFailure = 1
```

### ***Turning off warnings from arithmetic packages***

You can disable warnings from the Synopsys and numeric standard packages by adding the following lines to the [vsim] section of the *modelsim.ini* file.

```
[vsim]
NumericStdNoWarnings = 1
StdArithNoWarnings = 1
```

These variables can also be set interactively using the Tcl [set](#) command (UM-351). This capability provides an answer to a common question about disabling warnings at time 0. You might enter commands like the following in a DO file or at the ModelSim prompt:

```
set NumericStdNoWarnings 1
run 0
set NumericStdNoWarnings 0
run -all
```

Alternatively, you could use the [when](#) command (CR-228) to accomplish the same thing:

```
when {$now = @1ns } {set NumericStdNoWarnings 1}
run -all
```

Note that the time unit (ns in this case) would vary depending on your simulation resolution.

### **Force command defaults**

The **force** command has **-freeze**, **-drive**, and **-deposit** options. When none of these is specified, then **-freeze** is assumed for unresolved signals and **-drive** is assumed for resolved signals. This is designed to provide compatibility with force files. But if you prefer **-freeze** as the default for both resolved and unresolved signals, you can change the defaults in the *modelsim.ini* file.

```
[vsim]
; Default Force Kind
; The choices are freeze, drive, or deposit
DefaultForceKind = freeze
```

### **Restart command defaults**

The **restart** command has **-force**, **-nobreakpoint**, **-nolist**, **-nolog**, and **-nowave** options. You can set any of these as defaults by entering the following line in the *modelsim.ini* file:

```
DefaultRestartOptions = <options>
```

where *<options>* can be one or more of **-force**, **-nobreakpoint**, **-nolist**, **-nolog**, and **-nowave**.

Example: `DefaultRestartOptions = -nolog -force`

**Note:** You can also set these defaults in the *modelsim.tcl* file. The Tcl file settings will override the .ini file settings.

### **VHDL standard**

You can specify which version of the 1076 Std ModelSim follows by default using the **VHDL93** variable:

```
[vcom]
; VHDL93 variable selects language version as the default.
; Default is VHDL-2002.
; Value of 0 or 1987 for VHDL-1987.
; Value of 1 or 1993 for VHDL-1993.
; Default or value of 2 or 2002 for VHDL-2002.
VHDL93 = 2002
```

### **Opening VHDL files**

You can delay the opening of VHDL files with an entry in the *INI* file if you wish. Normally VHDL files are opened when the file declaration is elaborated. If the **DelayFileOpen** option is enabled, then the file is not opened until the first read or write to that file.

```
[vsim]
DelayFileOpen = 1
```

## Preference variables located in Tcl files

ModelSim Tcl preference variables give you control over fonts, colors, prompts, window positions and other simulator window characteristics. Preference files, which contain Tcl commands that set preference variables, are loaded before any windows are created, and so affect all windows.

When you invoke ModelSim the first time, it loads default preferences from the *pref.tcl* file. You can customize the preference variables and save a file called *modelsim.tcl* file that ModelSim reads in lieu of *pref.tcl*. Once you have created a *modelsim.tcl* file, ModelSim attempts to load the file each time it starts up. ModelSim searches for the file as follows:

- use **MODELSIM\_TCL** (UM-366) environment variable if it exists (if MODELSIM\_TCL is a list of files, each file is loaded in the order that it appears in the list); else
- use *./modelsim.tcl*; else
- use \$(HOME)/modelsim.tcl if it exists

**Important:** If your preference file is not named *modelsim.tcl*, or if the file is not located in the directories mentioned above, you must refer to it with the MODELSIM\_TCL environment variable.

## Setting variables from the GUI

Select **Tools > Edit Preferences** in the Main window to open the Preferences dialog box.



To change a setting, select the preference item and click **Change Value**. Click **Apply** to accept the settings for the current session only. Click **Save** to create a *modelsim.tcl* file with the current preference settings.

## More preferences

Additional compiler and simulator preferences may be set in the *modelsim.ini* file; see "[Preference variables located in INI files](#)" (UM-369).

## Variable precedence

Note that some variables can be set in a .tcl file or a .ini file. A variable set in a .tcl file takes precedence over the same variable set in a .ini file. For example, assume you have the following line in your *modelsim.ini* file:

```
TranscriptFile = transcript
```

And assume you have the following line in your *modelsim.tcl* file:

```
set PrefMain(file) {}
```

In this case the setting in the *modelsim.tcl* file will override that in the *modelsim.ini* file, and a transcript file will not be produced.

## Simulator state variables

Unlike other variables that must be explicitly set, simulator state variables return a value relative to the current simulation. Simulator state variables can be useful in commands, especially when used within ModelSim DO files (macros). The variables are referenced in commands by prefixing the name with a dollar sign (\$).

| Variable          | Result                                                                                                                                                                                                                                                                                                                                  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| argc              | returns the total number of parameters passed to the current macro                                                                                                                                                                                                                                                                      |
| architecture      | returns the name of the top-level architecture currently being simulated; for a configuration or Verilog module, this variable returns an empty string                                                                                                                                                                                  |
| configuration     | returns the name of the top-level configuration currently being simulated; returns an empty string if no configuration                                                                                                                                                                                                                  |
| delta             | returns the number of the current simulator iteration                                                                                                                                                                                                                                                                                   |
| entity            | returns the name of the top-level VHDL entity or Verilog module currently being simulated                                                                                                                                                                                                                                               |
| library           | returns the library name for the current region                                                                                                                                                                                                                                                                                         |
| MacroNestingLevel | returns the current depth of macro call nesting                                                                                                                                                                                                                                                                                         |
| n                 | represents a macro parameter, where n can be an integer in the range 1-9                                                                                                                                                                                                                                                                |
| Now               | always returns the current simulation time with time units (e.g., 110,000 ns) Note: will return a comma between thousands                                                                                                                                                                                                               |
| now               | when time resolution is a unary unit (i.e., 1ns, 1ps, 1fs): returns the current simulation time without time units (e.g., 100000)<br>when time resolution is a multiple of the unary unit (i.e., 10ns, 100ps, 10fs): returns the current simulation time with time units (e.g. 110000 ns) Note: will not return comma between thousands |
| resolution        | returns the current simulation time resolution                                                                                                                                                                                                                                                                                          |

### Referencing simulator state variables

Variable values may be referenced in simulator commands by preceding the variable name with a dollar sign (\$). For example, to use the **now** and **resolution** variables in an **echo** command type:

```
echo "The time is $now $resolution."
```

Depending on the current simulator state, this command could result in:

```
The time is 12390 ps 10ps.
```

If you do not want the dollar sign to denote a simulator variable, precede it with a "\". For example, \\$now will not be interpreted as the current simulator time.

## Special considerations for the now variable

For the **when** command (CR-228), special processing is performed on comparisons involving the **now** variable. If you specify "when {\$now=100}...", the simulator will stop at time 100 regardless of the multiplier applied to the time resolution.

You must use 64-bit time operators if the time value of **now** will exceed 2147483647 (the limit of 32-bit numbers). For example:

```
if { [gtTime $now 2us] } {  
    .  
    .  
    .
```

See "[ModelSim Tcl time commands](#)" (UM-355) for details on 64-bit time operators.

**UM-386** A - ModelSim variables

## B - ModelSim shortcuts

---

### Appendix contents

|                                                                     |           |        |
|---------------------------------------------------------------------|-----------|--------|
| <a href="#">Command shortcuts</a>                                   | . . . . . | UM-387 |
| <a href="#">Command history shortcuts</a>                           | . . . . . | UM-388 |
| <a href="#">Main and Source window mouse and keyboard shortcuts</a> | . . . . . | UM-389 |
| <a href="#">List window keyboard shortcuts</a>                      | . . . . . | UM-391 |
| <a href="#">Wave window mouse and keyboard shortcuts</a>            | . . . . . | UM-392 |
| <a href="#">Right mouse button</a>                                  | . . . . . | UM-393 |

This appendix is a collection of the keyboard and command shortcuts available in the ModelSim GUI.

## Command shortcuts

- You may abbreviate command syntax, but there's a catch — the minimum number of characters required to execute a command are those that make it unique. Remember, as we add new commands some of the old shortcuts may not work.
- Multiple commands may be entered on one line if they are separated by semi-colons (;). For example:

```
vlog -nodebug=ports level3.v level2.v ; vlog -nodebug top.v
```

The return value of the last function executed is the only one printed to the transcript. This may cause some unexpected behavior in certain circumstances. Consider this example:

```
vsim -c -do "run 20 ; simstats ; quit -f" top
```

You probably expect the **simstats** results to display in the Transcript window, but they will not, because the last command is **quit -f**. To see the return values of intermediate commands, you must explicitly print the results. For example:

```
vsim -do "run 20 ; echo [simstats]; quit -f" -c top
```

## Command history shortcuts

The simulator command history may be reviewed, or commands may be reused, with these shortcuts at the ModelSim/VSIM prompt:

| Shortcut           | Description                                                                                                                           |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| up and down arrows | scrolls through the command history with the keyboard arrows                                                                          |
| click on prompt    | left-click once on a previous ModelSim or VSIM prompt in the transcript to copy the command typed at that prompt to the active cursor |
| his or history     | shows the last few commands (up to 50 are kept)                                                                                       |

## Main and Source window mouse and keyboard shortcuts

The following mouse actions and special keystrokes can be used to edit commands in the entry region of the Main window. They can also be used in editing the file displayed in the Source window and all Notepad windows (enter the **notepad** command within ModelSim to open the Notepad editor).

| Keystrokes                                    | Result                                                                             |
|-----------------------------------------------|------------------------------------------------------------------------------------|
| < left   right - arrow >                      | move the cursor left   right one character                                         |
| < up   down - arrow >                         | scroll through command history (in Source window, move cursor one line up   down)  |
| < control >< left   right - arrow >           | move cursor left   right one word                                                  |
| < shift >< left   right   up   down - arrow > | extend selection of text                                                           |
| < control >< shift >< left   right - arrow >  | extend selection of text by word                                                   |
| < up   down - arrow >                         | scroll through command history (in Source window, moves cursor one line up   down) |
| < control >< up   down >                      | move cursor up   down one paragraph                                                |
| < alt >                                       | activate or inactivate menu bar mode                                               |
| < alt >< F4 >                                 | close active window                                                                |
| < backspace >                                 | delete character to the left                                                       |
| < home >                                      | move cursor to the beginning of the line                                           |
| < end >                                       | move cursor to the end of the line                                                 |
| < control >< home >                           | move cursor to the beginning of the text                                           |
| < control >< end >                            | move cursor to the end of the text                                                 |
| < esc >                                       | cancel                                                                             |
| < control - a >                               | select the entire content of the widget                                            |
| < control - c >                               | copy the selection                                                                 |
| < control - f >                               | find                                                                               |
| < F3 >                                        | find next                                                                          |
| < control - k >                               | delete from the cursor to the end of the line                                      |
| < control - s >                               | save                                                                               |
| < control - t >                               | reverse the order of the two characters to the right of the cursor                 |
| < control - u >                               | delete line                                                                        |

| <b>Keystrokes</b> | <b>Result</b>                                                        |
|-------------------|----------------------------------------------------------------------|
| < control - v >   | paste from the clipboard                                             |
| < control - x >   | cut the selection                                                    |
| < F8 >            | search for the most recent command that matches the characters typed |
| < F9 >            | run simulation                                                       |
| < F10 >           | continue simulation                                                  |
| < F11 >           | single-step                                                          |
| < F12 >           | step-over                                                            |

The Main window allows insertions or pastes only after the prompt; therefore, you don't need to set the cursor when copying strings to the command line.

## List window keyboard shortcuts

Using the following keys when the mouse cursor is within the List window will cause the indicated actions:

| Key                                       | Action                                                                                                          |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| <left arrow>                              | scroll listing left (selects and highlights the item to the left of the currently selected item)                |
| <right arrow>                             | scroll listing right (selects and highlights the item to the right of the currently selected item)              |
| <up arrow>                                | scroll listing up                                                                                               |
| <down arrow>                              | scroll listing down                                                                                             |
| <page up><br><control-up arrow>           | scroll listing up by page                                                                                       |
| <page down><br><control-down arrow>       | scroll listing down by page                                                                                     |
| <tab>                                     | searches forward (down) to the next transition on the selected signal                                           |
| <shift-tab>                               | searches backward (up) to the previous transition on the selected signal (does not function on HP workstations) |
| <shift-left arrow><br><shift-right arrow> | extends selection left/right                                                                                    |
| <control-f>                               | opens the Find dialog box to find the specified item label within the list display                              |

## Wave window mouse and keyboard shortcuts

The following mouse actions and keystrokes can be used in the Wave window.

| Mouse action                                                              | Result                                                                                         |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| < control - left-button - drag down and right> <sup>a</sup>               | zoom area (in)                                                                                 |
| < control - left-button - drag up and right>                              | zoom out                                                                                       |
| < control - left-button - drag up and left>                               | zoom fit                                                                                       |
| <left-button - drag> (Select mode)<br>< middle-button - drag> (Zoom mode) | moves closest cursor                                                                           |
| < control - left-button - click on a scroll arrow >                       | scrolls window to very top or bottom(vertical scroll) or far left or right (horizontal scroll) |

- a. If you enter zoom mode by selecting **View > Mouse Mode > Zoom Mode**, you do not need to hold down the <Ctrl> key.

| Keystroke                   | Action                                                                                                                                             |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| i I or +                    | zoom in (mouse pointer must be over the the cursor or waveform panes)                                                                              |
| o O or -                    | zoom out (mouse pointer must be over the the cursor or waveform panes)                                                                             |
| f or F                      | zoom full (mouse pointer must be over the the cursor or waveform panes)                                                                            |
| l or L                      | zoom last (mouse pointer must be over the the cursor or waveform panes)                                                                            |
| r or R                      | zoom range (mouse pointer must be over the the cursor or waveform panes)                                                                           |
| <up arrow>/<br><down arrow> | with mouse over waveform pane, scrolls entire window up/down one line; with mouse over pathname or values pane, scrolls highlight up/down one line |
| <left arrow>                | scroll pathname, values, or waveform pane left                                                                                                     |
| <right arrow>               | scroll pathname, values, or waveform pane right                                                                                                    |
| <page up>                   | scroll waveform pane up by a page                                                                                                                  |
| <page down>                 | scroll waveform pane down by a page                                                                                                                |

| Keystroke             | Action                                                                                                        |
|-----------------------|---------------------------------------------------------------------------------------------------------------|
| <tab>                 | search forward (right) to the next transition on the selected signal - finds the next edge                    |
| <shift-tab>           | search backward (left) to the previous transition on the selected signal - finds the previous edge            |
| <control-f>           | open the find dialog box; searches within the specified field in the pathname or values pane for text strings |
| <control-left arrow>  | scroll pathname, values, or waveform pane left by a page                                                      |
| <control-right arrow> | scroll pathname, values, or waveform pane right by a page                                                     |

## Right mouse button

The right mouse button provides shortcut menus in the most windows. See *Chapter 8 - Graphic interface* for menu descriptions.



# C - ModelSim messages

---

## Appendix contents

|                                             |        |
|---------------------------------------------|--------|
| ModelSim message system . . . . .           | UM-396 |
| Message format . . . . .                    | UM-396 |
| Getting more information . . . . .          | UM-396 |
| Suppressing warning messages . . . . .      | UM-397 |
| Suppressing VCOM warning messages . . . . . | UM-397 |
| Suppressing VLOG warning messages . . . . . | UM-397 |
| Suppressing VSIM warning messages . . . . . | UM-397 |
| Exit codes . . . . .                        | UM-398 |
| Miscellaneous messages . . . . .            | UM-400 |
| Empty port name warning . . . . .           | UM-400 |
| Lock message . . . . .                      | UM-400 |
| Metavalue detected warning . . . . .        | UM-400 |
| Sensitivity list warning . . . . .          | UM-401 |
| Tcl Initialization error 2 . . . . .        | UM-401 |
| Too few port connections . . . . .          | UM-402 |
| VSIM license lost . . . . .                 | UM-403 |

This appendix documents various status and warning messages that are produced by ModelSim.

## ModelSim message system

The ModelSim message system helps you identify and troubleshoot problems while using the application. The messages display in a standard format in the Main window transcript. Accordingly, you can also access them from a saved transcript file (see "[Saving the Main window transcript file](#)" (UM-165) for more details).

### Message format

The format for the messages is:

```
** <SEVERITY LEVEL>: ([ <Tool>[-<Group>]]-<MsgNum>) <Message>
```

**SEVERITY LEVEL** may be one of the following:

| severity level | meaning                                                                   |
|----------------|---------------------------------------------------------------------------|
| Note           | This is an informational message.                                         |
| Warning        | There may be a problem that will affect the accuracy of your results.     |
| Error          | The tool cannot complete the operation.                                   |
| Fatal          | The tool cannot complete execution.                                       |
| INTERNAL ERROR | This is an unexpected error that should be reported to support@model.com. |

**Tool** indicates which ModelSim tool was being executed when the message was generated. For example tool could be **vcom**, **ydel**, **vsim**, etc.

**Group** indicates the topic to which the problem is related. For example group could be FLI, PLI, VCD, etc.

### Example

```
# ** Error: (vsim-PLI-3071) ./src/19/testfile(77): $fdumplimit : Too few arguments.
```

### Getting more information

Each message is identified by a unique MsgNum id. You can access additional information about a message using the unique id and the **verror** (CR-176) command. For example:

```
% verror 3071
Message # 3071:
Not enough arguments are being passed to the specified system task or function.
```

## Suppressing warning messages

You can suppress some warning messages. For example, you may receive warning messages about unbound components about which you are not concerned.

### Suppressing VCOM warning messages

Use the `-nowarn <number>` argument to **vcom** (CR-167) to suppress a specific warning message. For example:

```
vcom -nowarn 1
      Suppresses unbound component warning messages.
```

Alternatively, warnings may be disabled for all compiles via the *modelsim.ini* file (see "[\[vcom\] VHDL compiler control variables](#)" (UM-370)).

The warning message numbers are:

|    |                                          |
|----|------------------------------------------|
| 1  | = unbound component                      |
| 2  | = process without a wait statement       |
| 3  | = null range                             |
| 4  | = no space in time literal               |
| 5  | = multiple drivers on unresolved signal  |
| 6  | = compliance checks                      |
| 7  | = optimization messages                  |
| 8  | = lint checks                            |
| 9  | = signal value dependency at elaboration |
| 10 | = VHDL93 constructs in VHDL87 code       |

### Suppressing VLOG warning messages

Use the `+nowarn<CODE>` argument to **vlog** (CR-204) to suppress a specific warning message. Warnings that can be disabled include the <CODE> name in square brackets in the warning message. For example:

```
vlog +nowarnDECAY
      Suppresses decay warning messages.
```

### Suppressing VSIM warning messages

Use the `+nowarn<CODE>` argument to **vsim** (CR-213) to suppress a specific warning message. Warnings that can be disabled include the <CODE> name in square brackets in the warning message. For example:

```
vsim +nowarnTFMPC
      Suppresses warning messages about too few port connections.
```

## Exit codes

The table below describes exit codes used by ModelSim tools.

| Exit code | Description                                                                                            |
|-----------|--------------------------------------------------------------------------------------------------------|
| 0         | Normal (non-error) return                                                                              |
| 1         | Incorrect invocation of tool                                                                           |
| 2         | Previous errors prevent continuing                                                                     |
| 3         | Cannot create a system process (execv, fork, spawn, etc.)                                              |
| 4         | Licensing problem                                                                                      |
| 5         | Cannot create/open/find/read/write a design library                                                    |
| 6         | Cannot create/open/find/read/write a design unit                                                       |
| 7         | Cannot open/read/write/dup a file (open, lseek, write, mmap, munmap, fopen, fdopen, fread, dup2, etc.) |
| 8         | File is corrupted or incorrect type, version, or format of file                                        |
| 9         | Memory allocation error                                                                                |
| 10        | General language semantics error                                                                       |
| 11        | General language syntax error                                                                          |
| 12        | Problem during load or elaboration                                                                     |
| 13        | Problem during restore                                                                                 |
| 14        | Problem during refresh                                                                                 |
| 15        | Communication problem (Cannot create/read/write/close pipe/socket)                                     |
| 16        | Version incompatibility                                                                                |
| 19        | License manager not found/unreadable/unexecutable (vlm/mgvlm)                                          |
| 42        | Lost license                                                                                           |
| 43        | License read/write failure                                                                             |
| 44        | Modeltech daemon license checkout failure #44                                                          |
| 45        | Modeltech daemon license checkout failure #45                                                          |
| 90        | Assertion failure (SEVERITY_QUIT)                                                                      |
| 99        | Unexpected error in tool                                                                               |
| 100       | GUI Tcl initialization failure                                                                         |
| 101       | GUI Tk initialization failure                                                                          |

| <b>Exit code</b> | <b>Description</b>                              |
|------------------|-------------------------------------------------|
| 102              | GUI IncrTk initialization failure               |
| 111              | X11 display error                               |
| 202              | Interrupt (SIGINT)                              |
| 204              | Illegal instruction (SIGILL)                    |
| 205              | Trace trap (SIGTRAP)                            |
| 206              | Abort (SIGABRT)                                 |
| 208              | Floating point exception (SIGFPE)               |
| 210              | Bus error (SIGBUS)                              |
| 211              | Segmentation violation (SIGSEGV)                |
| 213              | Write on a pipe with no reader (SIGPIPE)        |
| 214              | Alarm clock (SIGALRM)                           |
| 215              | Software termination signal from kill (SIGTERM) |
| 216              | User-defined signal 1 (SIGUSR1)                 |
| 217              | User-defined signal 2 (SIGUSR2)                 |
| 218              | Child status change (SIGCHLD)                   |
| 230              | Exceeded CPU limit (SIGXCPU)                    |
| 231              | Exceeded file size limit (SIGXFSZ)              |

## Miscellaneous messages

This section describes miscellaneous messages which may be associated with ModelSim.

### Empty port name warning

#### *Message text*

```
# ** WARNING: [8] <path/file_name>:  
empty port name in port list.
```

#### *Meaning*

ModelSim reports these warnings if you use the **-lint** argument to **vlog** (CR-204). It reports the warning for any NULL module ports.

#### *Suggested action*

If you wish to ignore this warning, do not use the **-lint** argument.

### Lock message

#### *Message text*

```
waiting for lock by user@user. Lockfile is <library_path>/_lock
```

#### *Meaning*

The `_lock` file is created in a library when you begin a compilation into that library, and it is removed when the compilation completes. This prevents simultaneous updates to the library. If a previous compile did not terminate properly, ModelSim may fail to remove the `_lock` file.

#### *Suggested action*

Manually remove the `_lock` file after making sure that no one else is actually using that library.

### Metavalue detected warning

#### *Message text*

```
Warning: NUMERIC_STD.">": metavalue detected, returning FALSE
```

#### *Meaning*

This warning is an assertion being issued by the IEEE **numeric\_std** package. It indicates that there is an 'X' in the comparison.

#### *Suggested action*

The message does not indicate which comparison is reporting the problem since the assertion is coming from a standard package. To track the problem, note the time the warning occurs, restart the simulation, and run to one time unit before the noted time. At this point, start stepping the simulator until the warning appears. The location of the blue

arrow in the source window will be pointing at the line following the line with the comparison.

These messages can be turned off by setting the **NumericStdNoWarnings** variable to 1 from the command line or in the *modelsim.ini* file.

## Sensitivity list warning

### **Message text**

```
signal is read by the process but is not in the sensitivity list
```

### **Meaning**

ModelSim outputs this message when you use the **-check\_synthesis** argument to **vcom** (CR-167). It reports the warning for any signal that is read by the process but is not in the sensitivity list.

### **Suggested action**

There are cases where you may purposely omit signals from the sensitivity list even though they are read by the process. For example, in a strictly sequential process, you may prefer to include only the clock and reset in the sensitivity list because it would be a design error if any other signal triggered the process. In such cases, your only option as of version 5.7 is to not use the **-check\_synthesis** argument. A more robust implementation of the argument may be added to a future version.

## Tcl Initialization error 2

### **Message text**

```
Tcl_Init Error 2 : Can't find a usable Init.tcl in the following directories :
      ./. . /tcl/tcl8.3 .
```

### **Meaning**

This message typically occurs when the base file was not included in a Unix installation. When you install ModelSim, you need to download and install 3 files from the ftp site. These files are:

- modeltech-base.tar.gz
- modeltech-docs.tar.gz
- modeltech-<platform>.exe.gz

If you install only the <platform> file, you will not get the Tcl files that are located in the base file.

This message could also occur if the file or directory was deleted or corrupted.

### **Suggested action**

Reinstall ModelSim with all three files.

## Too few port connections

### *Message text*

```
# ** Warning (vsim-3017): foo.v(1422): [TFMPC] - Too few port connections.
Expected 2, found 1.
# Region: /foo/tb
```

### *Meaning*

This warning occurs when an instantiation has fewer port connections than the corresponding module definition. The warning doesn't necessarily mean anything is wrong; it is legal in Verilog to have an instantiation that doesn't connect all of the pins. However, someone that expects all pins to be connected would like to see such a warning.

Here are some examples of legal instantiations that will and will not cause the warning message.

Module definition:

```
module foo (a, b, c, d);
```

Instantiation that does not connect all pins but will not produce the warning:

```
foo inst1(e, f, g, ); - positional association
foo inst1(.a(e), .b(f), .c(g), .d()); - named association
```

Instantiation that does not connect all pins but will produce the warning:

```
foo inst1(e, f, g); - positional association
foo inst1(.a(e), .b(f), .c(g)); - named association
```

Any instantiation above will leave pin *d* unconnected but the first example has a placeholder for the connection. Here's another example:

```
foo inst1(e, , g, h);
foo inst1(.a(e), .b(), .c(g), .d(h));
```

### *Suggested actions*

- Check that there is not an extra comma at the end of the port list. (e.g., model(a,b,) ). The extra comma is legal Verilog and implies that there is a third port connection that is unnamed.
- If you are purposefully leaving pins unconnected, you can disable these messages using the +nowarnTFMPC argument to vsim.

## VSIM license lost

### ***Message text***

```
Console output:  
Signal 0 caught... Closing vsim vlm child.  
vsim is exiting with code 4  
FATAL ERROR in license manager  
  
transcript/vsim output:  
# ** Error: VSIM license lost; attempting to re-establish.  
#     Time: 5027 ns  Iteration: 2  
# ** Fatal: Unable to kill and restart license process.  
#     Time: 5027 ns  Iteration: 2
```

### ***Meaning***

ModelSim queries the license server for a license at regular intervals. Usually these "License Lost" error messages indicate that network traffic is high, and communication with the license server times out.

### ***Suggested action***

Anything you can do to improve network communication with the license server will probably solve or decrease the frequency of this problem.

**UM-404** C - ModelSim messages

## D - System initialization

---

### Appendix contents

|                                                               |        |
|---------------------------------------------------------------|--------|
| <a href="#">Files accessed during startup</a>                 | UM-406 |
| <a href="#">Environment variables accessed during startup</a> | UM-407 |
| <a href="#">Initialization sequence</a>                       | UM-408 |

ModelSim goes through numerous steps as it initializes the system during startup. It accesses various files and environment variables to determine library mappings, configure the GUI, check licensing, and so forth.

## Files accessed during startup

The table below describes the files that are read during startup. They are listed in the order in which they are accessed.

| File                        | Purpose                                                                                                                                                                                                                                                 |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>modelsim.ini</i>         | contains initial tool settings; see " <a href="#">Preference variables located in INI files</a> " (UM-369) for specific details on the <i>modelsim.ini</i> file                                                                                         |
| location map file           | used by ModelSim tools to find source files based on easily reallocated "soft" paths; default file name is mgc_location_map                                                                                                                             |
| <i>pref.tcl</i>             | contains defaults for fonts, colors, prompts, window positions, and other simulator window characteristics; see " <a href="#">Preference variables located in Tcl files</a> " (UM-381) for specific details on the <i>pref.tcl</i> file                 |
| <i>modelsim.tcl</i>         | contains user-customized settings for fonts, colors, prompts, window positions, and other simulator window characteristics; see " <a href="#">Preference variables located in Tcl files</a> " (UM-381) for more details on the <i>modelsim.tcl</i> file |
| < <i>project_name</i> >.mpf | if available, loads last project file which is specified in the registry (Windows); see " <a href="#">What are projects?</a> " (UM-22) for details on project settings                                                                                  |

## Environment variables accessed during startup

The table below describes the environment variables that are read during startup. They are listed in the order in which they are accessed. For more information on environment variables, see "[Environment variables](#)" (UM-365).

| Environment variable | Purpose                                                                                                                                                                                                  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODEL_TECH           | set by ModelSim to the directory in which the binary executables reside (e.g., <code>../modeltech/&lt;platform&gt;/</code> )                                                                             |
| MODEL_TECH_OVERRIDE  | provides an alternative directory for the binary executables; MODEL_TECH is set to this path                                                                                                             |
| MODELSIM             | identifies the pathname of the <code>modelsim.ini</code> file                                                                                                                                            |
| MGC_WD               | identifies the Mentor Graphics working directory                                                                                                                                                         |
| MGC_LOCATION_MAP     | identifies the pathname of the location map file; set by ModelSim if not defined                                                                                                                         |
| MODEL_TECH_TCL       | identifies the pathname of all Tcl libraries installed with ModelSim                                                                                                                                     |
| HOME                 | identifies your login directory (UNIX only)                                                                                                                                                              |
| MGC_HOME             | identifies the pathname of the MGC tool suite                                                                                                                                                            |
| TCL_LIBRARY          | identifies the pathname of the Tcl library; set by ModelSim to the same pathname as MODEL_TECH_TCL; must point to libraries supplied by Model Technology                                                 |
| TK_LIBRARY           | identifies the pathname of the Tk library; set by ModelSim to the same pathname as MODEL_TECH_TCL; must point to libraries supplied by Model Technology                                                  |
| ITCL_LIBRARY         | identifies the pathname of the [incr]Tcl library; set by ModelSim to the same path as MODEL_TECH_TCL; must point to libraries supplied by Model Technology                                               |
| ITK_LIBRARY          | identifies the pathname of the [incr]Tk library; set by ModelSim to the same pathname as MODEL_TECH_TCL; must point to libraries supplied by Model Technology                                            |
| VSIM_LIBRARY         | identifies the pathname of the Tcl files that are used by ModelSim; set by ModelSim to the same pathname as MODEL_TECH_TCL; must point to libraries supplied by Model Technology                         |
| MTI_COSIM_TRACE      | creates an <code>mti_trace_cosim</code> file containing debugging information about FLI/PLI/VPI function calls; set to any value before invoking the simulator.                                          |
| MTI_LIB_DIR          | identifies the path to all Tcl libraries installed with ModelSim                                                                                                                                         |
| MODELSIM_TCL         | identifies the pathname of user-customized GUI preferences (e.g., <code>C:\modeltech\modelsim.tcl</code> ; this environment variable can be a list of file pathnames, separated by semicolons (Windows)) |

## Initialization sequence

The following list describes in detail ModelSim's initialization sequence. The sequence includes a number of conditional structures, the results of which are determined by the existence of certain files and the current settings of environment variables.

In the steps below, names in uppercase denote environment variables (except MTI\_LIB\_DIR which is a Tcl variable). Instances of `$(NAME)` denote paths that are determined by an environment variable (except `$(MTI_LIB_DIR)` which is determined by a Tcl variable).

- 1** Determines the path to the executable directory (`../modeltech/<platform>/`). Sets MODEL\_TECH to this path, *unless* MODEL\_TECH\_OVERRIDE exists, in which case MODEL\_TECH is set to the same value as MODEL\_TECH\_OVERRIDE.
- 2** Finds the `modelsim.ini` file by evaluating the following conditions:
  - use MODELSIM if it exists; else
  - use `$(MGC_WD)/modelsim.ini`; else
  - use `./modelsim.ini`; else
  - use `$(MODEL_TECH)/modelsim.ini`; else
  - use `$(MODEL_TECH)/../modelsim.ini`; else
  - use `$(MGC_HOME)/lib/modelsim.ini`; else
  - set path to `./modelsim.ini` even though the file doesn't exist
- 3** Finds the location map file by evaluating the following conditions:
  - use MGC\_LOCATION\_MAP if it exists (if this variable is set to "no\_map", ModelSim skips initialization of the location map); else
  - use `mgc_location_map` if it exists; else
  - use `$(HOME)/mgc/mgc_location_map`; else
  - use `$(HOME)/mgc_location_map`; else
  - use `$(MGC_HOME)/etc/mgc_location_map`; else
  - use `$(MGC_HOME)/shared/etc/mgc_location_map`; else
  - use `$(MODEL_TECH)/mgc_location_map`; else
  - use `$(MODEL_TECH)/../mgc_location_map`; else
  - use no map
- 4** Reads various variables from the [vsim] section of the `modelsim.ini` file. See "[\[vsim\] simulator control variables](#)" (UM-372) for more details.
- 5** Parses any command line arguments that were included when you started ModelSim and reports any problems.
- 6** Defines the following environment variables:
  - use MODEL\_TECH\_TCL if it exists; else

- set MODEL\_TECH\_TCL=\$(MODEL\_TECH)/../*tcl*
- set TCL\_LIBRARY=\$(MODEL\_TECH\_TCL)/*tcl8.3*
- set TK\_LIBRARY=\$(MODEL\_TECH\_TCL)/*tk8.3*
- set ITCL\_LIBRARY=\$(MODEL\_TECH\_TCL)/*itcl3.0*
- set ITK\_LIBRARY=\$(MODEL\_TECH\_TCL)/*itk3.0*
- set VSIM\_LIBRARY=\$(MODEL\_TECH\_TCL)/*vsim*

**7** Initializes the simulator's Tcl interpreter.

**8** Checks for a valid license (a license is not checked out unless specified by a *modelsim.ini* setting or command line option).

The next four steps relate to initializing the graphical user interface.

**9** Sets Tcl variable MTI\_LIB\_DIR=\$(MODEL\_TECH\_TCL)

**10** Loads \$(MTI\_LIB\_DIR)/*vsim/pref.tcl*.

**11** Finds the *modelsim.tcl* file by evaluating the following conditions:

- use MODELSIM\_TCL environment variable if it exists (if MODELSIM\_TCL is a list of files, each file is loaded in the order that it appears in the list); else
- use ./*modelsim.tcl*; else
- use \$(HOME)/*modelsim.tcl* if it exists

**12** Loads last working directory, project file, and printer defaults from the registry (Windows).

That completes the initialization sequence. Also note the following about the *modelsim.ini* file:

- When you change the working directory within ModelSim, the tool reads the [library], [vcom], and [vlog] sections of the local *modelsim.ini* file. When you make changes in the compiler options dialog or use the **vmap** command, the tool updates the appropriate sections of the file.
- The *pref.tcl* file references the default .ini file via the [GetPrivateProfileString] Tcl command. The .ini file that is read will be the default file defined at the time *pref.tcl* is loaded.



# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

## Index

---

*CR = Command Reference, UM = User's Manual*

### Symbols

- #, comment character [UM-350](#)
- +typdelays [CR-208](#)
- .so, shared object file
  - loading PLI/VPI C applications [UM-121](#)
  - loading PLI/VPI C++ applications [UM-122](#)
- ;{} [CR-12](#)
- 'hasX, hasX [CR-22](#)

### Numerics

- 1076, IEEE Std [UM-16](#)
  - differences between versions [UM-60](#)
- 1364, IEEE Std [UM-16](#), [UM-84](#)
- 2001, keywords, disabling [CR-208](#)
- 64-bit time
  - now variable [UM-385](#)
  - Tcl time commands [UM-355](#)

### A

- abort command [CR-36](#)
- absolute time, using @ [CR-15](#)
- ACC routines [UM-132](#)
- accelerated packages [UM-52](#)
- add list command [CR-38](#)
- add wave command [CR-41](#)
- alias command [CR-45](#)
- analog
  - signal formatting [UM-249](#)
  - supported signal types [UM-249](#)
- analog, signal formatting [CR-41](#)
- annotating interconnect delays, v2k\_int\_delays [CR-224](#)
- architecture simulator state variable [UM-384](#)
- archives
  - described [UM-45](#)
- archives, library [CR-203](#)
- argc simulator state variable [UM-384](#)
- arguments
  - passing to a DO file [UM-359](#)
- arithmetic package warnings, disabling [UM-379](#)
- arrays
  - indexes [CR-10](#)
  - slices [CR-10](#), [CR-12](#)
- AssertFile .ini file variable [UM-372](#)
- AssertionFormat .ini file variable [UM-372](#)

- AssertionFormatBreak .ini file variable [UM-372](#)
- AssertionFormatError .ini file variable [UM-372](#)
- AssertionFormatFail .ini file variable [UM-373](#)
- AssertionFormatFatal .ini file variable [UM-373](#)
- AssertionFormatNote .ini file variable [UM-372](#)
- AssertionFormatWarning .ini file variable [UM-372](#)
- assertions
  - configuring from the GUI [UM-282](#)
  - file and line number [UM-372](#)
  - messages
    - turning off [UM-379](#)
    - selecting severity that stops simulation [UM-282](#)
    - setting format of messages [UM-372](#)
    - testing for with onbreak command [CR-116](#)
    - warnings, locating [UM-372](#)
  - attributes, of signals, using in expressions [CR-22](#)

### B

- bad magic number error message [UM-143](#)
- balloon dialog, toggling on/off [UM-252](#)
- base (radix), specifying in List window [UM-192](#)
- base (radix), specifying in Memory window [UM-205](#)
- batch\_mode command [CR-46](#)
- batch-mode simulations [UM-15](#)
  - halting [CR-231](#)
- bd (breakpoint delete) command [CR-47](#)
- binding, VHDL, default [UM-51](#)
- blocking assignments [UM-98](#)
- bookmark add wave command [CR-48](#)
- bookmark delete wave command [CR-49](#)
- bookmark goto wave command [CR-50](#)
- bookmark list wave command [CR-51](#)
- bookmarks [UM-258](#)
- bp (breakpoint) command [CR-52](#)
- brackets, escaping [CR-12](#)
- break
  - on assertion [UM-282](#)
  - on signal value [CR-228](#)
- BreakOnAssertion .ini file variable [UM-373](#)
- breakpoints
  - conditional [CR-228](#), [UM-222](#)
  - continuing simulation after [CR-133](#)
  - deleting [CR-47](#), [UM-228](#), [UM-284](#)
  - listing [CR-52](#)
  - setting [CR-52](#), [UM-228](#)
  - signal breakpoints (when statements) [CR-228](#), [UM-](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- 222  
 Source window, viewing in [UM-224](#)  
 time-based [UM-222](#)  
     in when statements [CR-232](#)  
 .bsm file [UM-184](#)  
 buffered/unbuffered output [UM-376](#)  
 busses  
     escape characters in [CR-12](#)  
     RTL-level, reconstructing [UM-151](#)  
     user-defined [CR-42](#), [UM-193](#), [UM-244](#)
- C**
- C applications  
     compiling and linking [UM-121](#)  
 C++ applications  
     compiling and linking [UM-122](#)  
 case choice, must be locally static [CR-169](#)  
 case sensitivity  
     VHDL vs. Verilog [CR-13](#)  
 causality, tracing in Dataflow window [UM-178](#)  
 cd (change directory) command [CR-55](#)  
 cell libraries [UM-103](#)  
 cells  
     hiding in Dataflow window [UM-185](#), [UM-186](#)  
 change command [CR-56](#)  
 change directory, disabled [UM-166](#)  
 chasing X [UM-179](#)  
 -check\_synthesis argument [CR-168](#)  
 CheckpointCompressMode .ini file variable [UM-373](#)  
 CheckSynthesis .ini file variable [UM-370](#)  
 clock change, sampling signals at [UM-197](#)  
 columns  
     hide/showing in GUI [UM-159](#)  
     sorting by [UM-159](#)  
 combining signals, busses [CR-42](#), [UM-193](#), [UM-244](#)  
 command history [UM-168](#)  
 CommandHistory .ini file variable [UM-373](#)  
 command-line mode [UM-14](#)  
 commands  
     abort [CR-36](#)  
     add list [CR-38](#)  
     add wave [CR-41](#)  
     alias [CR-45](#)  
     batch\_mode [CR-46](#)  
     bd (breakpoint delete) [CR-47](#)  
     bookmark add wave [CR-48](#)  
     bookmark delete wave [CR-49](#)  
     bookmark goto wave [CR-50](#)  
     bookmark list wave [CR-51](#)  
     bp (breakpoint) [CR-52](#)  
     cd (change directory) [CR-55](#)  
     change [CR-56](#)  
     configure [CR-58](#)  
     dataset alias [CR-62](#)  
     dataset clear [CR-63](#)  
     dataset close [CR-64](#)  
     dataset info [CR-65](#)  
     dataset list [CR-66](#)  
     dataset open [CR-67](#)  
     dataset rename [CR-68](#), [CR-69](#)  
     dataset snapshot [CR-70](#)  
     delete [CR-72](#)  
     describe [CR-73](#)  
     disablebp [CR-74](#)  
     do [CR-75](#)  
     drivers [CR-76](#)  
     dumplog64 [CR-77](#)  
     echo [CR-78](#)  
     edit [CR-79](#)  
     enablebp [CR-80](#)  
     environment [CR-81](#)  
     examine [CR-82](#)  
     exit [CR-85](#)  
     find [CR-86](#)  
     force [CR-90](#)  
     help [CR-93](#)  
     history [CR-94](#)  
     log [CR-95](#)  
     lshift [CR-97](#)  
     lsublist [CR-98](#)  
     mem display [CR-99](#)  
     mem list [CR-101](#)  
     mem load [CR-102](#)  
     mem save [CR-105](#)  
     mem search [CR-107](#)  
     modelsim [CR-109](#)  
     noforce [CR-110](#)  
     nolog [CR-111](#)  
     notation conventions [CR-8](#)  
     notepad [CR-113](#)  
     noview [CR-114](#)  
     nowhen [CR-115](#)  
     onbreak [CR-116](#)  
     onElabError [CR-117](#)  
     onerror [CR-118](#)  
     pause [CR-119](#)  
     printenv [CR-120](#), [CR-121](#)  
     pwd [CR-123](#)  
     quietly [CR-124](#)  
     quit [CR-125](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

radix [CR-126](#)  
 readers [CR-127](#)  
 report [CR-128](#)  
 restart [CR-130](#)  
 resume [CR-132](#)  
 run [CR-133](#)  
 searchlog [CR-135](#)  
 setenv [CR-137](#)  
 shift [CR-138](#)  
 show [CR-139](#)  
 status [CR-141](#)  
 step [CR-142](#)  
 stop [CR-143](#)  
 system [UM-353](#)  
 tb (traceback) [CR-144](#)  
 transcript [CR-145](#)  
 transcript file [CR-146](#)  
 TreeUpdate [CR-242](#)  
 tssi2mti [CR-147](#)  
 unsetenv [CR-148](#)  
 variables referenced in [CR-14](#)  
 vcd add [CR-149](#)  
 vcd checkpoint [CR-150](#)  
 vcd comment [CR-151](#)  
 vcd dumports [CR-152](#)  
 vcd dumportsall [CR-154](#)  
 vcd dumportsflush [CR-155](#)  
 vcd dumportslimit [CR-156](#)  
 vcd dumpportsoff [CR-157](#)  
 vcd dumpportson [CR-158](#)  
 vcd file [CR-159](#)  
 vcd files [CR-160](#)  
 vcd flush [CR-162](#)  
 vcd limit [CR-163](#)  
 vcd off [CR-164](#)  
 vcd on [CR-165](#)  
 vcom [CR-167](#)  
 vdel [CR-174](#)  
 vdir [CR-175](#)  
 verror [CR-176](#)  
 vgencomp [CR-177](#)  
 view [CR-179](#)  
 virtual count [CR-181](#)  
 virtual define [CR-182](#)  
 virtual delete [CR-183](#)  
 virtual describe [CR-184](#)  
 virtual expand [CR-185](#)  
 virtual function [CR-186](#)  
 virtual hide [CR-189](#)  
 virtual log [CR-190](#)  
 virtual nohide [CR-192](#)  
 virtual noglog [CR-193](#)  
 virtual region [CR-195](#)  
 virtual save [CR-196](#)  
 virtual show [CR-197](#)  
 virtual signal [CR-198](#)  
 virtual type [CR-201](#)  
 vlib [CR-203](#)  
 vlog [CR-204](#)  
 vmake [CR-210](#)  
 vmap [CR-212](#)  
 vsim [CR-213](#)  
 VSIM Tcl commands [UM-354](#)  
 vsimDate [CR-226](#)  
 vsimId [CR-226](#)  
 vsimVersion [CR-226](#)  
 WaveActivateNextPane [CR-242](#)  
 WaveRestoreCursors [CR-242](#)  
 WaveRestoreZoom [CR-242](#)  
 when [CR-228](#)  
 where [CR-233](#)  
 wlf2log [CR-234](#)  
 wlf2vcf [CR-236](#)  
 wlfman [CR-237](#)  
 wlfrecover [CR-240](#)  
 write format [CR-241](#)  
 write list [CR-243](#)  
 write preferences [CR-244](#)  
 write report [CR-245](#)  
 write transcript [CR-246](#)  
 write tssi [CR-247](#)  
 write wave [CR-249](#)  
 comment character  
     Tcl and DO files [UM-350](#)  
 comment characters in VSIM commands [CR-8](#)  
 compare simulations [UM-141](#)  
 compatibility, of vendor libraries [CR-175](#)  
 compile history [UM-31](#)  
 compile order  
     auto generate [UM-32](#)  
     changing [UM-32](#)  
 compiler directives [UM-112](#)  
     IEEE Std 1364-2000 [UM-112](#)  
     XL compatible compiler directives [UM-113](#)  
 compiling  
     changing order in the GUI [UM-32](#)  
     compile history [UM-31](#)  
     default options, setting [UM-267](#)  
     graphic interface, with the [UM-265](#)  
     grouping files [UM-33](#)  
     order, changing in projects [UM-32](#)  
     properties, in projects [UM-38](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- range checking in VHDL [CR-171](#), [UM-60](#)  
 source errors, locating [UM-266](#)  
 Verilog [CR-204](#), [UM-85](#)  
     incremental compilation [UM-86](#)  
     XL 'uselib compiler directive [UM-91](#)  
     XL compatible options [UM-90](#)  
 VHDL [CR-167](#), [UM-59](#)  
     at a specified line number [CR-169](#)  
     selected design units (-just eapbc) [CR-168](#)  
     standard package (-s) [CR-172](#)  
     VITAL packages [UM-72](#)  
 component, default binding rules [UM-51](#)  
 Compressing files  
     VCD tasks [UM-335](#)  
 compressing files  
     VCD files [CR-152](#), [CR-160](#)  
 concatenation  
     directives [CR-26](#)  
     of signals [CR-25](#), [CR-198](#)  
 ConcurrentFileLimit .ini file variable [UM-373](#)  
 conditional breakpoints [CR-228](#), [UM-222](#)  
 configuration simulator state variable [UM-384](#)  
 configurations  
     Verilog [UM-92](#)  
 configurations, simulating [CR-213](#)  
 configure command [CR-58](#)  
 connectivity, exploring [UM-175](#)  
 constants  
     in case statements [CR-169](#)  
     values of, displaying [CR-73](#), [CR-82](#)  
 context menu  
     List window [UM-190](#)  
 context menus  
     described [UM-161](#)  
     Library tab [UM-48](#)  
     Project tab [UM-31](#)  
     Structure window [UM-232](#)  
 conversion, radix [CR-126](#)  
 convert real to time [UM-76](#)  
 convert time to real [UM-75](#)  
 cursors  
     link to Dataflow window [UM-172](#)  
     locking [UM-256](#)  
     measuring time with [UM-256](#)  
     naming [UM-255](#)  
     trace events with [UM-178](#)  
     Wave window [UM-255](#)  
 customizing  
     via preference variables [UM-381](#)
- D
- deltas  
     explained [UM-64](#)  
 Dataflow window [UM-171](#)  
     automatic cell hiding [UM-185](#), [UM-186](#)  
     options [UM-185](#), [UM-186](#)  
     pan [UM-177](#)  
     zoom [UM-177](#)  
     *see also* windows, Dataflow window  
 dataflow.bsm file [UM-184](#)  
 dataset alias command [CR-62](#)  
 Dataset Browser [UM-146](#)  
 dataset clear command [CR-63](#)  
 dataset close command [CR-64](#)  
 dataset info command [CR-65](#)  
 dataset list command [CR-66](#)  
 dataset open command [CR-67](#)  
 dataset rename command [CR-68](#), [CR-69](#)  
 Dataset Snapshot [UM-148](#)  
 dataset snapshot command [CR-70](#)  
 Datasets [UM-141](#)  
 datasets  
     environment command, specifying with [CR-81](#)  
     managing [UM-146](#)  
     restrict dataset prefix display [UM-147](#)  
 DatasetSeparator .ini file variable [UM-373](#)  
 declarations, hiding implicit with explicit [CR-173](#)  
 default binding rules [UM-51](#)  
 default compile options [UM-267](#)  
 Default editor, changing [UM-365](#)  
 DefaultForceKind .ini file variable [UM-373](#)  
 DefaultRadix .ini file variable [UM-373](#)  
 DefaultRestartOptions variable [UM-374](#), [UM-380](#)  
 defaults  
     restoring [UM-365](#)  
     window arrangement [UM-161](#)  
 +define+ [CR-205](#)  
 definition (ID) of memory [UM-201](#)  
 delay  
     delta delays [UM-64](#)  
     interconnect [CR-216](#)  
     modes for Verilog models [UM-104](#)  
     SDF files [UM-313](#)  
     stimulus delay, specifying [UM-221](#)  
 +delay\_mode\_distributed [CR-205](#)  
 +delay\_mode\_path [CR-205](#)  
 +delay\_mode\_unit [CR-205](#)  
 +delay\_mode\_zero [CR-205](#)  
 'delayed [CR-22](#)  
 DelayFileOpen .ini file variable [UM-374](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- delete command [CR-72](#)
- deleting library contents [UM-47](#)
- delta simulator state variable [UM-384](#)
- deltas
  - collapsing in the List window [UM-195](#)
  - hiding in the List window [CR-59](#), [UM-195](#)
  - referencing simulator iteration
    - as a simulator state variable [UM-384](#)
- dependencies, checking [CR-175](#)
- dependent design units [UM-59](#)
- describe command [CR-73](#)
- descriptions of HDL items [UM-228](#)
- design hierarchy, viewing in Structure window [UM-230](#)
- design library
  - creating [UM-46](#)
  - logical name, assigning [UM-49](#)
  - mapping search rules [UM-50](#)
  - resource type [UM-44](#)
  - VHDL design units [UM-59](#)
  - working type [UM-44](#)
- design units [UM-44](#)
  - hierarchy of, viewing [UM-162](#)
  - report of units simulated [CR-245](#)
- Verilog
  - adding to a library [CR-204](#)
- directories
  - mapping libraries [CR-212](#)
  - moving libraries [UM-50](#)
- directory, changing, disabled [UM-166](#)
- disablebp command [CR-74](#)
- distributed delay mode [UM-105](#)
- dividers
  - adding from command line [CR-41](#)
  - Wave window [UM-242](#)
- DLL files, loading [UM-121](#), [UM-122](#)
- do command [CR-75](#)
- DO files (macros) [CR-75](#)
  - error handling [UM-361](#)
  - executing at startup [UM-365](#), [UM-376](#)
  - parameters, passing to [UM-359](#)
  - Tcl source command [UM-362](#)
- docking
  - window panes [UM-159](#)
- DOPATH environment variable [UM-365](#)
- drivers
  - Dataflow Window [UM-175](#)
  - show in Dataflow window [UM-246](#)
  - Wave window [UM-246](#)
- drivers command [CR-76](#)
- drivers, multiple on unresolved signal [UM-269](#)
- dump files, viewing in ModelSim [CR-166](#)
- dumplog64 command [CR-77](#)
- dumpports tasks, VCD files [UM-334](#)

## E

- echo command [CR-78](#)
- edit command [CR-79](#)
- Editing
  - in notepad windows [UM-389](#)
  - in the Main window [UM-389](#)
  - in the Source window [UM-389](#)
- EDITOR environment variable [UM-365](#)
- editor, default, changing [UM-365](#)
- elaboration, interrupting [CR-213](#)
- embedded wave viewer [UM-176](#)
- enablebp command [CR-80](#)
- ENDFILE function [UM-69](#)
- ENDLINE function [UM-69](#)
- entities
  - default binding rules [UM-51](#)
- entities, specifying for simulation [CR-225](#)
- entity simulator state variable [UM-384](#)
- enumerated types
  - user defined [CR-201](#)
- environment command [CR-81](#)
- environment variables [UM-365](#)
  - reading into Verilog code [CR-205](#)
  - referencing from ModelSim command line [UM-368](#)
  - referencing with VHDL FILE variable [UM-368](#)
  - setting in Windows [UM-367](#)
  - specifying library locations in modelsim.ini file [UM-369](#)
  - specifying UNIX editor [CR-79](#)
  - state of [CR-121](#)
  - TranscriptFile, specifying location of [UM-376](#)
  - using in pathnames [CR-13](#)
  - using with location mapping [UM-54](#)
  - variable substitution using Tcl [UM-353](#)
- environment, displaying or changing pathname [CR-81](#)
- errors
  - bad magic number [UM-143](#)
  - during compilation, locating [UM-266](#)
  - getting details about messages [CR-176](#)
  - onerror command [CR-118](#)
- escape character [CR-12](#)
- event order
  - changing in Verilog [CR-204](#)
  - in Verilog simulation [UM-96](#)
- event queues [UM-96](#)
- events, tracing [UM-178](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

examine command [CR-82](#)  
 examine tooltip  
     toggling on/off [UM-252](#)  
 exit command [CR-85](#)  
 expand net [UM-175](#)  
 Explicit .ini file variable [UM-370](#)  
 Expression Builder [UM-288](#)  
     configuring a List trigger with [UM-197](#)  
 extended identifiers  
     syntax in commands [CR-13](#)

## F

-f [CR-205](#)  
 File compression  
     VCD tasks [UM-335](#)  
 file compression  
     VCD files [CR-152](#), [CR-160](#)  
 file I/O  
     TextIO package [UM-66](#)  
     VCD files [UM-329](#)  
 file-line breakpoints [UM-228](#)  
 files, grouping for compile [UM-33](#)  
 filtering signals in Signals window [UM-218](#)  
 find command [CR-86](#)  
 finding  
     cursors in the Wave window [UM-256](#)  
     marker in the List window [UM-199](#)  
     names and values [UM-161](#)  
 folders, in projects [UM-36](#)  
 force command [CR-90](#)  
     defaults [UM-380](#)  
 format file [UM-239](#)  
     List window [CR-241](#)  
     Wave window [CR-241](#), [UM-239](#)  
 FPGA libraries, importing [UM-56](#)

## G

GenerateFormat .ini file variable [UM-374](#)  
 generics  
     assigning or overriding values with -g and -G [CR-214](#)  
     examining generic values [CR-82](#)  
     limitation on assigning composite types [CR-215](#)  
 get\_resolution() VHDL function [UM-73](#)  
 glitches  
     disabling generation  
         from command line [CR-220](#)  
         from GUI [UM-275](#)

graphic interface [UM-155](#)  
 grouping files for compile [UM-33](#)  
 GUI preferences, saving [UM-381](#)  
 GUI\_expression\_format [CR-20](#)  
     GUI expression builder [UM-288](#)  
     syntax [CR-21](#)

## H

'hasX [CR-22](#)  
 Hazard .ini file variable (VLOG) [UM-370](#)  
 hazards  
     -hazards argument to vlog [CR-205](#)  
     -hazards argument to vsim [CR-221](#)  
     limitations on detection [UM-99](#)  
 HDL item [UM-19](#)  
 help command [CR-93](#)  
 hierarchy  
     forcing signals in [UM-74](#)  
     referencing signals in [UM-74](#)  
     releasing signals in [UM-74](#)  
     viewing signal names without [UM-251](#)  
 history  
     of commands  
         shortcuts for reuse [CR-17](#), [UM-388](#)  
         of compiles [UM-31](#)  
 history command [CR-94](#)  
 HOME environment variable [UM-365](#)

## I

I/O  
     TextIO package [UM-66](#)  
     VCD files [UM-329](#)  
 ieee .ini file variable [UM-369](#)  
 IEEE libraries [UM-52](#)  
 IEEE Std 1076 [UM-16](#)  
     differences between versions [UM-60](#)  
 IEEE Std 1364 [UM-16](#), [UM-84](#)  
 IgnoreError .ini file variable [UM-374](#)  
 IgnoreFailure .ini file variable [UM-374](#)  
 IgnoreNote .ini file variable [UM-374](#)  
 IgnoreVitalErrors .ini file variable [UM-370](#)  
 IgnoreWarning .ini file variable [UM-374](#)  
 implicit operator, hiding with vcom -explicit [CR-173](#)  
 importing FPGA libraries [UM-56](#)  
 +incdir+ [CR-205](#)  
 incremental compilation  
     automatic [UM-87](#)  
     manual [UM-87](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

with Verilog [UM-86](#)  
 index checking [UM-60](#)  
 indexed arrays, escaping square brackets [CR-12](#)  
 init\_signal\_spy [UM-74](#)  
 init\_usertfs function [UM-117](#)  
 Initial dialog box, turning on/off [UM-364](#)  
 interconnect delays [CR-216](#), [UM-325](#)  
   annotating per Verilog 2001 [CR-224](#)  
 internal signals, adding to a VCD file [CR-149](#)  
 item\_list\_file, WLF files [CR-237](#)  
 iteration\_limit, infinite zero-delay loops [UM-65](#)  
 IterationLimit .ini file variable [UM-374](#)

## K

keyboard shortcuts  
   List window [UM-200](#), [UM-391](#)  
   Main window [UM-170](#), [UM-389](#)  
   Source window [UM-389](#)  
   Wave window [UM-260](#), [UM-392](#)  
 keywords  
   disabling 2001 keywords [CR-208](#)  
   enabling System Verilog keywords [CR-207](#)

## L

language templates [UM-290](#)  
 language versions, VHDL [UM-60](#)  
 Libraries  
   modelsim\_lib [UM-73](#)  
 libraries  
   archives [CR-203](#)  
   dependencies, checking [CR-175](#)  
   design libraries, creating [CR-203](#), [UM-46](#)  
   design library types [UM-44](#)  
   design units [UM-44](#)  
   group use, setting up [UM-50](#)  
   IEEE [UM-52](#)  
   importing FPGA libraries [UM-56](#)  
   including precompiled modules [UM-277](#)  
   listing contents [CR-175](#)  
   mapping  
     from the command line [UM-49](#)  
     from the GUI [UM-49](#)  
     hierarchically [UM-378](#)  
     search rules [UM-50](#)  
   moving [UM-50](#)  
   multiple libraries with common modules [UM-89](#)  
   naming [UM-49](#)  
   predefined [UM-52](#)

refreshing library images [CR-172](#), [CR-207](#), [UM-52](#)  
 resource libraries [UM-44](#)  
 std library [UM-52](#)  
 Synopsys [UM-52](#)  
 vendor supplied, compatibility of [CR-175](#)  
 Verilog [CR-221](#), [UM-88](#)  
 VHDL library clause [UM-51](#)  
 working libraries [UM-44](#)  
   working with contents of [UM-47](#)  
 library map file, Verilog configurations [UM-92](#)  
 library maps, Verilog 2001 [UM-92](#)  
 library simulator state variable [UM-384](#)  
 License .ini file variable [UM-375](#)  
 licensing  
   License variable in .ini file [UM-375](#)  
 lint-style checks [CR-206](#)  
 List window [UM-187](#)  
   adding items to [CR-38](#)  
   context menu [UM-190](#)  
   setting triggers [UM-197](#)  
   *see also* windows, List window  
 LM\_LICENSE\_FILE environment variable [UM-365](#)  
 location maps, referencing source files [UM-54](#)  
 locations maps  
   specifying source files with [UM-54](#)

log command [CR-95](#)

log file  
   log command [CR-95](#)  
   nolog command [CR-111](#)  
   overview [UM-141](#)  
   QuickSim II format [CR-234](#)  
   redirecting with -l [CR-216](#)  
   virtual log command [CR-190](#)  
   virtual nolog command [CR-193](#)  
   *see also* WLF files

long simulations  
   saving at intervals [UM-148](#)  
 lshift command [CR-97](#)  
 ls sublist command [CR-98](#)

## M

MacroNestingLevel simulator state variable [UM-384](#)  
 macros (DO files) [UM-359](#)  
   breakpoints, executing at [CR-53](#)  
   creating from a saved transcript [UM-165](#)  
   depth of nesting, simulator state variable [UM-384](#)  
   error handling [UM-361](#)  
   executing [CR-75](#)  
   forcing signals, nets, or registers [CR-90](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

parameters  
     as a simulator state variable (n) [UM-384](#)  
     passing [CR-75](#), [UM-359](#)  
     total number passed [UM-384](#)  
 relative directories [CR-75](#)  
 shifting parameter values [CR-138](#)  
 Startup macros [UM-379](#)  
 Main window [UM-163](#)  
     *see also* windows, Main window  
 mapping  
     libraries  
         from the command line [UM-49](#)  
         hierarchically [UM-378](#)  
     symbols  
         Dataflow window [UM-184](#)  
 mapping libraries, library mapping [UM-49](#)  
 math\_complex package [UM-52](#)  
 math\_real package [UM-52](#)  
 +maxdelays [CR-206](#)  
 mc\_scan\_plusargs, PLI routine [CR-223](#)  
 mem display command [CR-99](#)  
 mem list command [CR-101](#)  
 mem load command [CR-102](#)  
 mem save command [CR-105](#)  
 mem search command [CR-107](#)  
 memories  
     displaying the contents [UM-201](#)  
     initializing [UM-208](#)  
     initializing interactively [UM-210](#)  
     loading memory patterns [UM-208](#)  
     MTI's definition of [UM-201](#)  
     saving memory data to a file [UM-211](#)  
 memory  
     modeling in VHDL [UM-77](#)  
 Memory window [UM-201](#)  
     *see also* windows, Memory window  
 memory, displaying contents [CR-99](#)  
 memory, listing [CR-101](#)  
 memory, loading contents [CR-102](#)  
 memory, saving contents [CR-105](#)  
 memory, searching for patterns [CR-107](#)  
 menus  
     Dataflow window [UM-173](#)  
     List window [UM-189](#)  
     Main window [UM-166](#)  
     Memory window [UM-202](#)  
     Process window [UM-214](#)  
     Signals window [UM-216](#)  
     Source window [UM-225](#)  
     Structure window [UM-231](#)  
     tearing off or pinning menus [UM-161](#)  
 Variables window [UM-234](#)  
 Wave window [UM-239](#)  
 messages  
     bad magic number [UM-143](#)  
     echoing [CR-78](#)  
     getting more information [CR-176](#)  
     loading, disabling with -quiet [CR-171](#), [CR-207](#)  
     redirecting [UM-376](#)  
     suppressing warnings from arithmetic packages  
         [UM-379](#)  
         turning off assertion messages [UM-379](#)  
 MGC\_LOCATION\_MAP env variable [UM-54](#)  
 MGC\_LOCATION\_MAP variable [UM-365](#)  
 +mindelays [CR-206](#)  
 mnemonics, assigning to signal values [CR-201](#)  
 MODEL\_TECH environment variable [UM-365](#)  
 MODEL\_TECH\_TCL environment variable [UM-365](#)  
 modeling memory in VHDL [UM-77](#)  
 ModelSim  
     commands [CR-29](#)–[CR-249](#)  
 modelsim command [CR-109](#)  
 MODELSIM environment variable [UM-365](#)  
 modelsim.ini  
     default to VHDL93 [UM-380](#)  
     delay file opening with [UM-380](#)  
     environment variables in [UM-378](#)  
     force command default, setting [UM-380](#)  
     hierarchical library mapping [UM-378](#)  
     opening VHDL files [UM-380](#)  
     restart command defaults, setting [UM-380](#)  
     startup file, specifying with [UM-379](#)  
     transcript file created from [UM-378](#)  
     turning off arithmetic package warnings [UM-379](#)  
     turning off assertion messages [UM-379](#)  
 modelsim.tcl file [UM-381](#)  
 modelsim\_lib [UM-73](#)  
     path to [UM-369](#)  
 MODELSIM\_TCL environment variable [UM-366](#)  
 Modified field, Project tab [UM-30](#)  
 modules  
     handling multiple, common names [UM-89](#)  
 mouse shortcuts  
     Main window [UM-170](#), [UM-389](#)  
     Source window [UM-389](#)  
     Wave window [UM-260](#), [UM-392](#)  
 .mpf file [UM-22](#)  
     loading from the command line [UM-41](#)  
 mti\_cosim\_trace environment variable [UM-366](#)  
 MTI\_TF\_LIMIT environment variable [UM-366](#)  
 multiple drivers on unresolved signal [UM-269](#)  
 Multiple simulations [UM-141](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

multi-source interconnect delays [CR-216](#)

## N

n simulator state variable [UM-384](#)

name case sensitivity, VHDL vs. Verilog [CR-13](#)

Name field

    Project tab [UM-30](#)

names, modules with the same [UM-89](#)

negative pulses

    driving an error state [CR-224](#)

Negative timing

    \$setuphold/\$recovery [UM-109](#)

negative timing

    algorithm for calculating delays [UM-100](#)

    check limits [UM-100](#)

    extending check limits [CR-221](#)

nets

    adding to the Wave and List windows [UM-221](#)

    Dataflow window, displaying in [UM-171](#)

    drivers of, displaying [CR-76](#)

    readers of, displaying [CR-127](#)

    stimulus [CR-90](#)

    values of

        displaying in Signals window [UM-215](#)

        examining [CR-82](#)

        forcing [UM-220](#)

        saving as binary log file [UM-221](#)

    waveforms, viewing [UM-236](#)

next and previous edges, finding [UM-393](#)

Nlview widget Symlib format [UM-184](#)

no space in time literal [UM-269](#)

NoCaseStaticError .ini file variable [UM-370](#)

NoDebug .ini file variable (VCOM) [UM-371](#)

NoDebug .ini file variable (VLOG) [UM-370](#)

noforce command [CR-110](#)

NoIndexCheck .ini file variable [UM-371](#)

+nolibcell [CR-207](#)

nolog command [CR-111](#)

NOMMAP environment variable [UM-366](#)

non-blocking assignments [UM-98](#)

NoOthersStaticError .ini file variable [UM-371](#)

NoRangeCheck .ini file variable [UM-371](#)

notepad command [CR-113](#)

Notepad windows, text editing [UM-389](#)

-notrigger argument [UM-197](#)

noview command [CR-114](#)

NoVital .ini file variable [UM-371](#)

NoVitalCheck .ini file variable [UM-371](#)

Now simulator state variable [UM-384](#)

now simulator state variable [UM-384](#)

+nowarn<CODE> [CR-207](#)

nowhen command [CR-115](#)

numeric\_bit package [UM-52](#)

numeric\_std package [UM-52](#)

    disabling warning messages [UM-379](#)

NumericStdNoWarnings .ini file variable [UM-375](#)

## O

onbreak command [CR-116](#)

onElabError command [CR-117](#)

onerror command [CR-118](#)

operating systems supported, *See Installation Guide*

optimizations

    disabling for Verilog designs [CR-207](#)

    disabling for VHDL designs [CR-171](#)

    disabling process merging [CR-167](#)

optimize for std\_logic\_1164 [UM-269](#)

Optimize\_1164 .ini file variable [UM-371](#)

OptionFile entry in project files [UM-271](#)

order of events

    changing in Verilog [CR-204](#)

ordering files for compile [UM-32](#)

organizing projects with folders [UM-36](#)

others .ini file variable [UM-370](#)

## P

Packages

    util [UM-73](#)

packages

    standard [UM-52](#)

    textio [UM-52](#)

    VITAL 1995 [UM-71](#)

    VITAL 2000 [UM-71](#)

page setup

    Dataflow window [UM-183](#)

    Wave window [UM-263](#)

pan, Dataflow window [UM-177](#)

panes

    docking and undocking [UM-159](#)

parameters

    making optional [UM-360](#)

    using with macros [CR-75](#), [UM-359](#)

path delay mode [UM-105](#)

pathnames

    in VSIM commands [CR-10](#)

    spaces in [CR-9](#)

PathSeparator .ini file variable [UM-375](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- pause command [CR-119](#)
- PedanticErrors .ini file variable [UM-371](#)
- platforms supported, *See Installation Guide*
- PLI
  - specifying which apps to load [UM-118](#)
  - Veriuser entry [UM-118](#)
- PLI/VPI [UM-116](#)
  - tracing [UM-137](#)
- PLIOBJ\$ environment variable [UM-118](#), [UM-366](#)
- popup
  - toggling waveform popup on/off [UM-252](#)
- Port driver data, capturing [UM-340](#)
- Postscript
  - saving a waveform in [UM-260](#)
  - saving the Dataflow display in [UM-181](#)
- precedence of variables [UM-383](#)
- precision, simulator resolution [UM-94](#)
- pref.tcl file [UM-381](#)
- preference variables
  - .ini files, located in [UM-369](#)
  - editing [UM-381](#)
  - saving [UM-381](#)
  - Tcl files, located in [UM-381](#)
  - preferences, saving [UM-381](#)
  - primitives, symbols in Dataflow window [UM-184](#)
  - printenv command [CR-120](#), [CR-121](#)
  - Process window [UM-213](#)
    - see also* windows, Process window
  - processes
    - optimizations, disabling merging [CR-167](#)
    - values and pathnames in Variables window [UM-233](#)
    - without wait statements [UM-269](#)
  - Programming Language Interface [UM-116](#)
  - project context menus [UM-31](#)
  - project tab
    - information in [UM-30](#)
    - sorting [UM-30](#)
  - Projects
    - MODELSIM environment variable [UM-365](#)
  - projects [UM-21](#)
    - accessing from the command line [UM-41](#)
    - adding files to [UM-25](#)
    - benefits [UM-22](#)
    - compile order [UM-32](#)
      - changing [UM-32](#)
    - compiler properties in [UM-38](#)
    - compiling files [UM-28](#)
    - context menu [UM-31](#)
    - creating [UM-24](#)
    - creating simulation configurations [UM-34](#)
  - folders in [UM-36](#)
  - grouping files in [UM-33](#)
  - loading a design [UM-29](#)
  - override mapping for work directory with vcom [CR-172](#)
  - override mapping for work directory with vlog [CR-208](#)
  - overview [UM-22](#)
  - propagation, preventing X propagation [CR-216](#)
  - pulse error state [CR-224](#)
  - pwd command [CR-123](#)

## Q

- QuickSim II logfile format [CR-234](#)
- Quiet .ini file variable
  - VCOM [UM-371](#)
- Quiet .ini file variable (VLOG) [UM-370](#)
- quietly command [CR-124](#)
- quit command [CR-125](#)

## R

- race condition, problems with event order [UM-96](#)

- radix
  - changing in Signals, Variables, Dataflow, List, and Wave windows [CR-126](#)
  - character strings, displaying [CR-201](#)
  - default, DefaultRadix variable [UM-373](#)
  - of signals being examined [CR-83](#)
  - of signals in Wave window [CR-43](#)
  - specifying in List window [UM-192](#)
  - specifying in Memory window [UM-205](#)
- radix command [CR-126](#)
- range checking [UM-60](#)
  - disabling [CR-170](#)
  - enabling [CR-171](#)
- readers and drivers [UM-175](#)
- readers command [CR-127](#)
- real type, converting to time [UM-76](#)
- reconstruct RTL-level design busses [UM-151](#)
- record field selection, syntax [CR-11](#)
- records, values of, changing [UM-233](#)
- \$recovery [UM-109](#)
- redirecting messages, TranscriptFile [UM-376](#)
- refreshing library images [CR-172](#), [CR-207](#), [UM-52](#)
- registers
  - adding to the Wave and List windows [UM-221](#)
  - values of
    - displaying in Signals window [UM-215](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- saving as binary log file [UM-221](#)
- waveforms, viewing [UM-236](#)
- report
  - simulator control [UM-364](#)
  - simulator state [UM-364](#)
- report command [CR-128](#)
- reporting
  - compile history [UM-31](#)
  - variable settings [CR-14](#)
- RequireConfigForAllDefaultBinding variable [UM-371](#)
- resolution
  - returning as a real [UM-73](#)
  - specifying with -t argument [CR-218](#)
  - verilog simulation [UM-94](#)
  - VHDL simulation [UM-63](#)
- Resolution .ini file variable [UM-375](#)
- resolution simulator state variable [UM-384](#)
- resource libraries [UM-51](#)
- restart command [CR-130](#)
  - defaults [UM-380](#)
  - in GUI [UM-167](#)
- restoring defaults [UM-365](#)
- results, saving simulations [UM-141](#)
- resume command [CR-132](#)
- RTL-level design busses
  - reconstructing [UM-151](#)
- run command [CR-133](#)
- RunLength .ini file variable [UM-375](#)
  
- S**
- saving
  - simulation options in a project [UM-34](#)
  - waveforms [UM-141](#)
- scope, setting region environment [CR-81](#)
- SDF
  - controlling missing instance messages [CR-217](#)
  - disabling timing checks [UM-325](#)
  - errors and warnings [UM-315](#)
  - instance specification [UM-314](#)
  - interconnect delays [UM-325](#)
  - mixed VHDL and Verilog designs [UM-324](#)
  - specification with the GUI [UM-315](#)
  - troubleshooting [UM-326](#)
  - Verilog
    - \$sdf\_annotate system task [UM-318](#)
    - optional conditions [UM-323](#)
    - optional edge specifications [UM-322](#)
    - rounded timing values [UM-323](#)
    - SDF to Verilog construct matching [UM-319](#)
- VHDL
  - resolving errors [UM-317](#)
  - SDF to VHDL generic matching [UM-316](#)
- \$sdf\_done [UM-111](#)
- search libraries [CR-221](#), [UM-277](#)
- searching
  - in the source window [UM-228](#)
  - in the Structure window [UM-232](#)
- List window
  - signal values, transitions, and names [UM-198](#)
  - values and names [UM-161](#)
- Verilog libraries [UM-88](#)
- Wave window
  - signal values, edges and names [UM-254](#)
- searchlog command [CR-135](#)
- setenv command [CR-137](#)
- \$setuphold [UM-109](#)
- shared objects
  - loading FLI applications
    - see ModelSim FLI Reference manual
  - loading PLI/VPI C applications [UM-121](#)
  - loading PLI/VPI C++ applications [UM-122](#)
- shift command [CR-138](#)
- Shortcuts
  - text editing [UM-389](#)
- shortcuts
  - command history [CR-17](#), [UM-388](#)
  - command line caveat [CR-16](#), [UM-387](#)
  - List window [UM-200](#), [UM-391](#)
  - Main window [UM-389](#)
  - Main windows [UM-170](#)
  - Source window [UM-389](#)
  - Wave window [UM-260](#), [UM-392](#)
- show command [CR-139](#)
- show drivers
  - Dataflow window [UM-175](#)
  - Wave window [UM-246](#)
- show source lines with errors [UM-268](#)
- Show\_BadOptionWarning .ini file variable [UM-370](#)
- Show\_Lint .ini file variable (VLOG) [UM-370](#)
- Show\_source .ini file variable
  - VCOM [UM-371](#)
  - Show\_source .ini file variable (VLOG) [UM-370](#)
  - Show\_VitalChecksWarning .ini file variable [UM-371](#)
  - Show\_Warning1 .ini file variable [UM-371](#)
  - Show\_Warning2 .ini file variable [UM-371](#)
  - Show\_Warning3 .ini file variable [UM-371](#)
  - Show\_Warning4 .ini file variable [UM-371](#)
  - Show\_Warning5 .ini file variable [UM-371](#)
  - Show3DMem .ini file variable [UM-375](#)
  - ShowEnumMem .ini file variable [UM-376](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- ShowIntMem .ini file variable [UM-375](#)
- Signal Spy [UM-74](#)
- signal\_force [UM-74](#)
- signal\_release [UM-74](#)
- signals
  - adding to a WLF file [UM-221](#)
  - adding to the Wave and List windows [UM-221](#)
  - alternative names in the List window (-label) [CR-39](#)
  - alternative names in the Wave window (-label) [CR-42](#)
  - combining into a user-defined bus [CR-42](#), [UM-193](#), [UM-244](#)
  - Dataflow window, displaying in [UM-171](#)
  - drivers of, displaying [CR-76](#)
  - environment of, displaying [CR-81](#)
  - filtering in the Signals window [UM-218](#)
  - finding [CR-86](#)
  - force time, specifying [CR-91](#)
  - hierarchy
    - referencing in [UM-74](#)
    - releasing in [UM-74](#)
  - log file, creating [CR-95](#)
  - names of, viewing without hierarchy [UM-251](#)
  - pathnames in VSIM commands [CR-10](#)
  - radix
    - specifying for examine [CR-83](#)
    - specifying in List window [CR-39](#)
    - specifying in Wave window [CR-43](#)
  - readers of, displaying [CR-127](#)
  - sampling at a clock change [UM-197](#)
  - states of, displaying as mnemonics [CR-201](#)
  - stimulus [CR-90](#)
  - transitions, searching for [UM-257](#)
  - types, selecting which to view [UM-218](#)
  - unresolved, multiple drivers on [UM-269](#)
  - values of
    - displaying in Signals window [UM-215](#)
    - examining [CR-82](#)
    - forcing anywhere in the hierarchy [UM-74](#)
    - replacing with text [CR-201](#)
    - saving as binary log file [UM-221](#)
  - waveforms, viewing [UM-236](#)
- Signals window [UM-215](#)
  - see also* windows, Signals window
- Simulating
  - Comparing simulations [UM-141](#)
  - simulating
    - command-line mode [UM-14](#)
- default run length [UM-281](#)
- delays, specifying time units for [CR-15](#)
- design unit, specifying [CR-213](#)
- graphic interface to [UM-272](#)
- iteration limit [UM-282](#)
- saving dataflow display as a Postscript file [UM-181](#)
- saving options in a project [UM-34](#)
- saving simulations [CR-95](#), [CR-219](#), [UM-141](#)
- saving waveform as a Postscript file [UM-260](#)
- stepping through a simulation [CR-142](#)
- stimulus, applying to signals and nets [UM-220](#)
- stopping simulation in batch mode [CR-231](#)
- time resolution [UM-273](#)
- Verilog [UM-93](#)
  - delay modes [UM-104](#)
  - hazard detection [UM-99](#)
  - resolution limit [UM-94](#)
  - XL compatible simulator options [UM-103](#)
- VHDL [UM-63](#)
- viewing results in List window [UM-187](#)
- VITAL packages [UM-72](#)
- Simulation Configuration
  - creating [UM-34](#)
- simulations
  - event order in [UM-96](#)
  - saving results [CR-69](#), [CR-70](#), [UM-141](#)
  - saving results at intervals [UM-148](#)
- simulator resolution
  - returning as a real [UM-73](#)
  - Verilog [UM-94](#)
  - VHDL [UM-63](#)
  - vsim -t argument [CR-218](#)
- simulator state variables [UM-384](#)
- simulator version [CR-219](#), [CR-226](#)
- simultaneous events in Verilog
  - changing order [CR-204](#)
- sizetf callback function [UM-128](#)
- so, shared object file
  - loading PLI/VPI C applications [UM-121](#)
  - loading PLI/VPI C++ applications [UM-122](#)
- sorting
  - HDL items in GUI windows [UM-161](#)
- source directory, setting from source window [UM-225](#)
- source errors, locating during compilation [UM-266](#)
- source files, referencing with location maps [UM-54](#)
- source files, specifying with location maps [UM-54](#)
- source libraries
  - arguments supporting [UM-90](#)
- source lines with errors
  - showing [UM-268](#)
- spaces in pathnames [CR-9](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- specify path delays [CR-224](#)
- square brackets, escaping [CR-12](#)
- standards supported [UM-16](#)
- Startup
  - macros [UM-379](#)
- startup
  - alternate to startup.do (vsim -do) [CR-214](#)
  - macro in the modelsim.ini file [UM-376](#)
  - startup macro in command-line mode [UM-14](#)
  - using a startup file [UM-379](#)
- Startup .ini file variable [UM-376](#)
- state variables [UM-384](#)
- status bar
  - Main window [UM-170](#)
- status command [CR-141](#)
- Status field
  - Project tab [UM-30](#)
- std .ini file variable [UM-369](#)
- std\_arith package
  - disabling warning messages [UM-379](#)
- std\_developerskit .ini file variable [UM-369](#)
- std\_logic\_arith package [UM-52](#)
- std\_logic\_signed package [UM-52](#)
- std\_logic\_textio [UM-52](#)
- std\_logic\_unsigned package [UM-52](#)
- StdArithNoWarnings .ini file variable [UM-376](#)
- STDOUT environment variable [UM-366](#)
- step command [CR-142](#)
- stimulus
  - applying to signals and nets [UM-220](#)
- stop command [CR-143](#)
- Structure window [UM-230](#)
  - see also* windows, Structure window
- subprogram write is ambiguous error, fixing [UM-68](#)
- symbol mapping
  - Dataflow window [UM-184](#)
- symbolic constants, displaying [CR-201](#)
- symbolic names, assigning to signal values [CR-201](#)
- synopsys .ini file variable [UM-369](#)
- Synopsys libraries [UM-52](#)
- synthesis
  - rule compliance checking [CR-168](#), [UM-268](#), [UM-370](#)
- system calls
  - VCD [UM-334](#)
  - Verilog [UM-106](#)
- system commands [UM-353](#)
- system tasks
  - ModelSim Verilog [UM-111](#)
  - VCD [UM-334](#)
  - Verilog [UM-106](#)
- Verilog-XL compatible [UM-109](#)
- System Verilog [UM-16](#)
  - enabling with -sv argument [CR-207](#)
- T
  - tab stops, in the Source window [UM-229](#)
  - tb command [CR-144](#)
  - Tcl [UM-345](#)–[UM-356](#)
    - command separator [UM-352](#)
    - command substitution [UM-351](#)
    - command syntax [UM-348](#)
    - evaluation order [UM-352](#)
    - preference variables [UM-381](#)
    - relational expression evaluation [UM-352](#)
    - time commands [UM-355](#)
    - variable
      - in when commands [CR-229](#)
      - substitution [UM-353](#)
  - VSIM Tcl commands [UM-354](#)
  - temp files, VSOUT [UM-368](#)
  - text and command syntax [UM-19](#)
  - Text editing [UM-389](#)
  - TEXTIO
    - buffer, flushing [UM-70](#)
  - TextIO package
    - alternative I/O files [UM-70](#)
    - containing hexadecimal numbers [UM-69](#)
    - dangling pointers [UM-69](#)
    - ENDFILE function [UM-69](#)
    - ENDLINE function [UM-69](#)
    - file declaration [UM-66](#)
    - implementation issues [UM-68](#)
    - providing stimulus [UM-70](#)
    - standard input [UM-67](#)
    - standard output [UM-67](#)
    - WRITE procedure [UM-68](#)
    - WRITE\_STRING procedure [UM-68](#)
  - TF routines [UM-134](#)
  - TFMPC
    - disabling warning [CR-223](#)
  - time
    - absolute, using @ [CR-15](#)
    - simulation time units [CR-15](#)
    - time resolution as a simulator state variable [UM-384](#)
  - time literal, missing space [UM-269](#)
  - time resolution
    - in Verilog [UM-94](#)
    - in VHDL [UM-63](#)
    - setting

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- with the GUI [UM-273](#)
  - with vsim command [CR-218](#)
  - time type
    - converting to real [UM-75](#)
  - time, time units, simulation time [CR-15](#)
  - time-based breakpoints [UM-222](#)
  - timescale directive warning
    - disabling [CR-223](#)
    - investigating [UM-94](#)
  - timing
    - \$setuphold/\$recovery [UM-109](#)
    - annotation [UM-313](#)
    - disabling checks [CR-207](#), [UM-325](#)
    - disabling checks for entire design [CR-216](#)
    - negative check limits
      - described [UM-100](#)
      - extending [CR-221](#)
  - title, Main window, changing [CR-218](#)
  - title, windows, changing [UM-157](#)
  - to\_real VHDL function [UM-75](#)
  - to\_time VHDL function [UM-76](#)
  - toggling waveform popup on/off [UM-252](#)
  - tooltip, toggling waveform popup [UM-252](#)
  - tracing
    - events [UM-178](#)
    - source of unknown [UM-179](#)
  - transcript
    - file name, specified in modelsim.ini [UM-378](#)
    - redirecting with -l [CR-216](#)
    - reducing file size [CR-146](#)
    - saving [UM-165](#)
    - using as a DO file [UM-165](#)
  - transcript command [CR-145](#)
  - transcript file command [CR-146](#)
  - TranscriptFile .ini file variable [UM-376](#)
  - tree windows
    - VHDL and Verilog items in [UM-162](#)
    - viewing the design hierarchy [UM-162](#)
  - TreeUpdate command [CR-242](#)
  - triggers, in the List window [UM-197](#)
  - triggers, in the List window, setting [UM-195](#)
  - TSCALE, disabling warning [CR-223](#)
  - TSSI [CR-247](#)
    - in VCD files [UM-340](#)
  - tssi2mti command [CR-147](#)
  - type
    - converting real to time [UM-76](#)
    - converting time to real [UM-75](#)
  - Type field, Project tab [UM-30](#)
- 
- U**
  - u [CR-208](#)
  - unbound component [UM-269](#)
  - UnbufferedOutput .ini file variable [UM-376](#)
  - undeclared nets, reporting an error [CR-206](#)
  - unit delay mode [UM-105](#)
  - unknowns, tracing [UM-179](#)
  - unresolved signals, multiple drivers on [UM-269](#)
  - unsetenv command [CR-148](#)
  - use 1076-1993 language standard [UM-267](#)
  - use clause, specifying a library [UM-52](#)
  - use explicit declarations only [UM-267](#)
  - UseCsupV2 .ini file variable [UM-376](#)
  - user-defined bus [CR-42](#), [UM-150](#), [UM-193](#), [UM-244](#)
  - UserTimeUnit .ini file variable [UM-376](#)
  - util package [UM-73](#)
- 
- V**
  - v [CR-208](#)
  - v2k\_int\_delays [CR-224](#)
  - values
    - describe HDL items [CR-73](#)
    - examine HDL item values [CR-82](#)
    - of HDL items [UM-228](#)
    - replacing signal values with strings [CR-201](#)
  - variable settings report [CR-14](#)
  - variables
    - adding to the Wave and List windows [UM-221](#)
    - describing [CR-73](#)
    - environment variables [UM-365](#)
    - LM\_LICENSE\_FILE [UM-365](#)
    - personal preferences [UM-364](#)
    - precedence between .ini and .tcl [UM-383](#)
    - referencing in commands [CR-14](#)
    - setting environment variables [UM-365](#)
    - simulator state variables
      - current settings report [UM-364](#)
      - iteration number [UM-384](#)
      - name of entity or module as a variable [UM-384](#)
      - resolution [UM-384](#)
      - simulation time [UM-384](#)
    - value of
      - changing from command line [CR-56](#)
      - changing with the GUI [UM-233](#)
      - examining [CR-82](#)
    - values of
      - displaying in Signals window [UM-215](#)
      - saving as binary log file [UM-221](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- Variables window [UM-233](#)  
*see also* windows, Variables window
- vcd add command [CR-149](#)
- vcd checkpoint command [CR-150](#)
- vcd comment command [CR-151](#)
- vcd dumpports command [CR-152](#)
- vcd dumpportsall command [CR-154](#)
- vcd dumpportsflush command [CR-155](#)
- vcd dumpportslimit command [CR-156](#)
- vcd dumpportsoff command [CR-157](#)
- vcd dumpportson command [CR-158](#)
- vcd file command [CR-159](#)
- VCD files [UM-329](#)
  - adding items to the file [CR-149](#)
  - capturing port driver data [CR-152](#), [UM-340](#)
  - case sensitivity [UM-330](#)
  - converting to WLF files [CR-166](#)
  - creating [CR-149](#), [UM-330](#)
  - dumping variable values [CR-150](#)
  - dumpports tasks [UM-334](#)
  - flushing the buffer contents [CR-162](#)
  - from VHDL source to VCD output [UM-336](#)
  - generating from WLF files [CR-236](#)
  - inserting comments [CR-151](#)
  - internal signals, adding [CR-149](#)
  - specifying maximum file size [CR-163](#)
  - specifying name of [CR-160](#)
  - specifying the file name [CR-159](#)
  - state mapping [CR-159](#), [CR-160](#)
  - stimulus, using as [UM-331](#)
  - supported TSSI states [UM-340](#)
  - turn off VCD dumping [CR-164](#)
  - turn on VCD dumping [CR-165](#)
  - VCD system tasks [UM-334](#)
  - viewing files from another tool [CR-166](#)
- vcd files command [CR-160](#)
- vcd flush command [CR-162](#)
- vcd limit command [CR-163](#)
- vcd off command [CR-164](#)
- vcd on command [CR-165](#)
- vcd2wlf command [CR-166](#)
- vcom command [CR-167](#)
- vdel command [CR-174](#)
- vdir command [CR-175](#)
- vector elements, initializing [CR-56](#)
- vendor libraries, compatibility of [CR-175](#)
- Vera, see Vera documentation
- Verilog
  - ACC routines [UM-132](#)
  - capturing port driver data with -dumpports [CR-159](#), [UM-340](#)
  - cell libraries [UM-103](#)
  - compiler directives [UM-112](#)
  - compiling and linking PLI C applications [UM-121](#)
  - compiling and linking PLI C++ applications [UM-122](#)
  - compiling design units [UM-85](#)
  - compiling with XL 'uselib' compiler directive [UM-91](#)
  - configurations [UM-92](#)
  - creating a design library [UM-85](#)
  - event order in simulation [UM-96](#)
  - language templates [UM-290](#)
  - library usage [UM-88](#)
  - SDF annotation [UM-318](#)
  - sdf\_annotate system task [UM-318](#)
  - simulating [UM-93](#)
    - delay modes [UM-104](#)
    - XL compatible options [UM-103](#)
  - simulation hazard detection [UM-99](#)
  - simulation resolution limit [UM-94](#)
  - source code viewing [UM-224](#)
  - standards [UM-16](#)
  - system tasks [UM-106](#)
  - TF routines [UM-134](#)
    - XL compatible compiler options [UM-90](#)
    - XL compatible routines [UM-136](#)
    - XL compatible system tasks [UM-109](#)
  - verilog .ini file variable [UM-369](#)
- Verilog 2001
  - disabling support [CR-208](#), [UM-370](#)
- Verilog PLI/VPI ??—[UM-139](#)
  - compiling and linking PLI/VPI C applications [UM-121](#)
  - compiling and linking PLI/VPI C++ applications [UM-122](#)
  - debugging PLI/VPI code [UM-137](#)
  - PLI callback reason argument [UM-126](#)
  - PLI support for VHDL objects [UM-131](#)
  - registering PLI applications [UM-117](#)
  - registering VPI applications [UM-119](#)
  - specifying the PLI/VPI file to load [UM-123](#)
- Verilog-XL
  - compatibility with [UM-83](#), [UM-115](#)
- Veriuser .ini file variable [UM-118](#), [UM-376](#)
- Veriuser, specifying PLI applications [UM-118](#)
- veriuser.c file [UM-130](#)
- verror command [CR-176](#)
- version
  - obtaining with vsim command [CR-219](#)
  - obtaining with vsim<info> commands [CR-226](#)
- vgencomp command [CR-177](#)

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- VHDL
  - delay file opening [UM-380](#)
  - dependency checking [UM-59](#)
  - field naming syntax [CR-11](#)
  - file opening delay [UM-380](#)
  - language templates [UM-290](#)
  - language versions [UM-60](#)
  - library clause [UM-51](#)
  - object support in PLI [UM-131](#)
  - simulating [UM-63](#)
  - source code viewing [UM-224](#)
  - standards [UM-16](#)
  - timing check disabling [UM-63](#)
  - VITAL package [UM-52](#)
- VHDL utilities [UM-73](#), [UM-74](#)
  - get\_resolution() [UM-73](#)
  - to\_real() [UM-75](#)
  - to\_time() [UM-76](#)
- VHDL-1987, compilation problems [UM-60](#)
- VHDL-1993, enabling support for [CR-167](#), [UM-371](#)
- VHDL-2002, enabling support for [CR-167](#), [UM-371](#)
- VHDL93 .ini file variable [UM-371](#)
- view command [CR-179](#)
- viewing
  - design hierarchy [UM-162](#)
  - library contents [UM-47](#)
  - waveforms [CR-219](#), [UM-141](#)
- virtual count commands [CR-181](#)
- virtual define command [CR-182](#)
- virtual delete command [CR-183](#)
- virtual describe command [CR-184](#)
- virtual expand commands [CR-185](#)
- virtual function command [CR-186](#)
- virtual hide command [CR-189](#), [UM-151](#)
- virtual log command [CR-190](#)
- virtual nohide command [CR-192](#)
- virtual nolog command [CR-193](#)
- virtual objects [UM-150](#)
  - virtual functions [UM-151](#)
  - virtual regions [UM-152](#)
  - virtual signals [UM-150](#)
  - virtual types [UM-152](#)
- virtual region command [CR-195](#), [UM-152](#)
- virtual regions
  - reconstruct the RTL hierarchy in gate-level design [UM-152](#)
- virtual save command [CR-196](#), [UM-151](#)
- virtual show command [CR-197](#)
- virtual signal command [CR-198](#), [UM-150](#)
- virtual signals
  - reconstruct RTL-level design busses [UM-151](#)
- reconstruct the original RTL hierarchy [UM-151](#)
- virtual hide command [UM-151](#)
- virtual type command [CR-201](#)
- VITAL
  - compiling and simulating with accelerated VITAL packages [UM-72](#)
  - disabling optimizations for debugging [UM-72](#)
  - specification and source code [UM-71](#)
  - VITAL packages [UM-71](#)
- vital95 .ini file variable [UM-369](#)
- vlib command [CR-203](#)
- vlog command [CR-204](#)
- vlog.opt file [UM-271](#)
- vlog95compat .ini file variable [UM-370](#)
- vmake command [CR-210](#)
- vmap command [CR-212](#)
- VPI, registering applications [UM-119](#)
- VPI/PLI [UM-116](#)
  - compiling and linking C applications [UM-121](#)
  - compiling and linking C++ applications [UM-122](#)
- vsim build date and version [CR-226](#)
- vsim command [CR-213](#)
- VSOUT temp file [UM-368](#)

## W

- WARNING[8], -lint argument to vlog [CR-206](#)
- warnings
  - disabling at time 0 [UM-379](#)
  - suppressing VCOM warning messages [CR-171](#)
  - suppressing VLOG warning messages [CR-207](#)
  - suppressing VSIM warning messages [CR-223](#)
  - turning off warnings from arithmetic packages [UM-379](#)
- Wave Log Format (WLF) file [UM-141](#)
- wave log format (WLF) file [CR-219](#)
  - of binary signal values [CR-95](#)
  - see also* WLF files
- wave viewer, Dataflow window [UM-176](#)
- Wave window [UM-236](#)
  - adding items to [CR-41](#)
  - in the Dataflow window [UM-176](#)
  - saving layout [UM-239](#)
  - toggling waveform popup on/off [UM-252](#)
  - see also* windows, Wave window
- WaveActivateNextPane command [CR-242](#)
- waveform logfile
  - log command [CR-95](#)
  - overview [UM-141](#)
  - see also* WLF files

# A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

- waveform popup [UM-252](#)
- waveforms [UM-141](#)
  - optimize viewing of [UM-377](#)
  - optimizing viewing of [CR-219](#)
  - saving and viewing [CR-95](#), [UM-142](#)
  - viewing [UM-236](#)
- WaveRestoreCursors command [CR-242](#)
- WaveRestoreZoom command [CR-242](#)
- WaveSignalNameWidth .ini file variable [UM-376](#)
- Welcome dialog, turning on/off [UM-364](#)
- when command [CR-228](#)
- when statement
  - setting signal breakpoints [UM-222](#)
  - time-based breakpoints [CR-232](#)
- where command [CR-233](#)
- wildcard characters
  - for pattern matching in simulator commands [CR-14](#)
- Windows
  - Main window
    - text editing [UM-389](#)
  - Source window
    - text editing [UM-389](#)
- windows
  - Dataflow window [UM-171](#)
    - zooming [UM-177](#)
  - finding HDL item names in [UM-161](#)
  - List window [UM-187](#)
    - adding HDL items [UM-188](#)
    - adding signals with a WLF file [UM-221](#)
    - display properties of [UM-194](#)
    - formatting HDL items [UM-191](#)
    - output file [CR-243](#)
    - saving data to a file [UM-200](#)
    - saving the format of [CR-241](#)
    - setting triggers [UM-195](#), [UM-197](#)
    - time markers [UM-161](#)
  - Main window [UM-163](#)
    - status bar [UM-170](#)
    - time and delta display [UM-170](#)
  - Memory window [UM-201](#)
    - initializing interactively [UM-210](#)
    - initializing memories [UM-208](#)
    - modifying display [UM-204](#)
    - navigating to memory locations [UM-206](#)
    - saving data to a file [UM-211](#)
    - selecting memory instances [UM-203](#)
    - viewing contents [UM-203](#)
    - viewing multiple instances [UM-203](#)
  - opening
    - from command line [CR-179](#)
    - with the GUI [UM-166](#)
- Process window [UM-213](#)
  - displaying active processes [UM-213](#)
  - specifying next process to be executed [UM-213](#)
  - viewing processing in the region [UM-213](#)
- saving position and size [UM-161](#)
- searching for HDL item values in [UM-161](#)
- Signals window [UM-215](#)
  - VHDL and Verilog items viewed in [UM-215](#)
- Source window
  - setting tab stops [UM-229](#)
- Structure window [UM-230](#)
  - selecting items to view in Signals window [UM-215](#)
  - VHDL and Verilog items viewed in [UM-230](#)
  - viewing design hierarchy [UM-230](#)
- title, changing [UM-157](#)
- Variables window [UM-233](#)
  - VHDL and Verilog items viewed in [UM-233](#)
- Wave window [UM-236](#)
  - adding HDL items to [UM-238](#)
  - adding signals with a WLF file [UM-221](#)
  - cursor measurements [UM-256](#)
  - display properties [UM-251](#)
  - display range (zoom), changing [UM-257](#)
  - format file, saving [UM-239](#)
  - path elements, changing [CR-60](#), [UM-376](#)
  - time cursors [UM-255](#)
  - zooming [UM-257](#)
- WLF files
  - adding items to [UM-221](#)
  - converting to VCD [CR-236](#)
  - creating from VCD [CR-166](#)
  - filtering, combining [CR-237](#)
  - limiting size [CR-219](#)
  - log command [CR-95](#)
  - optimizing waveform viewing [CR-219](#), [UM-377](#)
  - overview [UM-142](#)
  - repairing [CR-240](#)
  - saving [CR-69](#), [CR-70](#), [UM-143](#)
  - saving at intervals [UM-148](#)
  - specifying name [CR-219](#)
- wlf2log command [CR-234](#)
- wlf2vcf command [CR-236](#)
- wlfman command [CR-237](#)
- wlfrecover command [CR-240](#)
- work library [UM-44](#)
- workspace [UM-164](#)
- write format command [CR-241](#)
- write list command [CR-243](#)
- write preferences command [CR-244](#)
- WRITE procedure, problems with [UM-68](#)

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

write report command [CR-245](#)  
write transcript command [CR-246](#)  
write tssi command [CR-247](#)  
write wave command [CR-249](#)

**X**

X  
    tracing unknowns [UM-179](#)  
X propagation  
    disabling for entire design [CR-216](#)

**Y**

-y [CR-208](#)

**Z**

zero delay elements [UM-64](#)  
zero delay mode [UM-105](#)  
zero-delay loop, infinite [UM-65](#)  
zero-delay oscillation [UM-65](#)  
zero-delay race condition [UM-96](#)  
zoom  
    Dataflow window [UM-177](#)  
    from Wave toolbar buttons [UM-257](#)  
    saving range with bookmarks [UM-258](#)  
    with the mouse [UM-258](#)