328 90 3MB
Russian Pages [492]
ModelSim
®
SE
Ver s i o n 5 . 6 :23/
я/02
T h e l d ’ s m o s t p o p u l a r HDL s m u l a t or T h e l d ’ s m o s t p o p u l a r HDL s m u l a t or T h e l d ’ s m o s t p o p u l a u l a t or я я я HDL T h e l d ’ s m o s t p o p u l a r HDL s m u l a t or
ModelSim /VHDL, ModelSim /VLOG, ModelSim /LNL, Model Technology Incorporated.
ModelSim / PLUS , Model Technology.
,
, Model Technology. ,
.
, .
,
,
. ModelSim -
Model Technology Incorporated. PostScript Adobe Systems Incorporated. UNIX AT&T . FLEXlm Globetrotter Software, Inc. IBM, , PC , AIX RISC System/6000 International Business Machines. Windows, Microsoft, MS-DOS Microsoft. OSF/Motif Open Software Foundation, . SPARC SPARCstation SPARC International. Sun Microsystems , Sun ,SunOS OpenWindows Sun Microsystems. . Copyright (c) 1990 -2000, Model Technology Incorporated. . . Model Technology . Model Technology Incorporated 10450 SW Nimbus Avenue / Bldg. R-B Portland OR 97223-4347 USA
phone: 503-641-1340 fax: 503-526-5410 e-mail: [email protected], [email protected] home page: http://www.model.com support page: http://www.model.com/support
2
1 - Introduction( ) ............................................. 28 ModelSim graphic interface ............................................. 28 ( ModelSim’s)........................ 28 Standards supported......................................................................... 29 ( )...................................................... 29 Assumptions( )...................................................... 29 Sections in this document ( ) ............. 30 Command reference( ) ................................. 32 What is an "HDL item"( - " HDL ") ............ 32 Text conventions( ).................................. 33 Where to find our documentation ................................................... 33 ( ) ................................................. 33 Download a free PDF reader with Search ...................................... 34 ( PDF ) ............................................................................................................ 34 Technical support and updates( )................................................................................. 34
2 - Projects ( ) .................................................... 36 Introduction( ).................................................... 37 What are project? ( ?) ....................... 37 What are the benefits of projects?( ?)......................................................................... 37 How do projects differ from pre-5.5 versions?( 5.5?)37 Project conversion between versions( ) .............................................. 38 Getting started with projects( ) ............................................................................................. 38 Step 1 - Create a new project( 1)............................................................................ 39 Step 2 -Add items to the project ( 2) ......................................................... 39 Step 3 — Compile the files ( 3— ) .............................................................................. 40
Step 4 — Simulate a design ( 4— Other basic project operations (
The Project tab (
)........... 41 )41
) ................................................. 41
Sorting the list ( Project tab context menu (
)........................................................ 42 ) ........... 42
Changing compile order(
) ..... 43
Auto-generating compile order ( Grouping files (
-
)44 ).................................................... 44
Creating a Simulation Configuration ( ) ............................................................................... 44 Organizing projects with folders ( ) ........................................................................................... 45 Adding a folder(
) ............................................................ 45
Setting compiler options ( )46 Accessing projects from the command line ( ).......................................................................... 47
3 - Design Libraries ( )_.................................................. 48 Design library contents ( )............................................................................. 49 Design unit information( ) ........................................................................... 49 Design library types ( )....... 50 Working with design libraries ( )............................................................................. 50 Creating a library ( )................... 50 Managing library contents( ) ...................................................................... 51 Assigning a logical name to a design library ( )............................................................................. 52 Moving a library( )............. 54 Specifying the resource libraries( ) ...................................................... 54 Verilog resource libraries ( Verilog)............................................................................... 54
4
VHDL resource libraries ( VHDL )....................... 54 Predefined libraries( ) ............................ 55 Alternate IEEE libraries supplied ................................................................. 55 ( ) ...................................... 55 Rebuilding supplied libraries ( ) ....................................................................................................... 56 Regenerating your design libraries................................................................ 56 ( ) .................................... 56 Maintaining 32-bit and 64-bit versions in the same library ........................ 57 ( 3264) ..................................................................................................... 57
Importing FPGA libraries(
FPGA
)57
4 - VHDL Simulation( VHDL ) ........... 59 Compiling and simulating with the GUI ( GUI ) .............. 60 ModelSim variables( ModelSim)............... 60 Compiling VHDL designs( VHDL )........................................................................... 61 Creating a design library( )............................................................................. 61 Invoking the VHDL compiler( VHDL )..................................................................... 61 Dependency checking( ) ........... 61 Range and index checking ( ) ............................................................................. 61 Simulating VHDL designs ( VHDL )........................................................................... 62 Simulator resolution limit( )........................ 62 Simulating with an elaboration file ( )...................................... 63 Overview ( ).............................................. 63 Elaboration file flow ( ) ............................................................................... 63 Creating an elaboration file ( ).......................................... 64
5
Loading an elaboration file ( )...... 64 Modifying stimulus ( ).............................................. 64 Using with the PLI or FLI( PLI FLI)...................... 65 Syntax( ) ......................................................................................... 65
Using the TextIO package(
TextIO ) ..... 65
Syntax for file declaration ( )............ 66 Using STD_INPUT and STD_OUTPUT within ModelSim ........................ 66 ( STD_INPUT STD_OUTPUT ModelSim)................ 66
TextIO implementation issues(
TextIO)67
Writing strings and aggregates( ) ................... 67 Reading and writing hexadecimal numbers ................................................. 68 ( ) ......................................... 68 Dangling pointers( ) ...................................................... 68 The ENDLINE function( ENDLINE) .......................................... 69 The ENDFILE function( ENDFILE) ........................................... 69 Using alternative input/output files( – )................................................................................ 69 Providing stimulus ( ) ........ 69
Obtaining the VITAL specification and source code..................... 70 ( VITAL ).......... 70 VITAL packages( VITAL)................................................ 70 ModelSim VITAL compliance( VITAL ModelSim)71 VITAL compliance checking( VITAL compliance warnings(
VITAL).............. 71 VITAL). 71
Compiling and Simulating with accelerated VITAL packages..... 73 ( VITAL) .............................................................................................. 73 Util package ( Util)................................................................. 74 get_resolution() ................................................................................................ 74 init_signal_driver() .......................................................................................... 74 init_signal_spy() ............................................................................................... 75 signal_force() .................................................................................................... 75 signal_release()................................................................................................. 75 to_real()............................................................................................................. 75 to_time()............................................................................................................ 76
Foreign language interface(
).......... 77
5 - Verilog Simulation( Verilog )......... 78 Compilation( ).............................................. 80 Incremental compilation( ) ..... 81 Library usage( ) ................ 84 Verilog-XL compatible compiler arguments 6
(Verilog-XL ) 85 Verilog-XL ‘uselib compiler directive ( VerilogXL ‘ uselib).................................................. 86 Simulation( ).......................................... 88 Invoking the simulator( ) ............................................................... 88 Simulation resolution limit( ) ....................................... 88 Event ordering in Verilog designs( Verilog).......................................... 90 Negative timing check limits .......... ( ) ................................... 93 Verilog-XL compatible simulator arguments (Verilog-XL ) 96 Compiling for faster performance( ) ..................................... 96 Compiling with "-fast"( " - fast ") ............................................................................ 97 Compiling with +opt ( +opt ).................. 98 Compiling mixed designs with –fast ( –fast) ...................................... 98 Compiling gate-level designs with –fast ( –fast)......................... 99 Referencing the optimized design ( )........................................ 99 Enabling design object visibility with the +acc option....... ( +acc ).................................................................. 103 Using pre-compiled libraries( ). 105 Event order and optimized designs ( ) ........................... 105
7
Timing checks in optimized designs ( )................................................................... 105
Simulating with an elaboration file( ).................................................... 106 Overview( )............................................................. 106 Elaboration file flow ...................................................................................... 106 ( )................................................. 106 Creating an elaboration file ( ) .. 107 Loading an elaboration file( ).... 107 Modifying stimulus ( ) ............................................... 107 Using with the PLI or FLI( PLI FLI).................... 107 Syntax( ) ....................................................................................... 108
Cell Libraries( SDF timing annotation( Delay modes(
System Tasks(
) ........................................... 108 SDF )..................... 108 ) .............................................................. 108
) ............................................... 110
IEEE Std 1364 system tasks ( Std 1364 )........ 110 Verilog-XL compatible system tasks ........................................................... 112 (Verilog-XL ) ........................................ 112 $init_signal_driver system task( $init_signal_driver )114 $init_signal_spy system task( $init_signal_spy) ........ 114 $signal_force system task( $signal_force) .................. 114 $signal_release system task( $signal_release) ............ 115
Compiler Directives(
) ....................... 115
IEEE Std 1364 compiler directives( Std 1364 ) ................................................................................................. 116 Verilog-XL compatible compiler directives ................................................ 116 ( Verilog-XL ) ........................... 116
Verilog PLI/VPI .............................................................................. 118 Registering PLI applications( PLI)118 Registering VPI applications ( VPI) ............................................ 121 Compiling and linking PLI/VPI applications ......................................... 122 ( PLI/VPI) .. 122 Compiling and linking PLI/VPI C++ applications( PLI/VPI C++) .................................................. 125 Using 64-bit ModelSim with 32-bit PLI/VPI Applications( 64ModelSim 32PLI/VPI) .... 128 Specifying the PLI/VPI file to load .............................................................. 128 ( PLI/VPI ) .......................................... 128 PLI example( PLI)........................................................................... 129 VPI example ( VPI ) ........................................................................ 129 The PLI callback reason argument( PLI) 130 The sizetf callback function( sizetf)............................... 132 8
PLI object handles( PLI) ........................................... 132 Third party PLI applications( PLI)133 Support for VHDL objects( VHDL)............... 134 IEEE Std 1364 ACC routines ....................................................................... 135 ( Std 1364 ACC ) ................................................... 135 IEEE Std 1364 TF routines ( Std 1364 TF ) ....... 135 Verilog-XL compatible routines................................................................... 136 ( Verilog-XL).......................................... 136 64-bit support in the PLI ( 64PLI).................... 136 PLI/VPI tracing( PLI/VPI ) ................................................. 137 Debugging PLI/VPI application code( PLI/VPI) ........................................................................................................ 138
6 - Mixed VHDL and Verilog Designs........................... 139 ( VHDL Verilog).................... 139 Separate compilers, common design libraries( , ) .............................. 140 Access limitations in mixed-language designs( )...................................................................... 140 Simulator resolution limit( )............................................................................................ 140
Mapping data types(
) .................. 140
VHDL generics ( VHDL) ................................................................ 141 Verilog parameters( Verilog ) .................................................. 141 VHDL and Verilog port( VHDL Verilog ) ................................... 141 Verilog states( Verilog ) .............................................................. 142
VHDL instantiation of Verilog design units ................................. 144 (VHDL Verilog) ...................... 144 Verilog instantiation criteria( Verilog) .............. 144 Component declaration( ) ................................. 144 vgencomp component declaration................................................................ 146 ( vgencomp) ....................................................... 146
Verilog instantiation of VHDL design units ................................. 147 (Verilog VHDL) ...................... 147 VHDL instantiation criteria( SDF annotation( SDF
VHDL).................. 147 ) ............................................................. 148
7 – WLF files (datasets) and virtuals............................. 149 (WLF ( ) ).... 149 WLF files (datasets)( WLF ( ))149 Saving a simulation to a WLF file( WLF).................................... 150 Opening datasets( ) ........ 150 9
Viewing dataset structure ( )............................................................................ 150 Managing multiple datasets( ) ............................................................ 151 Saving at intervals with Dataset Snapshot( ) ................................................................................. 153
Virtual Objects (User-defined buses, and more).......................... 154 ( ( , . .)) .................................................................................. 154 Virtual signals( Virtual functions( Virtual regions( Virtual types(
) ............................................. 154 ) ........................................ 156 )............................................... 156 ) ...................................................... 157
Dataset, WLF file, and virtual commands .................................... 157 ( , WLF ) .. 157
8 - Graphic Interface( ) ...... 159 Window overview( Window) .............. 160 Common window features( )161 Quick access toolbars( ) ............................................................. 162 Drag and Drop( ) .......................... 162 Command history( ) ................ 163 Automatic window updating( ) .................................................. 163 Finding names, searching for values, and locating cursors ........................................................................................... 163 ( , , ).............................................. 163 Sorting HDL items( HDL ) .... 164 Multiple window copies( )164 Saving window layout( )164 Context menus( ) ........................... 164 Menu tear off( ) ................................... 164 Customizing menus and buttons( ) ............................................................................ 164
10
Tree window hierarchical view( )............................................................................................. 165
Main window(
)....................................................... 166
Workspace( ) ..................................................................... 167 Transcript( ) .................................................................................. 167 The Main window menu bar( ) ................ 168 The Main window toolbar( )174 The Main window status bar( ) ....... 176 Mouse and keyboard shortcuts ( ).................................................................................................. 177
Dataflow window ( Dataflow)............................................................................. 179 Adding items to the window ( ).................. 179 Links to other windows( ) ................................. 180 Dataflow window menu bar ( Dataflow) ................... 180 The Dataflow window toolbar( Dataflow). 183 Exploring the connectivity of your design( ) ......................................................................................................... 185 Zooming and panning ( ) ........ 186 Tracing events (causality)( ( ))187 Tracing the source of an unknown (X)( (X)) .............................................................................................. 188 Finding items by name in the Dataflow window( Dataflow) ............................................................................... 188 Printing and saving the display( ) .. 189 Configuring page setup( )... 190 Symbol mapping( )................................................ 190 Configuring window options( ) . 192
List window(
)............................................................ 192
HDL items you can view( HDL)...... 193 Adding HDL items to the List window( HDL List ) ................................................................................................................ 193 The List window menu bar ( )..................... 194 Editing and formatting HDL items in the List window( HDL List) ..................................... 196 Combining items in the List window( List)197 Setting List window display properties( )................................................................................................. 198 Finding items by name in the List window( List) ........................................................................................ 200 Searching for item values in the List window............................................. 200 ( ) ............................................ 200 Setting time markers in the List window .................................................... 201 ( ) ..................................... 201 11
Saving List window data to a file ................................................................. 202 ( )........................................... 202 List window keyboard shortcuts .................................................................. 202 ( List)................................................................... 202
Process window(
) ................................................ 203
The Process window menu bar(
Signals window(
Process) ................ 204
) .................................................. 206
The Signals window menu bar( Signals) ................ 207 Selecting HDL item types to view( HDL, )..................................................................................................... 209 Forcing signal and net values( ) ........................................................................................................... 210 Adding HDL items to the Wave and List windows or a WLF file............ 211 ( HDL Wave List WLF)... 211 Finding HDL items in the Signals window ( HDL )...................................................................... 212 Setting signal breakpoints( )... 213 Defining clock signals( ). 213
Source window(
) .................................................. 214
The Source window menu bar ( Source) ................... 214 The Source window toolbar( Source) 217 Setting file-line breakpoints( ) ................................................................................................. 219 Checking HDL item values and descriptions.............................................. 219 ( HDL )................................. 219 Finding and replacing in the Source window( Source)............................................................................................... 220 Setting tab stops in the Source window and Main window Transcript ... 220 ( Source Main) ................................................................................................. 220
Structure window(
)......................................... 222
The Structure window menu bar( ).... 223 Structure window context menu( Structure) .. 224 Finding items in the Structure window( ).......................................................................................... 225
Variables window(
) ...................................... 225
The Variables window menu bar( ) . 226 Finding HDL items in the Variables window( HDL Variables ).......................................................................................... 228
Wave window( Pathname pane( Values pane( Waveform pane( Cursor panes(
) .................................................... 228 ) ....................................................... 228 ) .................................................................. 229 ).................................. 229 )................................................................... 229 12
HDL items you can view( HDL )....... 230 Adding HDL items in the Wave window( HDL Wave)..................................................................................................... 231 The Wave window menu bar( ) ............. 232 The Wave window toolbar( Wave).... 236 Using Dividers( ) ....................................... 238 Splitting Wave window panes( Wave) .......... 238 Combining items in the Wave window ........................................................ 239 ( Wave) ................................................... 239 Editing and formatting HDL items in the Wave window.......................... 240 ( HDL Wave). 240 Setting Wave window display properties .................................................... 241 ( Wave) ...................................... 241 Sorting a group of HDL items( HDL)242 Setting signal breakpoints( ).... 242 Finding items by name or value in the Wave window( Wave) ................................. 243 Searching for item values in the Wave window.......................................... 243 ( Wave) ................................................ 243 Using time cursors in the Wave window( Wave) ................................................................................ 244 Finding a cursor( )................................................. 245 Making cursor measurements( ) .............. 245 Zooming - changing the waveform display range( ) .............................................................................. 246 Saving zoom range and scroll position with bookmarks ........................... 247 ( )........................................................ 247 Wave window mouse and keyboard shortcuts ........................................... 248 ( Wave)......................... 248 Printing and saving waveforms( ) ...................................................................................................... 249
Compiling with the graphic interface ( ) ........................................................ 253 Locating source errors during compilation( ) .................................................................. 253 Setting default compile options( ) .................................................................................. 253
Simulating with the graphic interface( ) ........................................................ 257 Design tab( VHDL tab( Verilog tab (
) ...................................................................... 257 VHDL) ....................................................................... 258 Verilog)..................................................................... 260 13
Libraries tab( ) ......................................................... 261 SDF tab( SDF) ............................................................................... 261 Options tab( )...................................................................... 262 Setting default simulation options( ) ............................................... 263
Creating and managing breakpoints( ) .................................................................. 265 Signal breakpoints( File-line breakpoints( Breakpoints dialog(
-
).................................... 265 ) ...................... 266 ) ...................................... 266
Miscellaneous tools and add-ons( )...................................................... 268 The GUI Expression Builder ........................................................................ 269 ( GUI) ................................................................ 269 Language templates( )...................................................... 270 The Button Adder ( )................................................. 271 The Macro Helper ( ) ................................................... 272 The Tcl Debugger ( Tcl )............................................................. 273
Graphic interface commands( ) .................................................................................... 277
9 - Performance Analyzer ( ) ............................ 279 Introducing Performance Analysis................................ 280 ( )280 A Statistical Sampling Profiler (
) .................................................................... 281 Getting Started ( ) .............................................. 281 Interpreting the data( )........ 282 Viewing Performance Analyzer Results ( ) ..... 282 Interpreting the Name Field( )................................................................................. 283 Interpreting the Under(%) and In(%) Fields( Under(%) In(%)) ............... 284
14
Differences in the Ranked and Hierarchical Views ................................... 284 ( )....... 284
Reporting results ( ) .............................. 285 Performance Analyzer preference variables ................................ 285 ( ).................................................................... 285 Performance Analyzer commands( )................................................................... 286
10 - Code Coverage( Enabling Code Coverage ( The coverage_summary window (
) ........................... 287 _
) ......... 288 ).... 288
Summary information( ) ........................................ 288 Misses tab( )................................................................. 289 Excluded tab( )........................................................ 289 The coverage_summary window menu bar( coverage_summary )...................................................................................... 290
Coverage data in the Source window( Source ) ............................................................................................ 290 Excluding lines and files(
)......................... 291
Merging coverage report files( )....................................................................................... 291 Exclusion filter files( ) ................ 292 Syntax( ) ....................................................................................... 292 Arguments( ) ............................................................................. 292 Example( ) ......................................................................................... 292 Default filter file( ) ................. 293
Code Coverage preference variables( ) ...................................................... 293 Code Coverage commands ( )............ 293
11 - Waveform Comparison( ) ..... 294 Introduction( )................................................. 295 Two modes of comparison( ) 296 Comparing hierarchical and flattened designs( ) ......................... 296 Graphic interface to Waveform Comparison( Waveform Comparison).......................... 297
15
Opening dataset comparison( ). 297 Adding signals, regions and/or clocks( , )................................................................................ 298 Setting compare options( ) ............... 300 Wave window display ( Wave) ..................................... 301 Printing compare differences( )................. 303 Compare objects in the List window( List)303
Waveform Comparison preference variables ( Waveform Comparison).. 304 Waveform Comparison commands ( Waveform Comparison).............................................. 304
12 - Signal Spy( )..................... 305 Introduction( ).................................................. 306 Designed for testbenches( testbenches)...................................................................... 306 init_signal_driver ............................................................ 306 Call only once( )................................ 307 Syntax( )......................................................... 307 Returns( )............................................................ 307 Arguments( )............................................... 307 Related procedures( ).............. 308 Limitations( )........................................... 308 Example( )........................................................... 308 init_signal_spy ................................................................. 309 Call only once( )................................ 309 Syntax( )......................................................... 309 Returns( )............................................................ 309 Arguments( )................................................ 309 Related functions( )..................... 310 Limitations( )............................................ 310 Example( )........................................................... 310 signal_force ...................................................................... 310 Syntax( )......................................................... 310 Returns( )............................................................ 311 Arguments( )................................................ 311
16
Related functions( )................................................... 311 Limitations( ) .......................................................................... 311 Example( ) ......................................................................................... 311
signal_release................................................................................... 312 Syntax( ) ....................................................................................... 312 Returns( ) .......................................................................................... 312 Arguments( ) .............................................................................. 312 Related functions( )................................................... 313 Limitations( ) .......................................................................... 313 Example( ) ......................................................................................... 313
$init_signal_driver .......................................................................... 313 Call only once( ) .............................................................. 313 Syntax( ) ....................................................................................... 314 Returns( ) .......................................................................................... 314 Arguments( ) .............................................................................. 314 Related procedures( )............................................ 314 Limitations( ) .......................................................................... 314 Example( ) ......................................................................................... 314
$init_signal_spy ............................................................................... 315 Call only once( ) .............................................................. 315 Syntax( ) ....................................................................................... 315 Returns( ) .......................................................................................... 315 Arguments( ) .............................................................................. 315 Related functions( )................................................... 316 Limitations( ) .......................................................................... 316 Example( ) ......................................................................................... 316
$signal_force.................................................................................... 316 Syntax( ) ....................................................................................... 317 Returns( ) .......................................................................................... 317 Arguments( ) .............................................................................. 317 Related functions( )................................................... 317 Limitations( ) .......................................................................... 317 Example( ) ......................................................................................... 317
$signal_release................................................................................. 318 Syntax( ) ....................................................................................... 318 Returns( ) .......................................................................................... 318 Arguments( ) .............................................................................. 318 Related functions( )................................................... 318 Limitations( ) .......................................................................... 318 Example( ) ......................................................................................... 319
13 - Standard Delay Format (SDF) Timing Annotation320 ( (SDF) ) ....................................... 320 17
Specifying SDF files for simulation( SDF ) ....................................................... 321 Instance specification ( )............................................................................ 321 SDF specification with the GUI( SDF GUI) ................. 321 Errors and warnings( )................................ 322
VHDL VITAL SDF......................................................................... 322 SDF to VHDL generic matching( SDF VHDL) ......................................................................................................................... 322 Resolving errors( ) .................................................... 323
Verilog SDF ..................................................................................... 323 The $sdf_annotate system task( $sdf_annotate) ........ 324 SDF to Verilog construct matching( SDF Verilog) ........................................................................................................... 325 Optional edge specifications( )327 Optional conditions( ) ....................................... 329 Rounded timing values( )............................................................................................ 329
SDF for Mixed VHDL and Verilog Designs( SDF VHDL Verilog) ........................................................... 330 Interconnect delays( ) ............................... 330 Troubleshooting( ) ...................... 330 Specifying the wrong instance( ) .... 330 Mistaking a component or module name for an instance label ( )....................... 331 Forgetting to specify the instance( ) 331
14 - Value Change Dump (VCD) Files ( (VCD)) ........................................ 333 ModelSim VCD commands and VCD tasks ( ModelSim VCD VCD )_............. 334 Creating a VCD file( VCD) .............. 336 Flow for four-state VCD file( ё VCD)................................................. 336 Flow for extended VCD file( VCD) ......................................... 336 Case sensitivity( )........ 336 Resimulating a design from a VCD file ( VCD )....... 337
18
Example 1 — Verilog counter( Example 2 — VHDL adder( Example 3 — Mixed-HDL design(
1-
ё
23-
Verilog ) .................. 337 VHDL)...................... 337 HDL )338
A VCD file from source to output(VCD ) .................................................................................... 338 VHDL source code( VHDL)............................................ 338 VCD simulator commands( VCD )339 VCD output( VCD)............................................................................ 339
Capturing port driver data ............................................................ 340 ( ) ........................................ 340 Supported TSSI states ( TSSI)................. 340 Strength values( ) ........................................................ 341 Port identifier code ( ) ................................. 341 Example VCD output from vcd dumpports............................................... 341 ( VCD vcd dumpports) ................................................ 341
15 - Logic Modeling SmartModels ( )........................................................................... 341 VHDL SmartModel interface (VHDL
)..................... 342
Creating foreign architectures with sm_entity ........................................... 343 ( sm_entity)......................................... 343 Vector ports( ) ................................................................ 347 Command channel( ) ....................................................... 347 SmartModel Windows( Windows) ............... 348 Memory arrays ( ) ......................................................... 350
Verilog SmartModel interface(Verilog )....................................................... 350 Linking the LMTV interface to the simulator( LMTV ) ............................................................ 350
16 - Logic Modeling Hardware Models (
)351
VHDL Hardware Model interface ( VHDL) ................................ 352 Creating foreign architectures with hm_entity ( hm_entity) ........................................ 353 Vector ports( ) ...................................................................... 356 Hardware model commands( ) ............... 357
17- Tcl and macros (DO files) ( Tcl (DO files)) ................................ 357 19
Tcl features within ModelSim ( Tcl ModelSim)....... 358 Tcl References( Tcl)......................................................... 359 Tcl tutorial(
Tcl ) ................................................ 359
Tcl commands ( Tcl command syntax(
Tcl) ...................................................... 359 Tcl)......................... 360
if command syntax ( if) ............................................ 362 set command syntax( set )........................................ 363 Command substitution ( ) ............................................... 364 Command separator( ) ............................................. 364 Multiple-line commands( ).............................. 364 Evaluation order ( ) ........................................................ 365 Tcl relational expression evaluation( Tcl) ............................................................................................ 365 Variable substitution( )............................................... 365 System commands ( ) ................................................... 366
List processing ( ) .......................................... 366 ModelSim Tcl commands ( ModelSim Tcl) ................. 367 ModelSim Tcl time commands ( ModelSim Tcl) ................................................................................. 368 Conversions( Relations( Arithmetic (
Tcl examples( Example 1( Example 2(
Macros (DO files)(
) .................................................................. 368 ) ................................................................................. 369 )............................................................................ 369
Tcl)......................................................... 370 1) .................................................................................. 370 2) .................................................................................. 372
(DO
) )..................... 374
Creating DO files( DO ) .................................................... 374 Using Parameters with DO files( DO )........................................................................................................ 375 Making macro parameters optional( )........................................................................ 375 Useful commands for handling breakpoints and errors( )....................... 376 Error action in DO files( DO ) .............. 377 Using the Tcl source command with DO files( source Tcl DO ) ......................................................... 377
A - ModelSim Variables( ModelSim ) .... 378 Variable settings report( )...................................................................... 379
20
Personal preferences( ) .................. 379 Returning to the original ModelSim defaults ............................... 380 ( ModelSim )....................................................................................... 380 Environment variables( ) .............................. 380 ModelSim Environment Variables( ModelSim) ...... 381 Creating environment variables in Windows( Windows)......................................................................................... 382 Referencing environment variables within ModelSim( ModelSim) ................................................................ 383 Removing temp files (VSOUT)( (VSOUT))384
Preference variables located in INI files ( , INI
) ............................ 384
[Library] library path variables( [ ] )................................................................................................... 384 [vcom] VHDL compiler control variables................................................... 385 ( [vcom] VHDL )....................... 385 [vlog] Verilog compiler control variables( Verilog ) ................................................................................... 386 [vsim] simulator control variables ( ) ........................................................................... 387 [lmc] Logic Modeling variables( [lmc] )........................................................................................... 391 Setting variables in INI files ( INI ). 391 Reading variable values from the INI file( INI )...................................................................................................... 392 Commonly used INI variables ( INI)392
Preference variables located in TCL files ..................................... 395 ( , TCL )............................................................................................ 395 User-defined variables ( More preferences( ё
) 396 ).......................................................... 396
Variable precedence( )...................... 396 Simulator state variables( ) ............................................................................. 397 Referencing simulator state variables( )........................................................ 397 Special considerations for $now( $now)397
B - ModelSim shortcuts (
ModelSim) ............. 398
21
Wave window mouse and keyboard shortcuts( Wave) .................... 399 List window keyboard shortcuts( List).................................................................. 400 Command shortcuts( ).......................... 400 Command history shortcuts( )........................................................................................... 400 Mouse and keyboard shortcuts in the Main ................................. 401 and Source windows( Main Source) .......................................... 401 Right mouse button(
) ........................................... 403
C - ModelSim messages(
ModelSim) ........ 403
ModelSim message system(
ModelSim).... 404
Message format( Getting more information(
) ........................................................ 404 ).......... 405
Suppressing warning messages( ) .................................................. 405 Suppressing VCOM warning messages( VCOM)................................................... 405 Suppressing VLOG warning messages( VLOG).................................................... 406 Suppressing VSIM warning messages( VSIM) ..................................................... 406
Exit codes( Miscellaneous messages(
)...................................................... 406 )..................... 408
Lock message( Tcl Initialization error 2( Too few port connections(
).................................................... 408 Tcl) ...................... 408 ) ....................... 409
2
D - Using the FLEXlm License Manager ( FLEXlm)........................ 410 Starting the license server daemon( daemon ) ........................................................................ 411 Locating the license file( ) .............................................................................. 411 Controlling the license file search( ) ............................................................ 411
22
Manual start( )........................................................................ 412 Automatic start at boot time( ) .................................................................................. 413 What to do if another application uses FLEXlm( FLEXlm) ............................................ 413
Format of the license file( Feature names(
) ...... 413 ) .................................................................. 414
Format of the daemon options file( daemon)............................................................................................ 414 License administration tools( ) .................................................. 415 lmstat............................................................................................................... 416 lmdown............................................................................................................ 416 lmremove ........................................................................................................ 417 lmreread.......................................................................................................... 417 Administration tools for Windows ( Windows) .......................................................... 418
E - System initialization(
)418
Files accessed during startup( ) ........................................................................................... 418 Environment variables accessed during startup( ) .......................................... 419 Initialization sequence( ) .................... 420
F - Tips and Techniques( )............. 422 How to use checkpoint/restore( / )...................... 423 The difference between checkpoint/restore and restarting ( / ) ............................................................. 425 Using macros with restart and checkpoint/restore ( checkpoint/restore.)......................................................... 425 Running command-line and batch-mode simulations( ) ............... 425 Command-line mode( ) .... 426 Batch mode( ) ................................... 427
23
Source code security and -nodebug( –nodebug) ..................................... 427 Saving and viewing waveforms in batch mode ( ) ......................................................... 428 Setting up libraries for group use ( ) ............................................................. 429 Using a DO file to test for assertions( DO )............................ 429 Sampling signals at a clock change( )................ 429 Converting signal values to strings( )................... 430 Converting an integer into a bit_vector ( bit_vector) ............ 430 Maintaining 32-bit and 64-bit modules in the same library ( 3264)...................... 431 Hiding library cell signals when saving a waveform file( ).............. 431 Examining constants in a package( )........................................................ 432 Bus contention checking( )432 Bus float checking( ).... 433 Design stability checking( ) .......................................................................... 433 Toggle checking( ) ............... 434 Detecting infinite zero-delay loops................................. 434 ( ) ...................................................................... 434
24
Referencing source files with location maps................................. 435 ( )435 Using location mapping( )435 Pathname syntax( ) .............................................. 436 How location mapping works( ) .............................................................................................. 436 Mapping with Tcl variables( Tcl).......... 436
Improve performance by locking memory on HP-UX 10.2 ........ 437 ( HPUX 10.2) ........................................................................................... 437 Configuring memory locking( )437 Limitations( ) .......................................................................... 437 System parameter setting( ) ............. 438
Improve performance of large simulations on Sun/Solaris( Sun/Solaris) ........................................................... 438 Enabling shared memory( )........................................................................................................... 438 How it works( )................................................................. 439
Performance affected by scheduled events being cancelled( ё ) .................................................................. 439 Modeling memory in VHDL( VHDL) .......................................................................................................... 440 Configuring a List trigger with Expression Builder ................... 444 ( ) .................................................................................... 444 Delta delays( ).................................................... 445
G - ModelSim Tk widgets( ModelSim Tk) .................................................................. 447 Widgets and the ModelSim GUI( GUI ModelSim) ............................................................ 448 MTI tree widget( MTI) ....... 449 Index arguments( ) ................. 449
25
Tree commands( Tree options( Additional Wave tree options(
).................................................. 450 ).......................................................... 455 Wave). 457
Wave tree commands( Wave) ............................. 458 Wave tree zoom commands( Wave) .................................................................................. 460 Wave tree cursor commands( Wave)461 Tree widget default bindings( ) .............................................................. 462 MTI vlist widget( MTI vlist )........................... 463 Vlist widget commands ( Vlist) ...... 463 Vlist widget options( Vlist) .................. 468 Miscellaneous commands( ) ..................... 470
H - What’s new in ModelSim( ModelSim)471 New features( ) ................................... 471 Command and variable changes( ) ................................................................... 472 Documentation changes ( )473 GUI changes in version 5.6( 5.6)................................ 474 Main window changes( ) .. 475 Menu bar( )............................................... 475 File menu( File)..................................................... 475 Design menu( ) ....................................... 476 View menu( ) .............................. 476 Project menu( )....................................... 477 Run menu ( ).................................. 477 Compare menu( )............................... 478 Macro menu( ) ........................................... 478 Options menu( )......................................... 478 Dataflow window changes ( Dataflow)479 List window changes( List) ............... 479 Edit menu( )............................. 479 Markers menu( )............................... 480
26
Prop menu(
) ......................................................................... 480
Signals window changes( Edit menu ( View menu ( Context menu (
).......................................................... 481 ) ........................................................... 481 ) ........................................................... 481
Source window changes( File menu( Edit menu( Object menu ( Options menu(
Signals) .................... 481
Source) ..................... 481
).............................................................................. 481 )........................................................... 481 )................................................................. 481 ) ....................................................................... 482
Structure window changes( Variables window changes( Edit menu ( View menu(
Wave window changes(
Structure)............ 482 Variables)............ 482 ).......................................................... 482 ) ............................................................ 482
Wave) ......................... 482
Menu bar and toolbar ( )... 482 File menu ( )............................................................................. 482 Edit menu ( ).......................................................... 483 Cursor menu ( ).................................................................... 483 Zoom menu ( )............................................... 484 Compare menu ( )........................................................... 484 Bookmark menu ( ) ........................................................... 484
License Agreement(
) ....... 533
27
1 - Introduction(
) ModelSim
- " HDL
"
ModelSim SE/EE WINDOWS98/Me/ NT 2000/XP. ModelSim -
,
5.6
UNIX, Microsoft
README .
.
ModelSim graphic interface ( ModelSim’s) , ModelSim .
,
,
: • SPARCstation OpenWindows, OSF/Motif,
CDE
• IBM RISC System/6000 OSF/Motif • Hewlett-Packard HP9000 Series 700 HPVUE, OSF/Motif, • Linux (Red Hat v. 6/7) KDE • Microsoft Windows NT
CDE
GNOME
WINDOWS 98/ME/ NT /2000/XP ModelSim
Tcl/TK,
,
. , 28
(
."Preference variables located in INI and MPF files" ( " INI MPF ") , "Graphic interface commands"( " ") ) , , . . " Tcl ModelSim " Tcl. ModelSim,
Graphic Interface(
.,
,
8-
).
Standards supported (
)
ModelSim VHDL , IEEE 1076-1987 1076-1993 VHDL, 1164-1993 Standard Multivalue Logic System for VHDL Interoperability, ( VHDL ), 1076.2-1996 Standard VHDL Mathematical Packages standards. ( VHDL). ModelSim VHDL IEEE 1076-1987
,
1076-1993.
ModelSim Verilog IEEE Std 1364-1995 Standard Hardware Description Language Based on the Verilog Hardware Description Language ( , Verilog ). Verilog Verilog LRM 2.0 . PLI (Programming Language Interface) VCD (Value Change Dump) ModelSim PE
2.2b,
SE.
, SDF 1.0 3.0, VITAL VITAL’ 95 – IEEE 1076.4-1995 , VITAL2000 – IEEE 1076.4-2000.
Assumptions( ,
) .
: OpenWindows, OSF/Motif, CDE, HP VUE, KDE, GNOME, Microsoft Windows 98/Me/NT/2000/XP.. , VHDL Verilog. ModelSim , HDL, , . HDLs, - www.model.com . , , ModelSim
29
ModelSim. ModelSim. web
ModelSim
ModelSim : www.model.com. ,
Start
Here for ModelSim, website: www.model.com.
ModelSim. Start Here
Sections in this document (
) ё
, : 2"
" ModelSim, .
3HDL, ,
,
ModelSim,
,
,
.
4 - VHDL -
VHDL
ModelSim.
5 - Verilog -
Verilog
6-
VHDL
ModelSim.
Verilog (SKS- single-kernel simulation) ModelSim/Plus
VHDL /
, Verilog.
, 7 - WLF
HDLs. (
) virtuals – ModelSim.
8, ModelSim .
ModelSim. ,
930
,
ModelSim ,
. 10 – . , . 11 , . 12 – , Verilog , ,
VHDL ,
,
VHDL
.
13 -
(SDF- Standard Delay Format)
ModelSim SDF ( . .
SDF,
14 -
VITAL SDF
) Verilog
(VCD - Value Change Dump) Verilog VCD ModelSim.
Model Technology’s VCD ,
VHDL. 15 -
SmartModels(
)
SmartModel Library SmartModel Windows ModelSim. 16 – ModelSim. 17 - Tcl
(DO files) Tcl (tool command language ModelSim.
),
A-
ModelSim ,
,
ModelSim.
31
B–
ModelSim .
ModelSim C-C
ModelSim ModelSim.
D-
FLEXlm FLEXlm Model Technology's ModelSim.
E,
ModelSim.
FModelSim . G–
ModelSim Tk Tk , ModelSim
H-
ModelSim
ModelSim 5.6 .
Command reference( ModelSim. "CR" (
) ModelSim Command Reference. Command Reference –
,"
" (CR-27)).
What is an "HDL item"(
- " HDL
VHDL
ModelSim Verilog, HDL ”
, Verilog
Verilog, “HDL” . :
,
VHDL
, ,
,
), ,
,
VHDL ,“
, (
")
,
, , ,
,
32
Text conventions(
)
,
:
italic text ,
ё
ё ,
bold text
, ,
,
ё
,
,
monospace type
(>)
, : File > Quit UNIX ,
-
Windows
UPPER CASE (
, DO, , WLF, INI, MPF, PDF,
ModelSim . .)
Where to find our documentation ( ) ModelSim www.model.com/support/documentation.asp
Start Here SE/EE (
ModelSim
ModelSim )
ModelSim SE Quick Guide ( )
ModelSim SE ModelSim SE
:
PDF
PDF
PDF, HTML PDF, HTML
Main window > Help > SE Documentation; Support page web site:: www.model.com ModelSim Main window > Help > SE Documentation; Support page web site:: www.model.com Main window > Help > SE Documentation, Support page web site:: www.model.com Main window > Help > SE Documentation 33
ModelSim SE
Std_DevelopersKit User’s Manual( _ -
PDF, HTML PDF, HTML PDF
Main window > Help > SE Documentation Main window > Help > SE Documentation www.model.com/support/pdf/sdk_um.pdf
Mentor Graphics QuickHDL. ) Command Help
ASCII
Error message help
ASCII
Tcl Man Pages ( Tcl)
HTML
Ч
[
] Main,
verror
HTML
Main window > Help > Tcl Man Pages, contents.htm \modeltech\docs\tcl_help_html www.model.com/resources/techdocs.asp
HTML
www.model.com/resources/faqs.asp
ASCII
Main window > Help > Technotes, \modeltech\docs\technotes
Download a free PDF reader with Search ( PDF Model Technology’s PDF Adobe http://www.adobe.com. Reader with Search ;
) Adobe Acrobat Reader. ModelSim. , Acrobat , .
Technical support and updates( ) Web
Model Technology
,
,
.
www.model.com/support/default.asp , www.model.com/contact_us.asp .
.
www.model.com/products/release.asp
34
. www.model.com/support/register_news_list.asp
35
2 - Projects (
-
)
? ? -5.5?
1— 2— 3— 4—
-
ModelSim. ModelSim.
Introduction(
)
What are project? (
?) HDL
. "
,
,
",
. mpf, .
, ,
. :
•
HDL
•
,
README
• •
What are the benefits of projects?(
?) .
•
ModelSim;
•
;
• ;
, HDL
• ;
,
•
;
•
"
";
,
, •
.ini, ModelSim
; ,
.ini
How do projects differ from pre-5.5 versions?( 5.5?) 5.5. : • •
. ; .
37
• .
; ,
, . •
(
,
,
)
.mpf. ,
:
,
5.5
. ,
,
5.5. 15
,
, .
Project conversion between versions( ) .
,
(
5.6,
,
5.5), ,
.
. , .
< ,
.mpf.bak .
Getting started with projects(
) .
1— .mp
.
2— HDL, ,
,
. . 3— ModelSim . 4— , .
38
Step 1 - Create a new project(
1-
File > New > Project ( Create Project.
)
Main),
.
: • . • ,
.
.mpf
• .
"
" . "work."
,
, Project Location. OK,
Project Add Items to the Project .
Step 2 -Add items to the project (
2-
)
Add Items to the Project ( :
)
• VHDL, Verilog, Tcl, .
,
Source.
• . •
.
ё
, .
" •
" ё
. "
.
"
.
39
VHDL, Verilog, Tcl,
Create New File Source. selecting File > Add to Project > New File ( (2Windows; 3UNIX) Project > New file.
, Main) Project
Add to
:
Create Project File • . • .
VHDL, Verilog, TCL,
.
• ,
. ,
. "
OK, Project
Source
ё
, Main.
Add Existing File (
) ,
File (
"
.
)
,
UNIX)
Project
File > Add to Project > Existing (2Windows; 3Add to Project > Existing File. :
Add file to Project • ,
.
. • ." (
" , .v –
, Verilog).
• ,
.
,
. "
"
.
•
/ . OK,
( )
ё ( )
Project
Main.
Step 3 — Compile the files (
3—
) 40
.
Project , , Compile > Compile All (
, Project
Main)
Compile > Compile All. , ,
Library
"+",
.
Step 4 — Simulate a design (
4—
)
, Simulate.
,
.
. ,
Wave .
ModelSim.
Other basic project operations (
)
ModelSim ,
. ,
File > Close > Project ( Library Structure ( .
File > Delete > Project (
The Project tab (
File > Open > Project (
Main). " sim "
Main).
Project, )
Main).
) 41
Project
. .
-
. ,
. VHDL
Verilog.
;X
, ;
. –
,
Windows
ё , Compile All. -
,
. , . Customize Project View. Project
Customize View.
Sorting the list (
) .
,
;
,
. , (
)
(
).
Project tab context menu ( ,
ё
, UNIX)
) Project
, Windows; 3-
( 2-
-
. :
• ModelSim. • ( ).
,
, -
Compile Selected,
.
• ,
.
• ,
.
• . "
"
. 42
• . • . • ( ) .
"
"
. • . • . • . "
"
.
• . "
"
.
• . . • Project
.
• View/change ( ).
Changing compile order(
) , ModelSim . : 1)
; 2)
. ,
1
Compile > Compile Order ( Project.
:
Main)
43
,
2 .
-
, .
Auto-generating compile order ( Auto Generate
-
)
Compile Order( , ;
)"
" . -
, . ,
( ) .
Grouping files (
) Compile Order, , , .
. Verilog Verilog. , 1
:
,
.
Group
2
,
,
Ungroup.
Creating a Simulation Configuration ( ) ( .
,
)
,
, ,
(generics),
SDF
. .
, ( ,
, top_config). Project, . 44
, 1
:
File > Add to Project > Simulation Conf ( Project .
2 3
Main)
Simulation Configuration Name. ,
( ).
( )
4 5
Add. , .
"
". Project.
OK, ,
.
Organizing projects with folders ( ) ,
,
.
"
"
. –
.
,
.
Adding a folder(
) ,
File > Add to Project > Folder.
, Project .
,
OK.
, ,
.
,
.
, Properties
(
, Properties
). 45
Setting compiler options ( VHDL
Verilog
(vcom
) vlog,
)
, . ,
Compile > Compile Options (
).
. , Project
( ) Properties.
,
. VHDL Verilog,
VHDL
VHDL
Verilog
, General,
, , General ,
Verilog General.
General
. .
, .
,
,
,
General
:
• Do Not Compile( ,
) .
• Compile to library ( ,
) ; .
• Place in Folder(
) ,
( ). "
.
• File Properties (
) (
,
"
,
,
, VHDL
, Project.
).
Verilog
"
". ,
:
•
, (
)
" " " OK, ModelSim
.
, "
. •
VHDL VHDL
Verilog,
Verilog, . 46
Accessing projects from the command line ( ) ,
ModelSim GUI ( ).
, ,
. , MODELSIM (< Project_Root_Dir > / < Project_Name > .mpf). project (CR-192) , .
.
47
3 - Design Libraries (
)_
Verylog VHDL
32... FPGA VHDL
64-
,
, ;
. Verilog .
,
, ModelSim ,
Design library contents ( -
)
,
. , ,
;
Verilog
VHDL , UDPs (user defined primitives -
). : • ,
,
,
,
UDPs. . • . .
, .
Design unit information( , •
) :
,
• •
ё
49
Design library types (
) :
-
.
,
. ,
.
; )
(
,
. ModelSim; (
work, ).
, ,
. work -
.
,
.
Working with design libraries (
) VHDL
ModelSim, , ё
,
Verilog.
; .
Creating a library ( (
) "
" ), ModelSim .
, ,
. ModelSim. ModelSim
UNIX / DOS,
vlib (CR-
285): vlib ModelSim, > New > Library (
File
Main).
Create a New Library • Create a new library and a logical mapping to it (
: ё)
50
Library Name. ,
.
, . • Create a map to an existing library (
) Library Name,
Browse ,
Library Maps to • Library Name (
. ) .
• Library Physical Name (
) . ModelSim
.
• library Maps to(
) . reate a map to an existing
Browse , library . OK, ModelSim ,
_info
"[Library] library path variables([ .
,
ModelSim. [Library-
modelsim.ini ]
,
:
.
_info
)"
-
; GUI ModelSim,
, vlib (CR-282). ,
UNIX
].
Windows.
Managing library contents(
) ,
,
,
, . Library (
,
, (
Library (
Windows — 2- , UNIX — 3-
,
,
) , ( M),
(E),
.
. )
,
Type.
, )
Library .
:
51
• Simulate .
- vsim (CR-296).
• Edit Source, "
Edit Library Mapping (
, ")
• Refresh ( ) - vcom (CR-250)
.
-refresh.
• Recompile .
-
vcom (CR-250). • Optimize Verilog. (CR-286)
- vlog "
+opt.
+opt "
. • Delete .
- vdel (CR-
256). ,
,
.
,
, .
ё
. ,
,
Delete.
, .
• View Customize ,
,
,
.
• View Update . • New
ё
.
• Properties ( .
,
,
Assigning a logical name to a design library ( VHDL
,
,
. .)
)
, ModelSim. 52
, ModelSim (
),
,
,
, . GUI,
,
,
. GUI , Edit
.. .
,
ё
,
: ё
• Library Mapping Name (
)
. • Library Pathname (
) .
Library mapping from the command line ( )
, ; ё
:
vmap UNIX/DOS ModelSim. vmap (CR-295) modelsim.ini , modelsim.ini, [Library]
modelsim.ini. ,
.
: =
,
modelsim.ini :
[Library] work = /usr/rick/design my_asic = /usr/rick/design work ,
my_asic .
53
Unix UNIX
,
: ln -s vmap (CR-295 )
, .
,
: vmap
: •
modelsim.ini.
•
,
modelsim.ini modelsim.ini,
, . ,
,
.
Moving a library(
) . ,
, .
Specifying the resource libraries( ) Verilog resource libraries ( ModelSim .
Verilog) Verilog
vlog (CR-286), . UDPs ( , ,
VHDL) .
"
".
VHDL resource libraries (
VHDL )
VHDL,
library VHDL, , .
library library .
, . 54
,
library
,
ё
vcom (CR-250)
;
. ,
work. ,
vcom- work .
Predefined libraries(
) VHDL.
std
standard
.
textio,
Э 1987
.
ANSI/IEEE Std 1076-1993. use VHDL , . .
VHDL, Std 1076TextIO ".
,"
, —
use
,
:
LIBRARY std, work; USE std.standard.all ,
,
, /
.all ,
USE std, .
. standard VHDL,
, USE. - work, .
library ,
, USE ,
, , ,
, . : Verilog
-L
-Lf
Verilog vlog (CR-286).
Alternate IEEE libraries supplied (
VHDL.
) :
• ieeepure , std_logic_1164
(
ModelSim).
• ieee Synopsys , Model Technology, 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, vital_timing. , , modelsim.ini. 55
modelsim.ini
ieee.
Rebuilding supplied libraries (
) ,
modeltech. vhdl_src; Windows (rebldlibs.do). DO ModelSim
, :
do rebldlibs.do (
,
-
,
modeltech
). UNIX (rebuild_libs.csh rebuild_libs.sh). rebuild_libs ,
, modeltech.
,
: 1993, vcom (CR-250)
,
-93.
Regenerating your design libraries (
)
ModelSim, . ,
README, ,
. Refresh
Library ( " 250)
" ),
-refresh
vcom (CR-
vlog (CR-286). ,
vcom VHDL Verilog.
,
-refresh, vlog
,
;
-refresh, -work ,
. ,
,
Verilog
,
mylib,
VHDL
:
vcom -work mylib -refresh vlog -work mylib -refresh -refresh -
, .
,
,
, ModelSim (4.6 .
).
,
, (
Verilog)
. 56
,
: 1993, vcom (CR-250)
,
-93
.
Maintaining 32-bit and 64-bit versions in the same library ( 3264) 32,
ModelSim, . (64-
32-
"
64-
),
"
.
32-
:
ModelSim:
vcom file1.vhd vcom file2.vhd ,
64-
ModelSim:
vcom -refresh , , ModelSim
. ,
"
Importing FPGA libraries(
".
FPGA
)
ModelSim FPGA. . : FPGA
,
,
.
FPGA ,
ModelSim.
FPGA
,
,
File > Import > Library (
Main).
.
57
58
4 - VHDL Simulation( VHDL
)
VHDL . VHDL
VHDL
PLI
FLI.
TextIO STD_INPUT
STD_OUTPUT ModelSim.
TextIO
ENDLINE ENDFILE . (
)
vsim VITAL
VITAL VITAL ModelSim VITAL VITAL VITAL
get_resolution() 59
init_signal_driver() init_signal_spy() signal_force() signal_release() to_real() to_time()
VHDL; VITAL (VHDL Initiative
TextIO ModelSim; ModelSim Towards ASIC Libraries VHDL ASIC) ModelSim’s.
ASIC;
TextIO 1987 Э Std 1076-1993;
VHDL, VHDL
Э Std 1076-
.
Compiling and simulating with the GUI ( GUI ) . ModelSim GUI,
.:
• • •
ModelSim variables(
ModelSim) ,
, ,
, .
-
, . ModelSim ModelSim.
GUI ModelSim. ,
60
Compiling VHDL designs(
VHDL
Creating a design library(
)
) ,
, vlib (CR-285),
.
.
: vlib work ,
work.. work. work -
:
work.
, _info. UNIX, MS WINDOWS, DOS vlib (CR-285).
."
,
" .
Invoking the VHDL compiler(
VHDL
)
VHDL
ModelSim vcom (CR-250) VHDL
.
, .
VHDL,
,
. , -1993
VHDL. VHDL , 1076 –1987
,
1076 -1987
vcom (CR-250)
, -93 vcom (CR-250), 1076 - 1993. modelsim.ini ( . " ).
. ; , , INI"
Dependency checking( ,
1076
,
,
) , . vcom (CR-250) . ,
,
,
, , ,
,
.
Range and index checking (
) ,
,
, 61
.
,
,
,
. ,
.
(
NoRangeCheck INI
) vcom (CR-250). NoIndexCheck . "
, ,
" work -
:
, _info.
, UNIX, MS Windows,
,
modelsim.ini,
work. , vlib (CR-
DOS -
285).
Simulating VHDL designs (
VHDL
) vsim (CR-
, 296). Windows/DOS
UNIX (
")
"
"
Simulate( )" .
VHDL
vsim (CR-296) , , . vsim (CR-296)
.
, ,
/
structure :
my_asic
vsim my_asic structure
Simulator resolution limit( ) 64, . modelsim.ini. report (CR-
Resolution , 200)
simulator state.
Overriding the resolution (
ModelSim, Resolution
)
,
-t Simulate. : 1x, 10x
100x
Simulator ,
,
,
,
,
. , vsim -t 10ps topmod ,
10
: .
–t , , 62
. 0
,
4
.
Choosing the resolution (
) , . , ,
.
Simulating with an elaboration file ( ) Overview (
)
ModelSim
, .
, . ,
: -
.
,
, 5.6,
ModelSim (
.
),
. ,
"
".
.
,
PLI
FLI.
? . "
,
,"
, ,
.
,
-
,
,
, ,
,
SDF.
., , . ModelSim, ,
ё
ModelSim ,
Elaboration file flow (
.
)
63
, . , -sdf instance=)
1 ( ,. Verilog, ,
$sdf_annotate. ё
$sdf_annotate . ,
2
vsim.
(
)
,
(
Modifying stimulus). ,
3 (
).
Creating an elaboration file (
) vsim (CR-296) ,
-elab .
ЕК
ModelSim.
Loading an elaboration file (
) vsim (CR-296) ,
- load_elab < filename > : .
, OS,
vsim (
,
, ).
Modifying stimulus (
) . .
•
, .
; ,
,
,
.
• , stdin/stdout. • . vcdread
-filemap_elab. , VCD vcdstim
, . ,
VCD
,
,
,
. • Verilog, mc_scan_plusargs (). +args +args
+args, ё
PLI
, ,
, .
64
Using with the PLI or FLI(
PLI
PLI
FLI)
, , tf.
sizetf, misctf -load_elab,
,
checktf,
PLI
. tf
,
load_elab – FLI
Verilog HDL
,
PLI
-
. , .
FLI,
,
(-elab)
. FLI ,
(-load_elab) , , ,
-load_elab. "
/ FLI
Syntax(
FLI " .
)
vsim (CR-296) compress_elab, -filemap_elab, -load_elab. : . vsim ( , GUI
-elab, , , OS,
Using the TextIO package(
, ).
TextIO ) TextIO,
VHDL: USE std.textio.all; ,
TextIO:
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;
65
Syntax for file declaration (
)
VHDL ’ 87
:
file identifier : subtype_indication is [mode] file_logical_name ; "file_logical_name"
.
VHDL ’ 93
:
file identifier_list: subtype_indication [file_open_information] ; "file_open_kind_expression" : [open file_open_kind_expression]
file_logical_name file_logical_name;
(VHDL ’ 87): file filename : TEXT is in "usr/rick/myfile"; ,
,
,
,
ё.
,
, , RETURNs(
, , )
.
, ,
modelsim.ini. , ConcurrentFileLimit.
DelayFileOpen
.
.
B - ModelSim Variables .
Using STD_INPUT and STD_OUTPUT within ModelSim ( STD_INPUT STD_OUTPUT ModelSim) VHDL ’ 87
TextIO
:
file input: TEXT is in "STD_INPUT"; file output: TEXT is out "STD_OUTPUT"; VHDL ’ 93
TextIO
:
file input: TEXT open read_mode is "STD_INPUT"; file output: TEXT open write_mode is "STD_OUTPUT"; STD_INPUT
,
, ,
,
STD_OUTPUT
. 66
ModelSim, .
STD_INPUT ,
STD_OUTPUT
.
TextIO implementation issues(
TextIO)
Writing strings and aggregates(
)
VHDL
, STRING
, VHDL
WRITE ,
BIT_VECTOR.
:
WRITE (L, "hello"); : ERROR: Subprogram "WRITE" is ambiguous. TextIO, BIT_VECTOR .
WRITE
STRING :
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); , , ,
" hello " , . :
WRITE (L, "010101"); 67
, , .
, "010101" :
•
,
,
:
WRITE (L, string’("hello")); •
,
,
:
WRITE_STRING (L, " hello "); WRITE_STRING WRITE,
,
STRING WRITE,
. WRITE_STRING Io_utils, //modeltech/examples/io_utils.vhd. .
Reading and writing hexadecimal numbers (
) VHDL. VHDL
(ISAC-VASG) .
,
TextIO
, ModelSim Io_utils, /modeltech/examples/io_utils.vhd. ,
io_utils, VHDL:
use std.textio.all; use work.io_utils.all;
Dangling pointers(
) TextIO,
WRITELINE
(
),
. VHDL:
VHDL (
L1
L2
):
READLINE (infile, L1); -- Read and allocate buffer L2 := L1; -- Copy pointers WRITELINE (outfile, L1); -- Deallocate buffer
VHDL (
L1
L2
): 68
READLINE (infile, L1); L2 := new string’(L1.all); WRITELINE (outfile, L1);
-- Read and allocate buffer -- Copy contents -- Deallocate buffer
The ENDLINE function(
ENDLINE) Э
ENDLINE, Э Std 1076-1987 VHDL. ,
,
VHDL VHDL ,
.
ISAC-VASG ,
ENDLINE
TextIO. : (L = NULL) OR (L’LENGTH = 0)
The ENDFILE function(
ENDFILE)
VHDL
, :
ENDFILE
Э Std 1076-1987
Э Std 1076-1993,
-- function ENDFILE (L: in TEXT) return BOOLEAN; , ENDFILE ,
,
TextIO. , .
Using alternative input/output files( – ) TextIO,
.
,
TEXT. VHDL ’ 87
:
file myinput : TEXT is in "pathname.dat"; VHDL ’ 93
:
file myinput : TEXT open read_mode is "pathname.dat"; ("myinput" READLINE
)
WRITELINE.
Providing stimulus ( ,
) ,
, ,
, . 69
VHDL :
.
ModelSim
< install_dir>/modeltech/examples/stimulus.vhd
Obtaining the VITAL specification and source code ( VITAL
)
VITAL ASIC 1076.4
VITAL ASIC :
445 Hoes Lane Piscataway, NJ 08855-1331 Tel: (732) 981-0060 Fax: (732) 981-1721 : http://www.ieee.org VITAL VITAL /modeltech/ Vhdl_src/vital2.2b, /vital95
VITAL packages(
/ /vital2000.
VITAL) VITAL 2000
-
ieee
VITAL 1995
,
vital95. use
.
VHDL , LIBRARY vital95; USE vital95.all , ModelSim vsim (CR-296) VITAL v2.2b, /modeltech/vital2.2b.
VITAL 1995.
VITAL2000. -vital2.2b, ,
:
,
, vital
70
ModelSim VITAL compliance(
VITAL ModelSim)
VITAL, SDF , VITAL, VITAL Model Development Specification.( ). ModelSim IEEE 1076.4 VITAL ASIC Modeling Specification. , ModelSim VITAL_TIMING VITAL_Primitives VITAL_MEMORY. IEEE 1076.4 VITAL ASIC Modeling Specification (VITAL 1995 and 2000).
VITAL compliance checking(
VITAL) VITAL;
, VITAL. vcom (CR-250)
VITAL 2000
VITAL_LEVEL0 , VITAL_LEVEL0 VITAL_LEVEL1. VITAL 2.2b, , vcom (CR-250) VITAL 1995 , , .
, -novitalcheck. VITAL 2000 ,
VITAL compliance warnings(
VITAL)
LRM
( ,
1-
VITAL);
. • (
)
(1076.4
• PreviousDataIn VITALStateTable (1076.4 6.4.3.2.2) • (
q_w, )(1076.4
VITAL 6.4.3)
DataIn PreviousDataIn VITALStateTable 6.4.3.2.2) DataIn
, 71
LRM.
,
,
VITAL 3.0 LRM –
, . -
, . ,
CheckEnabled VITAL
,
. -
vcom (CR-250). , nowarn vcom -nowarn 6. 6 , , ,WARNING [6]. [vcom] VHDL compiler control variables( modelsim.ini VHDL ).
vcom -
[vcom] Show_VitalChecksWarnings = 0
72
Compiling and Simulating with accelerated VITAL packages ( VITAL) ё ,
vcom (CR-250) ieee .
VITAL
,
: • VITAL Level-0 optimization " 0,
".
–
-1,
-1.
• VITAL Level-1 optimization -1 VITAL 3.0, VITAL.
-
.
VITAL vcom (CR-250)
VITAL
: -O0 | -O4 -O0 ( ,
,
).
.
, , . -O4 (
).
-debugVA , , ModelSim
,
VITAL VITAL
, -1.
VITAL VITAL.
73
Util package ( util,
Util)
ModelSim VHDL. modeltech
5.5
, modelsim_lib, modelsim.ini.
, VHDL
:
library modelsim_lib; use modelsim_lib.util.all;
get_resolution() get_resolution () .
, 1e-15.
1 Syntax resval := get_resolution(); Returns(
)
resval ,
Arguments(
)
Related functions( to_real() to_time()
Example(
)
) 10ps, :
resval := get_resolution(); ,
resval
1e-11.
init_signal_driver() Init_signal_driver () VHDL
VHDL
Verilog
Verilog. VHDL (
,
testbench). init_signal_driver
12 – . 74
init_signal_spy() Init_signal_spy () VHDL , , , testbench). init_signal_ spy
(
VHDL
/
Verilog
Verilog. VHDL 12– .
signal_force() signal_force ()
,
Verilog ,
/
VHDL ,
. VHDL (
force (CR-154 ) . signal_ force 12–
, testbench). signal_force ,
.
signal_release() signal_release () , , VHDL Verilog , , VHDL ( , testbench). signal_release noforce (CR-171). signal_release 12– .
.
to_real() to_real () . .
,
1900 fs ps,
2.0 (
, 2 ps).
Syntax realval := to_real(timeval); Returns(
)
realval
Arguments (
-
)
timeval
75
Related functions (
)
get_resolution() to_time () Example (
) ps, :
realval := to_real(12.99 ns); ,
timeval
12990.0 (ns)
, , :
get_resolution () realval := 1e+9 * (to_real(12.99 ns)) * get_resolution(); ,
(fs),
: realval : = 1e+15 * (to_real(12.99 ns)) * get_resolution();
to_time() to _time () . . ,
5.9
,
ps ,
6 ps.
Syntax timeval := to_time(realval); Returns(
)
timeval -
Arguments (
)
realval
Related functions (
)
get_resolution() to_real () Example (
) ps, :
timeval := to_time(72.49); 76
,
timeval
72 ps.
Foreign language interface(
) (FLI)
C, Model Technology’s HDL, vsim. ,
HDL VHDL ,
) FLI ModelSim’s
, , (
. ModelSim FLI. ModelSim ModelSim.
77
5 - Verilog Simulation( Verilog
)
Verilog-XL Verilog-XL ‘
uselib.
. . Verilog Verilog-XL
-fast +opt -fast -fast +acc .
-
PLI
FLI.
SDF
Std 1364 Verilog-XL $init_signal_driver $init_signal_spy $signal_force $signal_release
Std 1364-1995
. 78
Verilog-XL Verilog PLI/VPI PLI VPI PLI/VPI ++ PLI/VPI 64-
ModelSim 32-
PLI/VPI PLI/VPI PLI VPI PLI . sizetf PLI PLI VHDL Std 1364 ACC Std 1364 TF Verilog-XL 64PLI/VPI
. . PLI
, Verilog. ModelSim Verilog
Verilog ModelSim IEEE Std 1364, .
Verilog,
, ModelSim Verilog
Std 1364-1995, :
•
(SDF -Standard Delay Format ) Verilog ASIC
•
FPGA
VCD ( Value Change Dump -
•
)
PLI/VPI
•
,
• •
VHDL
Verilog
(
SDF) • •
, ,
ModelSim VHDL Verilog-XL Std 1364
ModelSim Verilog:
79
• Verilog (VPI - Verilog Procedural Interface) ( . / < install_dir > /modeltech/docs/technotes/Verilog_VPI.note ) • Verilog 2001 (see //modeltech/docs/technotes/vlog_2000.note ) . GUI ModelSim
:
• • •
Compilation(
) Verilog, Verilog
,
.
Verilog . . 2 - Design Libraries (
).
ModelSim Verilog , vlog, ,
Verilog ,
,
.
, UDPs
.
,
. -work. , :
,
,
Contents top.v: module top; initial $display("Hello world"); endmodule : % vlib work : % vlog top.v - - Compiling module top Top level modules: top (
): 80
% vdir MODULE top : % vsim -c top # Loading work.top VSIM 1> run -all # Hello world VSIM 2> quit
,
, ,
-c. run –all
, , .
,
. "transcript"
,
(log) .
Incremental compilation(
)
, ModelSim Verilog
,
,
,
.
Verilog, , (
, ;
, . " Compiling for faster performance( )" . ,
, ,
UDP . , .
,
:
,
, ,
,
. , : Contents of top.v: module top; or2(n1, a, b); and2(n2, n1, c); endmodule
Contents of and2.v: module and2(y, a, b); output y; 81
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 (
,
): % 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 ,
, ,
"
"
,
.
,
, . .
, . , % vlog top.v -- Compiling -- Compiling -- Compiling
and2.v module module module
or2.v top and2 or2
Top level modules: top , ,
.
, (
). 82
, .
,
-incr, ,
. ,
,
.
:
,
% vlog -incr -- Compiling -- Compiling -- Compiling
top.v and2.v or2.v module top module and2 module or2
Top level modules: top ,
,
"or2":
% vlog -incr top.v and2.v or2.v -- Skipping module top -- Skipping module and2 -- Compiling module or2 Top level modules: top ,
" top "
"and2",
"Or2". , .
, ;
, . ,
: , (
) ,
.
,
, ModelSim
.
83
Library usage(
)
UDPs
Verilog
.
, . , ,
, .
-
,
ASIC :
% 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 ,
–work asiclib, asiclib , work. , ,
. work, .
.
Verilog
•
:
ё
,
-Lf
. • •
, ,
ё
"
Verilog-XL -L ,
uselib " .
. • •
work. , . ,
—
,
work UDP, ,
work ,
, . , 84
-
.
, .
-L work
,
. ,
, "modA" "libA" "libB". , "modA" "modB" "cellA" "libA" "libB". , " -L libA - LlibB " "modB" "libA" "cellA".
" Top " "modB" , "cellA", , ,
"cellA"
" -L work -L libA -L libB ".
Verilog-XL compatible compiler arguments (Verilog-XL
)
,
Verilog-XL, vlog (CR-286 )
ModelSim. . +define+[=] +delay_mode_distributed +delay_mode_path +delay_mode_unit +delay_mode_zero -f +incdir+ +mindelays +maxdelays +nowarn +typdelays -u
, , Verilog-XL.
vlog (CR-286)
. ,
, ModelSim
,
. ModelSim
, . . , ,
.
UDPs, , .
85
, . . -v -y +libext+ +librescan +nolibcell -R []
Verilog-XL ‘uselib compiler directive ( Verilog- XL ‘ uselib) ‘ uselib – -v, -y, +libext. , , compile_uselibs (
)
, .
‘ uselib , vlog (CR-286).
-
‘ uselib: ‘ uselib ... : dir= | file= | libext= | lib= : dir=-y file=-v libext=+libext+ , ‘uselib dir=/h/vendorA libext=.v : -y /h/vendorA +libext +.v Verilog,
‘ uselib
. ‘ uselib
, ,
‘ uselib. ,
,
, :
‘uselib dir=/h/vendorA file=.v NAND2 u1(n1, n2, n3); 86
‘uselib dir=/h/vendorB file=.v NAND2 u2(n4, n5, n6); NAND2
vendorA
vendorB. -compile_uselibs ModelSim (CR-286) ,
5.5
,
-compile_uselibs ‘ uselib.
, , modelsim.ini this is still the default behavior when -compile_uselibs is not used. Э ( compile_uselibs И .
. -
),
-compile_uselibs, ModelSim , ,
ё : • , -compile_uselibs =./mydir • , " ") • mti_uselibs, ModelSim
:
, ,
-compile_uselibs. MTI_USELIB_DIR (
5.5,
, ModelSim Verilog.
uselib ,
, compile_uselibs – . www.model.com/products/documentation/pre55_uselib.pdf pre-5.5. ‘uselib is persisten (‘ uselib
. vlog -compile_uselibs dut.v srtr.v dut.v dut.v, , ,
dut.v,
,
‘ uselib ,
,
,
‘ -
)
, ,
vlog ,
.
,
uselib. ‘ uselib ‘ uselib . ‘ uselib dut.v,
:
srtr.v . -
, "
srtr ,
"
‘ uselib.
87
Simulation(
) Verilog
ModelSim
VHDL
, . , Verilog
.
Invoking the simulator(
)
Verilog
, . (
).
, "testbench"
" globals",
: vsim testbench globals ,
, UDPs
, .
UDPs
work. . –L
, "
-Lf
, UDPs vsim (
"
). ,
run , ,
.
,
Verilog. , run 100 ns).
$finish ( quit ,
, run –all ,
.
Simulation resolution limit( ) 64,
.
,
‘ timescale ‘ timescale:
. ‘ timescale 1 ns / 100 ps
, ,
ns
-
. 100 ps.
timescale 88
, timescale timescale
. .
,
,
:
vsim vsim mod2 mod1, 10 ps. timescale,
2 10 ps. 1
, ( 2,
/mod1/set 1.55 ns , 1 ns 20 ps . , , 15.5 ps
, 1.55
1
2 ModelSim :
, /mod2/set
Wave,
timescale).
, 20 ps.
** Warning: (vsim-3010) [TSCALE] - Module ’mod1’ has a ‘timescale directive in effect, but previous modules do not.( ’mod1‘ ‘timescale , .) vsim vsim mod1 mod2, , ModelSim : ** Warning: (vsim-3009) [TSCALE] - Module ’mod2’ does not have a ‘timescale directive in effect, but previous modules do. ( : (vsim-3009) [TSCALE] ’mod2‘ timescale , .) . ‘ timescale, ,
modelsim.ini. (
Resolution 1 ns
.) timescale
,
timescale.
timescale
, ,
vlog (CR-286). timescales. timescale .
timescale ( ModelSim)
89
, Simulate. sec.
-t ps, ns, us, ms,
: 1x, 10x
100x fs,
10 ps: vsim -t 10ps top ,
. timescale
-t , , .
,
4 ps
0 ps.
, . , ,
.
Event ordering in Verilog designs( Verilog) ( ).
ModelSim , " Delta Verilog
" ,
,
.
,
, Event queues( 5
,
.
) Std 1364-1995 LRM, ,
, .
, :
• • • • •
-
-
LRM
,
- 1) ;
2) 3)
; ;; 4) ;; 5) -
, . ,
, . 90
,
.
,
:
1 always@(q) p = q; 2 always @(q) p2 = not q; 3 always @(p or p2) clk = p and p2; 4 always @(posedge clk) : q = 0, p = 0, p2=1 . #,
, (old->new) new
#
,
1:
2:
1
2
,
. 2, clk clk.
’
.
.
,
1, clk
.
;
,
-
‘
/
-
,
, .
-
.
, ,
, :
• • • -
, .(
-
.)
-
. ,
,
. 91
, .(
,
.)
.
-
,
-
. gen1: always @(master) clk1 = master; gen2: always @(clk1) clk2 = clk1; f1 : always @(posedge clk1) begin q1 run -all VSIM 2> quit ,
,
,
. , .
Compiling with +opt (
+opt )
+opt
-fast, (
Makefile,
,
,
). ,
-fast, +opt. ,
,
+opt –
-fast. ,
+opt,
; +opt . ,
–L
-Lf,
. , .
vlog (CR-286)
- fast, +acc, .
,
+opt. PLI.
Compiling mixed designs with –fast ( –fast) Verilog . VHDL
, , VHDL
Verilog -fast, Verilog,
-fast .
98
Compiling gate-level designs with –fast ( –fast) netlist , - fast. : • forcecode
- fast
-forcecode.
, • •
-
. -fast.
testbench ,
. testbench
, . .
,
,
, testbench -fast , ModelSim vlog , . +nocheck
. . 5.5b,
vlog (CR-286). write cell_report (CR-320) , . write cell_report
vlog (CR-286),
-debugCellOpt , ,
. " (cell) "
-
.
,
Module: top Architecture: fast Module: bottom (cell) Architecture: fast
bottom
, top bottom . -debugCellOpt
-fast,
top .
-fast Transcript,
,
. : ModelSim
5.6
,
-
.
, " celldefine.
Referencing the optimized design ( ) , , . fast,
99
- "verilog". (
" fast ") ,
- fast = < option>. "Opt1"
,
,
: % vlog -fast=opt1 cpu_rtl.v ,
, , , ,
,
.
(testbenches).
,
, ,
,
,
. :
% vlog -fast=t1 testbench1.v design.v -- Compiling module testbench1 -- Compiling module design Top level modules: testbench1 Analyzing design... Optimizing 2 modules of which 0 are inlined: -- Optimizing module design(t1) -- Optimizing module testbench1(t1)
% vlog -fast=t2 testbed2.v design.v -- Compiling module testbench2 -- Compiling module design Top level modules: testbench2 Analyzing design... 100
Optimizing 2 modules of which 0 are inlined: -- Optimizing module design(t2) -- Optimizing module testbench2(t2) design.v, , t2. testbench1,
testbench1 testbench2
,
testbench1 testbench2
,
t1
t1. t2.
,
. ,
, , ,
.
,
, (
)
. ( ).
"verilog", ,
,
testbench
, , . ,
defparams, , .
, % vlog -fast=c1 testbench.v design.v config1.v -- Compiling module testbench -- Compiling module design -- Compiling module config1 Top level modules: testbench config1 Analyzing design... Optimizing 3 modules of which 0 are inlined: -- Optimizing module design(c1) -- Optimizing module testbench(c1) -- Optimizing module config1(c1)
101
% vlog -fast=c2 testbench.v design.v config2.v -- Compiling module testbench -- Compiling module design -- Compiling module config2 Top level modules: testbench config2 Analyzing design... Optimizing 3 modules of which 0 are inlined: -- Optimizing module design(c2) -- Optimizing module testbench(c2) -- Optimizing module config2(c2) "testbench"
,
,
.
,
% vsim ’ testbench (c1) ’ config1 ,
config1, .
, ,
.
,
,
Simulate ,
, .
– fast .
1
GUI, Library (Main window) , ,
.
vdir (CR-257)
.
, VSIM 1> vdir design # MODULE design # Optimized Module t1 # Optimized Module t2 102
,
: " __ < n> "
.
, (
,
).
Enabling design object visibility with the +acc option ( +acc ) ,
– fast PLI.
,
, . PLI.
,
PLI Access , ,
,
,
, .
,
– fast , .
, –fast ,
+acc .
,
, .
+acc
:
+acc[=][+[.]] :
b
. PLI, .
, ,
. zxtqrfv
c
rb.
Verilog
ё
,
PLI
. .
l ,, n p
,
.
. , PLI , ( .
, ) (
r
,
,
,
) 103
,
< module> . ,
ё
.
,
"." "+".
, . PLI, , $dumpvars -
, +acc.
, PLI,
, PLI acc_vcl_add, , . ,
VCD.
ё
, $dumpvars
,
$dumpvars,
testbench ( ):
initial $dumpvars; , : % vlog -fast +acc=rn testbench.v design.v ,
, (
,
1
,
):
initial $dumpvars(1, testbench.u1); ( testbench.u1
" design"):
% vlog -fast +acc=rn+design testbench.v design.v , (
, 0
testbench.u1 ):
,
initial $dumpvars(0, testbench.u1); : % vlog -fast +acc=rn+design. testbench.v design.v , .
104
Using pre-compiled libraries( ) –fast , , , -L
vlog (CR-286).
-Lf
, .
,
. ,
XL
‘ uselib (
.Verilog-
‘ uselib ). ‘ uselib ,
, .
-L or –Lf vsim (CR-296) ,
:
.
Event order and optimized designs ( ) ,
Verilog .
,
,
–fast ,
–fast. (
ordering in Verilog designs" -keep_delta ( ,
).
. " "Event
,
. vlog (CR-286))
–fast , .
,
.
Timing checks in optimized designs ( ) , ,
.
–fast. ,
, ,
. -
–fast
Std 1364-1995. ,
, –fast Std
1364-2001.
105
Simulating with an elaboration file( ) Overview( ) ModelSim
, .
, .
,
:
.
ModelSim (
,
,
.
5.6, ),
. ,
,
"
."
. PLI
, FLI. ? . ,"
,
"
, , .
, -
, , ,
SDF.
. , .
ModelSim ,
, ModelSim
,
.
Elaboration file flow (
) , .
1 , -sdf instance=) . Verilog, $sdf_annotate , 2 vsim, . ( , ( ). 3 )( ).
, ( $sdf_annotate. . )
,
106
Creating an elaboration file (
) ,
-elab ModelSim.
К
(CR-296).
Loading an elaboration file(
vsim
) ,
-load_elab
vsim (CR-296). : . vsim ( ,
, OS,
,
).
Modifying stimulus (
) . .
•
, .
; ,
, •
, .
-filemap_elab, . ,
• .
stdin/stdout. , . , .
VCD vcdread vcdstim
• Verilog, mc_scan_plusargs (). +args
ё
,
, ,
PLI
+args,
+args
VCD
,
ё
,
.
Using with the PLI or FLI( PLI , sizetf, misctf -load_elab,
FLI) tf
checktf, PLI tf ,
. ,
, .
Verilog HDL
PLI
-load_elab
, PLI
. FLI
,
107
.
FLI,
(-elab) (-load_elab)
, .
FLI , ,
, ,
,
-load_elab. "
/
FLI "
FLI
Syntax(
.
)
vsim (CR-296 ) -compress_elab, -filemap_elab, -load_elab.
-elab,
Cell Libraries( Model Technology ) ". .
) ё
ASIC Council’s Verilog Si2 "Library Tested and Approved( , Verilog ASIC.
, ModelSim Verilog.
ASIC
"
ё
FPGA
Verilog
" Verilog , .
. , 14.5 . ModelSim Verilog
Std 1364-1995
Std 1364
13
Verilog-XL
SDF timing annotation( ModelSim Verilog
.
SDF
)
,
(SDF - Standard Delay Format). 11 - Standard Delay Format (SDF) Timing Annotation (SDF) .
. (Ф
Delay modes(
)
)
Verilog
, , UDPs, ,
. -
. ,
,
ё
port -to- port ,
-
.
Verilog .
,
module and2(y, a, b); 108
input a, b; output y; and(y, a, b); specify (a => y) = 5; (b => y) = 5; endspecify endmodule " "
" " ,
,
,
.
,
,
. ,
,
, ..
,
,
, (
Std 1364-1995).
-
, .
Verilog-XL.
.
. +delay_mode_distributed ‘ delay_mode_distributed.
,
, .
+delay_mode_path
(
ё
‘ delay_mode_path.
, time_unit
‘ timescale), . +delay_mode_unit
‘ delay_mode_unit.
, . +delay_mode_zero ‘ delay_mode_zero.
109
System Tasks(
)
Std 1364 ModelSim Verilog
Verilog, , Verilog-XL. ,
,
, Language Interface) Interface).
(PLI – Programming Verilog (VPI - Verilog Procedural ,
,
PLI/VPI, .
IEEE Std 1364 system tasks (
Std 1364
) Std 1364.
$printtimescale $timeformat
$finish $stop
$dist_chi_square $dist_erlang $dist_exponential $dist_normal $dist_poisson $dist_t $dist_uniform $random
$bitstoreal $itor $realtobits $rtoi $signed $unsigned
$realtime $stime $time
$q_add $q_exam $q_full $q_initialize $q_remove
$test$plusargs $value$plusargs
$hold $nochange $period $recovery $setup $setuphold $skew $width $removal $recrem
110
PLA $display $displayb $displayh $displayo $monitor $monitorb $monitorh $monitoro $monitoroff $monitoron $strobe $strobeb $strobeh $strobeo $write $writeb $writeh $writeo яФ $fclose $fdisplay $fdisplayb $fdisplayh $fdisplayo $ferror $fflush $fgetc $fgets $fmonitor $fmonitorb $fmonitorh $fmonitoro
$async$and$array $async$nand$array $async$or$array $async$nor$array $async$and$plane $async$nand$plane $async$or$plane $async$nor$plane $sync$and$array $sync$nand$array $sync$or$array $sync$nor$array $sync$and$plane $sync$nand$plane $sync$or$plane $sync$nor$plane
В $fopen $fread $fscanf $fseek $fstrobe $fstrobeb $fstrobeh $fstrobeo $ftell $fwrite $fwriteb
(VCD) $dumpall $dumpfile $dumpflush $dumplimit $dumpoff $dumpon $dumpvars $dumpportson $dumpportsoff $dumpportsall $dumpportsflush $dumpports $dumpportslimit
- ы $fwriteh $fwriteo $readmemb $readmemh $rewind $sdf_annotate $sformat $sscanf $swrite $swriteb $swriteh $swriteo $ungetc
: $readmemb $readmemh Std 1364. , . , ModelSim ,
Verilog-XL, , [127:0] 0
[0:127], 127.
111
Verilog-XL compatible system tasks (Verilog-XL
) Verilog-XL.
, Std 1364. $countdrivers $getpattern $sreadmemb $sreadmemh Verilog-XL, Std 1364. $deposit(variable, value); Verilog ; value -
variable , .
.
, $deposit
. ModelSim
force –deposit.
$system("operating system shell command");
. ,
Unix:
$system ("ls"); ,
,
( Verilog-XL.
)
$recovery (reference_event, data_event, removal_limit, recovery_limit ,[notifier], [tstamp_cond], [tcheck_cond], {delayed-reference],[delayed_data]) $recovery notifier , $recrem recovery_limit
recovery_limit . $recovery .
,
, removal_limit
.
$setuphold(clk_event, data_event, setup_limit, hold_limit, [notifier], [tstamp_cond], [tcheck_cond], [delayed_clk], [delayed_data])
112
tstamp_cond clk_event.
data_event clk_event
data_event.
tcheck_cond clk_event.
data_event clk_event
delayed_clk clk_event.
data_event.
, ,
setup_limit,
. delayed_data, data_event. . delayed_clk
,
delayed_data
hold_limit
,
, .
delayed_clk
delayed_data
clk
data .
, . delayed_data
delayed_clk , "Negative timing check limits"
.
,
.
-
Verilog-XL,
ModelSim Verilog,
.
$input("filename") . do . $list [(hierarchical_name)] ,
.
. Source . $reset 0. - restart. $restart("filename") , ,
$save. restore .
$save("filename") 113
, . checkpoint . $scope (hierarchical_name) hierarchical_name. environment . $showscopes , . show. $showvars , .
show.
$init_signal_driver system task( $init_signal_driver () VHDL
Verilog
$init_signal_driver ) VHDL Verilog. Verilog
(
, testbench). $init_signal_driver
12- Signal Spy .
$init_signal_spy system task(
$init_signal_spy)
$init_signal_spy () /
VHDL, VHDL.
Verilog
Verilog , , Verilog ( , testbench). $init_signal_spy 12- Signal Spy .
$signal_force system task(
$signal_force)
$signal_force () VHDL
, Verilog. Verilog (
, ,
testbench). $signal_force
$signal_force
force (CR-154 ) . 12- Signal Spy .
,
114
$signal_release system task(
$signal_release)
$signal_release () VHDL noforce (CR-171.) $signal_release 12- Signal Spy .
, Verilog. $signal_release
Compiler Directives(
)
ModelSim Verilog 1364
,
Std
Verilog-XL (
.
‘timescale) , ‘
resetall. ,
, .
,
, ,
,
. ,
‘ resetall ( Std 1364): ‘ ‘ ‘ ‘ ‘ ‘ ‘ ‘ ‘
celldefine Define_nettype Delay_mode_distributed Delay_mode_path Delay_mode_unit Delay_mode_zero timescale Unconnected_drive uselib 115
ModelSim Verilog
:
‘define MODEL_TECH
IEEE Std 1364 compiler directives( )
Std 1364 Std 1364.
‘ celldefine ‘ default_nettype ‘define ‘else ‘endcelldefine ‘endif ‘ifdef ‘include ‘nounconnected_drive ‘resetall ‘timescale ‘unconnected_drive ‘undef
Verilog-XL compatible compiler directives ( Verilog-XL
) Verilog-XL.
‘default_decay_time , , ,
. "
"
,
.
‘delay_mode_distributed . modes(
)
. Delay
.
‘ delay_mode_path ё Delay modes(
.
)
.
.
‘ delay_mode_unit
. Delay modes(
)
. .
116
‘ delay_mode_zero . modes(
)
. Delay
.
‘ uselib +libext. . Verilog-XL ‘uselib compiler directive( Verilog-XL ) .
-v, -y, ‘uselib
Verilog-XL ё
ModelSim Verilog. ModelSim Verilog,
,
Verilog-XL.
‘accelerate ‘autoexpand_vectornets ‘disable_portfaults ‘enable_portfaults ‘endprotect ‘expand_vectornets ‘noaccelerate ‘noexpand_vectornets ‘noremove_gatenames ‘noremove_netnames ‘nosuppress_faults ‘protect ‘remove_gatenames ‘remove_netnames ‘suppress_faults Verilog-XL ModelSim Verilog. -
ModelSim Verilog, ModelSim Verilog
, Verilog-XL.
‘default_trireg_strength ‘signed ‘unsigned
117
Verilog PLI/VPI Verilog PLI (Programming Language Interface(Verilog Procedural Interface -
)
VPI
Verilog) C.
PLI ( (
, . Third party PLI applications PLI
Verilog )).
,
PLI/VPI.
ModelSim Verilog
PLI acc_handle_datapath(). ,
cc_handle_datapath(),
Std 1364, , .
5.6 , VPI
Std 1364-2001. :
< install_dir>/modeltech/docs/technotes/Verilog_VPI.note. Std 1364 -
,
PLI/VPI. PLI/VPI ModelSim Verilog.
Registering PLI applications(
PLI)
PLI , . PLI Verilog-XL, ModelSim Verilog PLI s_tfcell.
veriuser.h
, : 118
typedef int (*p_tffn)(); typedef struct t_tfcell { short type;/* USERTASK, USERFUNCTION, or USERREALFUNCTION */ short data;/* */ p_tffn checktf; /* , */ p_tffn sizetf; /* */ p_tffn calltf; /* */ p_tffn misctf; /* */ char *tfname;/* */ /*
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; (checktf, sizetf, calltf,
misctf)
Std 1364.
. ,
,
calltf, Verilog.
,
PLI, (USERTASK) (USERFUNCTION) (USERREALFUNCTION). tfname $).
,
( ). , ( ModelSim Verilog.
PLI, init_usertfs,
veriusertfs. ,
init_usertfs
, mti_RegisterUserTF ()
. veriuser.h
mti_RegisterUserTF ()
:
void mti_RegisterUserTF(p_tfcell usertf); ё (de-references) , 0.
usertf , usertf,
, . ,
veriusertfs (
Verilog-XL), 119
init_usertfs, ( 0).
,
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 */ }; ,
init_usertfs, :
void init_usertfs() { p_tfcell usertf = veriusertfs; while (usertf->type) mti_RegisterUserTF(usertf++); } , init_usertfs.
PLI
veriusertfs
PLI ,
( ,
"Compiling and linking PLI/ VPI applications"(" PLI/VPI " ). PLI Windows .dll): •
Veriuser
(
.
,
modelsim.ini:
Veriuser = pliapp1.so pliapp2.so pliappn.so •
PLIOBJS:
% setenv PLIOBJS " pliapp1.so pliapp2.so pliappn.so " •
-pli
(
):
-pli pliapp1.so -pli pliapp2.so -pli pliappn.so
.
PLI ,
. .
120
Registering VPI applications (
VPI)
VPI .
,
. Vpi_register_systf () Vpi_register_cb () ,
. vlog_startup_routines
,
. 0
.
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.sysfunctype = 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; 121
tmpH = vpi_register_cb (&callback);
vpi_free_object(tmpH); ) void (*vlog_startup_routines [ ] ) () = { RegisterMySystfs, 0 /* 0 */ }; VPI
-
"Registering PLI applications(
PLI) ".
PLI
VPI ,
. : •
init_usertfs ()
, ,
mti_RegisterUserTF (). •
init_usertfs ()
,
veriusertfs
, veriusertfs.
, •
init_usertfs () Vlog_startup_routines , vlog_startup_routines.
,
veriusertfs
,
,
,
PLI
VPI
, .
VPI, vlog_startup_routines ,
init_usertfs ().
Compiling and linking PLI/VPI (
applications PLI/VPI)
PLI/VPI C , Microsoft Visual C / C ++ gcc cc . PLI/VPI ё ModelSim /modeltech/ include. _user.h ACC, TF, vpi_user.h VPI , . ,
, ModelSim. Windows DLLs, UNIX , veriuser.h . PLI
VPI
. -
, . 122
, (
("Specifying the PLI/VPI file to load " )).
PLI/VPI, Windows
cl -c -I\modeltech\include app.c link -dll -export: app.obj \ \modeltech\win32\mtipli.lib/out:app.dll Verilog PLI, "init_usertfs". , init_usertfs, , "veriusertfs". Verilog VPI, "vlog_startup_routines". , , ModelSim , DLL. PLI VPI DLLs, Microsoft Visual C / C ++ 4.1 . gcc PLI/VPI Windows. , gcc Microsoft. lib/.dll. Linux gcc compiler: gcc -c -I//modeltech/include app.c ld -shared -E -o app.so app.o cc compiler: cc -c -I//modeltech/include app.c ld -shared -E -o app.so app.o 32-
Solaris
gcc compiler: gcc -c -I//modeltech/include app.c ld -G -B symbolic -o app.so app.o cc compiler: cc -c -I//modeltech/include app.c ld -G -B symbolic -o app.so app.o :
-B
ld , .
.
. ,
app.so
Solaris, :
. •
app.so
.(
.) 123
• LD_LIBRARY_PATH =
64Solaris cc -v -xarch=v9 -O -I$//modeltech/include -c app.c ld -G -B symbolic app.o -o app.so :
ld ,
-B
. .
.
32-
HP700 ё
, (
+z
,
) , -b ).
-fpic
( gcc compiler:
gcc -c -fpic -I / /modeltech/include app.c ld -b -o app.sl app.o cc compiler: cc -c +z -I / /modeltech/include app.c ld -b -o app.sl app.o ,
gcc.
-fpic
64-
HP700
cc -v +DD64 -O -I/modeltech/include -c app.c ld -b -o app.so app.o
32ModelSim IBM RS/6000. ModelSim's ,
IBM RS/6000 PLI/VPI VPI
PLI . ModelSim rs6000/mti_exports ModelSim
. PLI/VPI
,
, C,
‘-lc’
PLI/VPI. ‘ld’.
, gcc
cc
AIX 4.x: gcc compiler:
124
gcc -c -I / /modeltech/include app.c ld -o app.sl app.o -bE:app.exp \ - bI://modeltech/rs6000/mti_exports -bM:SRE -bnoentry -lc cc compiler: cc -c -I / /modeltech/include app.c ld -o app.sl app.o -bE:app.exp \ - bI://modeltech/rs6000/mti_exports -bM:SRE -bnoentry –lc app.exp
PLI/VPI.
PLI,
"init_usertfs".
, "veriusertfs".
init_usertfs ,
VPI,
"vlog_startup_routines". ,
, ,
ModelSim 64-
.
IBM RS/6000 4.3 AIX
64-
. 64-
.
gcc
:
cc -c -q64 -I//modeltech/include app.c ld -o app.s1 app.o -b64 -bE:app.exports \ -bI://modeltech/rs64/mti_exports -bM:SRE -bnoentry -lc AIX 4.3 32-
:
,
-DUSE_INTTYPES
. ,
inttypes.h
mti.h.
Compiling and linking PLI/VPI C++ applications( PLI/VPI C++) ModelSim C;
,
C++
. PLI/VPI ModelSim C++
C, PLI/VPI
.
extern: extern "C" {
} veriuser.h, acc_user.h,
vpi_user.h
extern.
125
PLI/VPI (veriusertfs, init_usertfs,
vlog_startup_routines) extern. ModelSim C C++, iostreams cout, . io_mcdprintf (), io_printf (), vpi_mcd_printf (), vpi_printf (), vpi_vprintf (), vpi_mcd_vprintf () (transcript). , PLI/VPI C++ , ModelSim. Microsoft Visual C++ Windows DLLs, C++ C++ UNIX. , . , " PLI/VPI ". Windows
GNU
Microsoft Visual C++: cl -c [-GX] -I\modeltech\include app.cxx link -dll -export: app.obj \ \modeltech\win32\mtipli.lib /out:app.dll -GX . Verilog PLI, "init_usertfs". , init_usertfs, , "veriusertfs". Verilog VPI, "vlog_startup_routines". , , ModelSim , DLL.
: GNU PLI/VPI Microsoft. lib/.dll.
C++ Windows.
32GNU C++
,
GNU C++
Linux 2.95.3
c++ -c -fPIC -I/modeltech/include app.C c++ -shared -fPIC -o app.so app.o 32Sun WorkShop
Solaris 5.0
CC -c -Kpic -o app.o -I/modeltech/include app.C CC -G -o app.so app.o -lCstd -lCrun GNU C++
2.95.3
126
c++ -c -fPIC -I/modeltech/include app.C c++ -shared -fPIC -o app.so app.o 64-
Solaris
Sun WorkShop
5.0
CC -c -v -xcode=pic32 -xarch=v9 -o app.o \ -I/modeltech/include app.C CC -G -xarch=v9 -o app.so app.o -lCstd -lCrun 32-
HP-UX C++, .
: UX 11.0 HP C++
HP-
3.25
aCC -c +DAportable +z -o app.o -I/modeltech/include app.C aCC -v -b -o app.so app.o -lstd -lstream –lCsup GNU C++
2.95.3
c++ -c -fPIC -I/modeltech/include app.C c++ -shared -fPIC -o app.so app.o
ModelSim
GNU C++ -
, ModelSim .
64HP C++
-UX,
. ,
- UX 3.25
aCC -c +DA2.0W +z -o app.o -I/modeltech/include app.C aCC -v +DA2.0W -b -o app.so app.o -lstd -lstream -lCsup 32-
IBM RS/6000
IBM C++ version 3.6 xlC -c -o app.o -I/modeltech/include app.C makeC++SharedLib -o app.sl \ -bI:/modeltech/rs6000/mti_exports -p 10 app.o 64IBM C++
IBM RS/6000 3.6
127
xlC -q64 -c -o app.o -I/modeltech/include app.C makeC++SharedLib -o app.sl -X64 \ -bI:/modeltech/rs64/mti_exports -p 10 app.o
Using 64-bit ModelSim with 32-bit PLI/VPI Applications( ModelSim 32PLI/VPI) 32-
PLI/VPI
64-
ModelSim,
64ILP32
64-
,
LP64. ,
64-
:
Sun Solaris 7 64-bit Developer’s Guide http://docs.sun.com:80/ab2/coll.45.10/SOL64TRANS/ HP HP-UX 64-bit Porting and Transition Guide http://docs.hp.com:80/dynaweb/hpux11/hpuxen1a/0462/@Generic__BookView HP-UX 11.x Software Transition Kit http://software.hp.com/STK/
Specifying the PLI/VPI file to load ( PLI/VPI
)
PLI/VPI •
: Veriuser
modelsim.ini :
Veriuser = pliapp1.so pliapp2.so pliappn.so •
PLIOBJS:
% setenv PLIOBJS " pliapp1.so pliapp2.so pliappn.so " •
. -pli
(
):
-pli pliapp1.so -pli pliapp2.so -pli pliappn.so : .dll
Windows,
,
.so. PLI/VPI
.
,
. .
modelsim.ini.
ModelSim
128
PLI example(
PLI) ,
PLI.
hello.c: #include "veriuser.h" static 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/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 (
VPI ) ,
VPI.
hello.c: #include "vpi_user.h" static PLI_INT32 hello(PLI_BYTE8 * param) { vpi_printf( "Hello world!\n" ); } 129
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/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(
PLI)
PLI 1364
. Std 1364. misctf
. veriuser.h. . Std ModelSim Verilog, , : 130
reason_endofcompile . reason _finish $finish
quit.
. reason _startofsave checkpoint , .
PLI tf_write_save,
,
reason_save. reason _save ё
, tf_write_save.
checkpoint.
PLI
reason _startofrestart restore , . ,
PLI ё
tf_read_restart, reason_startofrestart ,
reason_restart. , -restore.
reason _restart restore.
ё
-
PLI tf_read_restart.
reason _reset restart .
ё
PLI ,
.
PLI
, , PLI -keeploaded (CR-299) -keeploadedrestart (CR-299) .)
( vsim
.
reason _endofreset ,
restart, ,
,
.
reason _interactive $stop . reason _scope environment acc_set_interactive_scope,
. callback_flag
.
reason _paramvc .
131
reason _synch ,
tf_synchronize().
reason _rosynch ,
tf_rosynchronize().
reason _reactivate ,
tf_setdelay.
reason _paramdrc ModelSim Verilog. reason _force ModelSim Verilog. reason _release ModelSim Verilog. reason _disable ModelSim Verilog.
The sizetf callback function(
sizetf)
sizetf , . sizetf •
sizetf,
Std 1364: 32.
•
sizetf " real" Verilog.
0,
•
sizetf " integer" Verilog.
-32,
PLI object handles(
PLI) ,
PLI ACC
,
, ,
,
acc_close
.
,
, cc_close(). ModelSim Verilog
:
accOperator (acc_handle_condition) accWirePath (acc_handle_path) 132
accTerminal (acc_handle_terminal, acc_next_cell_load, acc_next_driver, cc_next_load) accPathTerminal (acc_next_input acc_next_output) accTchkTerminal (acc_handle_tchkarg1 acc_handle_tchkarg2) accPartSelect (acc_handle_conn, acc_handle_pathin, acc_handle_pathout) accRegBit (acc_handle_by_name, acc_handle_tfarg, acc_handle_itfarg) PLI
,
acc_close
, .
ё
PLI accTerminal, .
accRegBit
,
acc_close () ,
Third party PLI applications(
PLI) PLI
ModelSim Verilog. ModelSim Verilog , PLI. ModelSim Verilog.
,
,
Verilog-XL PLI,
, Verilog-XL PLI veriuser.c. veriuser.c "Registering PLI applications"( " ModelSim Verilog, veriuser.c , ( . "Compiling and linking PLI/VPI applications"(" PLI/VPI") ). , veriuser.c , , Solaris:
PLI ").
libapp.a,
% cc -c -I /modeltech/include veriuser.c % ld -G -o app.sl veriuser.o libapp.a PLI
ModelSim Verilog.
Veriuser PLIOBJS (
modesim.ini, "
HP700, , Verilog-XL
:
-pli PLI " ).
+z.
,
, ,
,
, ,
ModelSim Verilog.
, 133
, ,
.
Support for VHDL objects(
VHDL)
PLI ACC VHDL VHDL VHDL , : Type ( ) Fulltype( ) accArchitecture accArchitecture accArchitecture accEntityVitalLevel0 accArchitecture
ccArchVitalLevel0
accArchitecture
cArchVitalLevel1
accArchitecture
VHDL/Verilog.
Description(
)
, VITAL_Level0 , VITAL_Level0 , VITAL_Level1 , FOREIGN
accForeignArch
VHDL , generics accArchitecture
accForeignArchMixed
, FOREIGN VHDL , generics
accBlock accForLoop accForeign
accBlock accForLoop accShadow mti_CreateRegion ()
accGenerate
accGenerate
accPackage accSignal
accPackage accSignal
acc_vhdl.h. ACC , , , ModelSim VHDL (mti_* .
ё ,
VHDL )
(
, ).
. generics, .
, ,
PLI ,
. FLI Reference Manual
134
IEEE Std 1364 ACC routines ( Std 1364 ACC ) ModelSim Verilog Std 1364. : acc_fetch_paramval () , acc_fetch_paramval_str () Acc_fetch_paramval_str () , cc_fetch_paramval () , Acc_fetch_paramval_str ()
ACC
,
64.
-
,
PLI acc_user.h.
. ,
*. .
IEEE Std 1364 TF routines ( ModelSim Verilog Std 1364.
Std 1364 TF ) TF
,
135
Verilog-XL compatible routines (
Verilog-XL)
PLI
Std 1364,
ModelSim Verilog
Verilog-XL. char *acc_decompile_exp(handle condition)
acc_decompile_expr Verilog-XL. acc_handle_condition.
, acc_decompile_exp –
, .
char *tf_dumpfilename(void) VCD. void tf_dumpflush(void) VCD ( $dumpflush
Verilog).
int tf_getlongsimtime(int *aof_hightime) 64.
, aof_hightime.
64-bit support in the PLI ( acc_fetch_paramval PLI () , acc_fetch_paramval_str () Acc_fetch_paramval_str () , acc_fetch_paramval () *. Acc_fetch_paramval_str ()
64-
PLI) 64.
-
,
PLI acc_user.h.
. , .
136
PLI/VPI tracing(
PLI/VPI )
, PLI
VPI. : ,
-
,
;
,
C,
,
, .
logfile(
)
PLI
VPI.
,
MTI PLI/VPI,
, PLI/VPI. VHDL/Verilog,
, .
,
vsim (CR-235)
-trace_foreign:
vsim -trace_foreign [-tag ]
:
ё
1
"mti_trace_" ё
2
"mti_data_.c", "mti_init_.c", "mti_replay_.c" and "mti_top_.c" ё
3
-tag ,
.
.
137
vsim -trace_foreign 1 mydesign logfile. vsim -trace_foreign 3 mydesign , logfile
.
vsim -trace_foreign 1 -tag 2 mydesign logfile "2".
, (calltf, checktf, sizetf
PLI/VPI
misctf
),
Verilog VCL.
Debugging PLI/VPI application code(
PLI/VPI) PLI/VPI
, (
).
-g
Solaris, AIX, vsim ‘). , wdb ‘
ddd ‘ (
.
vsim
ё
,
, ,
vsim
.
Linux
gdb - UX
ddd (
,
wdb HP www.hp.com/go/wdb.
vsim ‘). 1.2
. vsim's PLI/VPI, PLI/VPI,
. ,
,
()
. vsim, .
acc_product_version , ,
(
vsim
, " run -c top").
HP-UX
,
vsim , F5 , HP-UX " __ dld_flags "
. . HP Windows NT, , , vsim GUI. go , vsim wdb. , . share , . ,
vsim Exceed,
NT " go"
PLI/VPI. .
. PLI/VPI.
,
share . PLI/VPI
.
PLI/VPI.
138
6 - Mixed VHDL and Verilog Designs ( VHDL Verilog) ,
VHDL Verilog VHDL Verilog Verilog VHDL
Verilog Verilog vgencomp
Verilog VHDL SDF
VHDL
,
(SKS - single-kernel simulation) ModelSim VHDL / Verilog. ,
HDLs. VHDL ,
VHDL
Verilog
.
,
VHDL . HDL
Verilog.
Verilog, .
, VHDL
Verilog.
139
Separate compilers, common design libraries( , ) vcom (CR-250)
VHDL
(
(
, Verilog UDPs)
)
,
.
, ,
vlog (CR-286) . VHDL
Verilog, VHDL
( ).
. "Design Libraries"( "
") ,
vcom (CR-250)
vlog(CR-286).
Access limitations in mixed-language designs( ) Verilog VHDL. , ,
,
. VHDL (
, . .)
, . ,
Verilog VHDL.
"
VHDL VHDL: 1) ; 2) 12 - Signal Spy
" )
(
Verilog Signal Spy( ).
Simulator resolution limit( ) VHDL.
" Simulator resolution limit "
.
Mapping data types( - HDL ModelSim
. HDL -
) ,
-
, ,
HDL . 140
VHDL
Verilog .
VHDL Verilog
, Verilog VHDL generics VHDL. ModelSim HDL .
Verilog
VHDL generics ( VHDL integer real time physical enumeration string
VHDL) Verilog integer or rea integer or real integer or real integer or rea integer or real string literal real, real
,
. : ‘ timescale.
Verilog
, T'VAL (P),
Verilog. , VAL -
T–
VHDL , ,
Verilog parameters( Verilog VHDL integer real string
P-
.
)
Verilog Integer Real String Verilog
VHDL and Verilog port( VHDL ё
VHDL Verilog:
ё
VHDL
.
Verilog
) Verilog
,
Bit bit_vector std_logic std_logic_vector vl_logic 141
vl_logic_vector vl_logic ,
,
Verilog,
ё vl_logic
.
bit
std_logic ,
Verilog. ,
vl_logic . vl_types
Vl_logic verilog. ( std
ieee). ModelSim. (
vl_types . \modeltech\vhdl_src\verilog\vltypes.vhd.)
Verilog states( Verilog
)
Verilog
std_logic
bit
:
Verilog
std_logic
bit
HiZ
’Z‘
’0‘
Sm0
’L‘
’0‘
Sm1
’H‘
’1‘
SmX
’W‘
’0‘
Me0
’L‘
’0‘
Me1
’H‘
’1‘
MeX
’W‘
’0‘
We0
’L‘
’0‘
We1
’H‘
’1‘
WeX
’W‘
’0‘
La0
’L‘
’0‘
La1
’H‘
’1‘
142
LaX
’W‘
’0‘
Pu0
’L‘
’0‘
Pu1
’H‘
’1‘
PuX
’W‘
’0‘
St0
’0‘
’0‘
St1
’1‘
’1‘
StX Su0
’X‘ ’0‘
’0‘ ’0‘
Su1
’1‘
’1‘
SuX
’X‘
’0‘
ё
Verilog •
(strength):
'0'
• std_logic strong strength(
'X',
• std_logic strong strength(
'W',
0
1
) 0 )
1
VHDL
Verilog bit '0' '1'
VHDL std_logic,
:
Verilog St0 St1
Verilog Std_logic
Verilog
'U' 'X' '0' '1' 'Z' 'W' 'L' 'H'
StX StX St0 St1 HiZ PuX Pu0 Pu1
:
143
'- '
StX
VHDL instantiation of Verilog design units (VHDL Verilog) Verilog, , Verilog
VHDL
. .
ё
,
,
ё
,
Verilog
.
Verilog instantiation criteria(
Verilog)
Verilog : •
VHDL,
-
(UDPs,
•
). (Verilog
).
•
( VHDL).
Component declaration( Verilog VHDL ,
)
,
, VHDL. , vgencomp (CR-259). vgencomp (CR-259)
, .
: • std_logic • std_logic_vector ,
:
144
• bit
bit_vector
• vl_logic VHDL
vl_logic_vector
Verilog VHDL
,
ё
ё VHDL 1076-1987, VHDL 1076-1993 ( -93). VHDL
Verilog
,
Verilog VHDL
ё
,
.
Verilog ,
: • Verilog (CR-259)
-93.
vgencomp VHDL 1076-1993 Verilog,
, . , Verilog , , vgencomp (CR-259) -93 . : Verilog , -93 .
•
Verilog topmod TOPMOD TopMod top_mod _topmod
VHDL topmod topmod topmod top_mod \_topmod\
\topmod \ \topmod\
topmod \topmod\
Verilog
ё .
,
,
-93:
Verilog
VHDL
Topmod
topmod
TOPMOD
\TOPMOD\
TopMod
\TopMod\
top_mod
top_mod
_topmod
\_topmod\
145
\topmod
Topmod
\ \topmod\
\topmod\
vgencomp component declaration ( vgencomp) vgencomp (CR-259)
:
Generic clause(
) ,
. , .
,
,
integer
integer
real
real
string literal
string
-
:
.
Verilog p1 = 1 - 3;
VHDL p1 : integer := -2;
p2 = 3.0;
p2 : real := 3.000000;
p3 = "Hello";
p3 : string := "Hello";
,
. Verilog
VHDL
. 146
VHDL VHDL
,
bit, std_logic, vl_logic. - bit_vector, std_logic_vector, ,
Verilog vl_logic_vector. ,
.
Verilog
VHDL
input p1;
p1 : in std_logic;
output [7:0] p2;
p2 : out std_logic_vector(7 downto 0);
output [4:7] p3;
p3 : out std_logic_vector(4 to 7);
inout [width-1:0] p4;
p4 : inout std_logic_vector;
Verilog .
,
Verilog,
Verilog
.
Verilog instantiation of VHDL design units (Verilog VHDL) VHDL
Verilog (
).
VHDL instantiation criteria(
VHDL)
VHDL : •
Verilog,
-
/
• Vl_ulogic_vector, . • -
.
bit, bit_vector, std_ulogic, std_ulogic_vector, vl_ulogic, .
,
, .
,
,
,
.
. ,
. 147
-
VHDL
(1076-1993).
VHDL -
, VHDL
. . ,
ё
defparam
generics
. .
Verilog
. ,
. Verilog,
, .
" Library usage ( .
)" ,
, :
\mylib.entity(arch) u1 (a, b, c); \mylib.entity u1 (a, b, c); \entity(arch) u1 (a, b, c);
, : • library = mylib • design unit = entity • architecture = arch
SDF annotation( SDF VHDL/Verilog for Mixed VHDL and Verilog Designs( SDF .
) SDF. "SDF VHDL /Verilog ")
148
7 – WLF files (datasets) and virtuals (WLF ( ) WLF
(
)
) WLF
ModelSim (
,
,
. .)
WLF WLF(wave log format -wlf vsim (CR. ,
ModelSim 296))
)( "
",
WLF
. ModelSim
5.3
,
WLF
.
, ,
,
.
WLF files (datasets)( WLF
(
))
(WLF)
.
WLF . WLF
"
"
,
, .
WLF
,
" sim ",
. WLF.
,
Wave — 149
" sim "; " gold" .
(
: " Simulator resolution limit " ) ,
.
Saving a simulation to a WLF file( WLF) Dataflow, List, log ,
Wave WLF ,
vsim.wlf ,
. . vsim (CR-296), , WLF . File > Save Dataset Wave Main dataset save (CR-129 dataset snapshot (CR-130), .
,
vsim.wlf
–wlf < filename >
, WLF :
dataset save dataset snapshot, quit quit –sim , WLF. , WLF .
ModelSim )"
" bad magic number ( .
Opening datasets(
) , File > Open > Dataset( dataset open (CR-127.
Open Dataset • Dataset Pathname( WLF • Logical Name for Dataset( , .
Viewing dataset structure (
Main)
. ) ,
. ) .
WLF
)
150
5.5
,
,
,
Structure
. " Structure:
Structure ".
("sim")
("test"
"gold").
, ,
, ,
, UNIX — 2-
(Windows – 1-
). , (Windows — 2-
, , UNIX — 3-
. " Structure window context menu( .
)
-
Structure )"
Managing multiple datasets(
) Ь ,
Dataset Browser. ,
View > Dataset (
Dataset Browser
Main).
.
• Open Open Dataset (
"
)" .
• Close . . • Make Active "
".
,
.
,
, , :
.
env
VSIM.
Main. .
• Rename .
,
,
vsim -view .
151
WLF
. vsim –
,
view
:
-view = : vsim -view foo=vsim.wlf ModelSim ,
,
"
" . Main. ,
. environment (CR-147),
rowser
,
Dataset . WLF
,
.
:
Sim:/top/alu/out View:/top/alu/out Golden:top.alu.out ,
, .
, ModelSim Wave . Tools > Window Preferences (
, Wave
List).
"
ModelSim
List
"
..
environment (CR-147)
.
:
env foo: foo foo. . (
"
")
,
.
Signals
. ,
, . (
, ,
,
pref.tcl, PrefMain (DisplayDatasetPrefix). ё 0 . 1
,
: /top/foo), . File > Environment (
1
Signals).
,
.
152
, Tools > Edit Preferences (
pref.tcl, ).
,
, . - dataset ( , pref.tcl.
environment -nodataset, , environment (CR-147) 1).
environment
Saving at intervals with Dataset Snapshot( ) WLF . "
"
WLF
,
. , Snapshot (
Tools > Dataset
Wave).
Dataset Snapshot Dataset Snapshot
:
• Enabled/Disabled . Disabled К • Simulation Time ,
, 1000000
.
.
• WLF File Size ,
, .
WLF - 100 .
К • Snapshot contains only data since previous snapshot ( , ModelSim, , . • Snapshot contains all previous data ( , .
) . WLF
) ,
153
WLF
,
. К
К
• Directory ,
Ф ModelSim
.
• . ModelSim
.
.wlf
/ • Always replace snapshot file( ,
) . .
• Use incrementing suffix on snapshot files( ) , ё . ( , vsim_snapshot_0.wlf, vsim_snapshot_1.wlf,
. .)..
Virtual Objects (User-defined buses, and more) ( ( , . .)) GUI,
-
ModelSim.
,
5.3, ModelSim : • • • • ,
Bus1
:
Virtual signals(
) 154
-
,
WLF , , , force. (Edit > Combine),
. examine , virtual signal (CR-280). ,
.
, . -install , .
virtual signal
,
,
RTL ,
. ,
RTL-
,
. virtual hide (CR-271) ,
, . ,
WLF
,
virtuals:/Signals. -
, ,
. virtuals save(CR-278). .
, , ModelSim )
, virtuals (
Wave Wave )
" implicit(
virtuals.do
List ,
List,
,
virtuals.do ( Wave
.
virtual
List
: ) virtuals "
Wave
List.
virtuals ModelSim ,
, .
ё
Wave,
,
. -
,
ё
, .
155
"explicit(
) virtuals ".
Virtual functions(
) GUI
,
.
, .
,
,
examine (CR-148),
force
( CR-154). : •
,
•
,
•
,
"
• 1.34 ns "
"
,
"
CLK,
,
ё
.
GUI :
,
, , std_logic, std_logic_vector, 9.
,
. Verilog VHDL std_logic
Verilog ,
the virtual function
(CR-268). ModelSim , Verilog "vreg" Verilog.
Verilog GUI, .
Virtual regions(
.
Verilog ,
)
,
RTL .
,
156
,
RTL . ,
virtual region
(CR-277) .
Virtual types(
) , -
. ,
. , . ,
virtual type
(CR-283).
Dataset, WLF file, and virtual commands ( , WLF
)
, WLF
,
. ,
,
ModelSim.
dataset alias (CR-122) dataset list (CR-126) dataset open (CR-127) dataset save (CR-129) dataset snapshot (CR-130) log (CR-164)
WLF
nolog (CR-172)
WLF
searchlog (CR-212) WLF virtual function (CR-268)
virtual region (CR-277) virtual signal (CR-280) virtual type (CR-283) 157
vsim (CR-296) -wlf
WLF
,
158
)
8 - Graphic Interface( Window
ё
.
ModelSim Windows ;
,
ModelSim
,
. ,
ModelSim , ModelSim .
. Tcl/Tk,
,
,
.
159
Window overview(
Window) .
ModelSim
( File > New
). Window. : • ,
. .
ModelSim ) .
(
• "
"
(
).
• VHDL,
Verilog
. • ,
.
• VHDL, ,
Verilog .
• , ("
HDL .( . see "Source code security and -nodebug" -nodebug ") .)
• , ,
,
,
VHDL
, .
5.5
Verilog,
,
, .
• VHDL
,
Verilog
(
),
, .
• ( VHDL,
), Verilog
. .
160
Common window features(
)
ModelSim’s
, ; .
Quick access toolbars(
Main, Source,
Wave
) Drag and Drop (
Dataflow, List, Process, Signals, Source, Structure, Variables,
)
Command history( ) Automatic window updating ( ) Finding names, searching for values, and locating cursors ( , , ) Sorting HDL items ( HDL ) Multiple window copies ( Menu tear off(
Dataflow, Process, Signals,
Wave
Structure
Process, Signals, Source, Structure, Variables Wave
) )
Customizing menus and buttons ( ) Combining items in the List window List) ( Combining items in the Wave window ( Wave) Tree window hierarchical view (
List Wave
Structure, Signals, Variables,
Wave
)
• Cut/Copy/Paste/Delete
, .
•
cut/copy/paste - ^X / ^ C / ^ V .
161
• (
, ). ,
.
•
( )
• -
: ,
,
-
X- Windows
(
),
-
. : X- Windows. ё X- Windows (xterm, emacs,
•
. .). Transcript
Edit > Paste
.
•
.
Quick access toolbars(
)
Dataflow, Main, Source,
Wave .
Drag and Drop(
) HDL
.
,
,
, •
,
.
: Dataflow, List, Process, Signals, Source, Structure, Variables,
•
Wave
: Dataflow, List,
Wave ,
: List
Wave. 162
Command history(
) ;
,
.
Automatic window updating(
) :
ModelSim
Dataflow window
Process window Signals window Source window Structure window Variables window Dataflow window Signals window Structure window Variables window Dataflow window Process window Signals window Source window
Process window
Signals window Structure window
Finding names, searching for values, and locating cursors ( , , •
HDL Edit > Find : Dataflow, List, Process, Signals, Source, Structure, Variables, , .
Wave
(\)
Find , \Arch Signal 1 \,
• List
)
HDL Wave
. \\ Arch.... ,
,
Edit > Find
:
. :
•
List,
•
Wave ,
View > Goto. View > Cursor.
163
,
< < Find>>,
. (
Find
Sun). event add Tcl/Tk.
< < Find>>, ,
event add
Sorting HDL items(
HDL
Process, Signals, Structure, Variables ,
View > Sort HDL net_1, net_10,
)
net_2
Signals
Multiple window copies(
Wave, . Wave.
)
File > New Window , .
.
Saving window layout(
) ModelSim
. :
,
1 2
, . Tools > Save Preferences ( Main) modelsim.tcl . 3 " " shortcut ModelSim, ( Windows), MODELSIM_TCL, ( " Windows " ).
Context menus(
) ,
" " Windows, UNIX — 3-
(2-
,
Menu tear off(
) «
.
,
). , . , . : Dataflow, List, Main, Signals, Source,. Wave.
»( torn off), ,
,
.
Customizing menus and buttons( ,
)
,
. .
164
• "Customizing menus and buttons" ( "
") ,
• "The Button Adder" ("
")
.
Tree window hierarchical view( ) ,
ModelSim
"
" Structure, Signals, Variables,
Structure Wave. HDL
, , VHDL HDL
Verilog :
VHDL (
) ,
,
, ,
, Verilog (
) ,
,
,
,
, ,
, )
(
) ,
,
, ." ,
( . .) " .
165
,
,
,
, .
, , .
[+]
ё
+,
[-]
ё
-,
ё
Find , < control- f > (Windows).
< control-s> (Unix)
,
Edit > Find
Find .
.
,
• "Finding items by name in the List window" (" ") • "Finding HDL items in the Signals window" ( " ")
HDL
• "Finding items by name or value in the Wave window" ( " " ).
Main window(
) ,
ModelSim.
,
, ; ,
ModelSim .
Main
:
,
,
/
. 166
The toolbar provides buttons for quick access to the many common commands.
ModelSim. . ,
ModelSim. ,
.
Workspace(
) 5.5
.
, ,
/
. View > Hide/Show Workspace.
. •
Project
•
, 2- Project Library
. .
"
"
•
.
Structure .
,
" Structure window " . .
•
"
.
" Compare ,
,
. .
11 -
Transcript(
) Main
, ,
,
ModelSim. VSIM, .
ё
,
.
,
, (
"
"
).
Main 167
, Main. modelsim.ini .
TranscriptFile
modelsim.tcl
PrefMain (file) ,
TranscriptFile
modelsim.ini –
.
, . ,
File > Transcript > Save Transcript As, File , Tcl - PrefMain Save Transcript.
Transcript > Save Transcript . Save Transcript As, (saveFile). ,
,
Save.
.
,
(DO
) (DO file).
do (CR-137 )
.
The Main window menu bar(
)
ModelSim . .
New
: FolderSource-
VHDL, Verilog,
ProjectLibrary-
ё ;
Window-
"
ё
"
Open
: File ProjectDataset-
hdl .mpf WLF
Close
: ProjectDataset-
Import
: Library-
FPGA; 168
Save Delete
"Importing FPGA libraries" : Dataset: Project-
Change Directory Transcript
.mpf :
Save Transcript-
transcript Main window transcript file" (" ") Save Transcript as...-
Main "Save Transcript as"( , ), . "Saving the
Main
Clear TranscriptMain Add to Project
: File – ; see "Step 2 — Add items to the project" Simulation Configuration – , ( ) ; "Creating a Simulation Configuration" Folder – "Organizing projects ; with folders"
Recent Directories Recent Projects Quit
, ModelSim
Copy Paste Select All Unselect All Find
All Windows Dataflow
ModelSim /
Dataflow
169
List Process Signals Source
/ / / /
Structure
/
Structure
Variables
/
Variables
Wave
/
Wave
Datasets , Hide/Show Workspace Encoding.
List Process Signals Source
Dataset Browser ,
select from alphebetical 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 , , , ASCII,
Unicode,
Shift-JIS
Properties
Compile Compile Options
HDL VHDL "Setting default compile options" : "Step 3 — Compile the files" Verilog:
Compile All Compile Order
:
"Changing compile order"
Compile Report ( ) Compile Summary
170
Simulate
Simulating
; with the graphic interface
Simulation Options Run
; "Setting default simulation options" : Run ; Simulate > Simulation Options, Run Length Run –All ; . Continuerun (CR-208) -continue Run –Next -
, run (CR-208) ; .
Step -
;
.
step (CR-220 ) Step –Over Restart -
, ;
,
,
; — ,
, , )
( restart (CR-202 )
;
.
Break End Simulation
Waveform Compare Profile
; : Profile On – 9Profile Off Profile Clear – ( View hierarchical profile(
;
) )-
; View ranked profile(
)-
; Source Coverage
; Code Coverage 171
ё Breakpoints
; "Setting file-line breakpoints"
Execute Macro Macro Helper
.do
.tcl
UNIX "The Macro Helper" Tcl , TDebug; . Debugger" TclPro Debugger Scriptics ® , TclPro Transcript File:
;
.
Tcl Debugger TclPro Debugger Options(
)
Command History: , Save File: Save Transcript As Saved Lines: ( Line Prefix: Update Rate:
"The Tcl . Scriptics
Save Transcript,
5000)
ModelSim Prompt: ModelSim VSIM Prompt: Paused Prompt: HTML Viewer:
VSIM Paused ;
Edit Preferences
Save Preferences
; http://www.model.com/resources/pref_variables/frameset.htm ModelSim Tcl; http://www.model.com/resources/pref_variables/frameset.htm
(
)
Start Comparison Comparison Wizard Run Comparison End Comparison Add
: Compare by Signal (
)-
Compare by Region(
)172
Clocks(
)-
,
Clear ( Show (
))-
Options Differences
: Wave Main Save -
,
Write Report(
)-
Rules
: Show (
)–
Save – Reload
ё
Initial Layout
Cascade Tile Horizontally Tile Vertically : Layout Style
Default –
5.5
Classic 5.5 Cascade Horizontal Vertical Icon Children
Main
Icon All Deicon All Customize
(deicon) The Button Adder(
),
173
; , Source
;
, , ;
"View menu" view (CR-261)
,
Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences,
PrefMain (layoutStyle).
Help About ModelSim
ModelSim ( . .
)
Release Notes
notepad (CR-174) ModelSim
Enable Welcome
Welcome ,
Welcome Menu SE PDF (HTML) Documentation
ModelSim
Welcome PDF Adode ModelSim CD
ModelSim HTML; PDF Acrobat reader , www.adobe.com
Tcl Help
Tcl (
)
Windows Tcl Syntax
Tcl
Tcl Man Pages
Tcl /Tk 8.3
Technotes
HTML HTML
,
The Main window toolbar(
)
ModelSim.
174
Compile > Compile Compile HDL Source
vcom < arguments >, vlog < arguments > .: vcom (CR-250) vlog (CR-286)
Files
Simulate > Simulate
vsim < arguments > .: vsim (CR-296)
Simulate , Edit > Copy
.: " "
Edit > Paste
.: " "
Simulate > Run > Restart
restart .: restart (CR-147)
Simulate > Simulation Options
run .: : run (CR-208)
Simulate >Run > Run
run (no arguments) .: run (CR-208)
Simulate >Run > Continue
run -continue
, , ,
WLF file Run Length
.: run (CR-208)
175
Run > Run -All
-
run –all .: run (CR-208), * ."Assertions tab ( )"
Simulate > Break
Simulate >Run > Step
Step .: step (CR-220)
HDL Simulate >Run > Step -Over
HDL ,
step -over
.: step (CR-220)
The Main window status bar(
)
:
Project Now
,
(
ё "Simulating with the graphic interface", ,
Delta
(
,
)
176
Mouse and keyboard shortcuts (
) , .
, notepad ModelSim,
Notepad ( ). - UNIX
Source
- Windows
< left-button - click > < left-button - press > + drag < shift - left-button - press > < left-button - double-click > < left-button - double-click > + drag
+
< control - left-button - click > < left-button - click > ModelSim
VSIM
< middle-button -click >
none
< middle-button - press > + drag
none
UNIX < left | right - arrow >
Windows |
< control > < left | right - arrow > | < shift > < left | right | up | down arrow > < control > < shift > < left | right - arrow > < up | down arrow > (
Source, |
)
< control > < up | down > 177
| < control > < home > < control > < end > < backspace >, < control-h > < delete >, < control-d >
< backspace >
none < alt >
esc
< delete >
< alt > < F4 > < control - a >, < home > < control - b >
< home >
< control - d > < control - e >, < end >
< end >
< control - f >
< control - k > < control - n >
< control - o >
Source
( Windows)
Source
( Windows)
none
< control - p >
< control - s >
< control - f >
< F3 > < control - t >
< control - u > < control - v > PageDn
PageDn
< control - w >
< control - x >
< control - x >, < control - s> < control - y >, F18
< control - s > < control - v >
178
none
< control - a > (widget)
< control - \ > < control - ->, < control < control - Z > -/> Source < meta - "" >
none
< meta - v > , PageUp
PageUp
< Meta - w>
< control - c >
< F8 > ,
( Main) < F9> < F10 > < F11 > < F12>
;
, .
Dataflow window ( Dataflow) Dataflow
"
"
;
,
; .
;
,
,
;
.
Adding items to the window (
ё
) : 179
• • •
Navigate add button (CR-45 ) Navigate
Dataflow ,
.
: View region — Add region — View all nets — , ,
. Navigate > Expand net
, to readers.
, .
Links to other windows(
)
Dataflow
:
Main window
Dataflow, Structure,
Process window
,
Signals window Wave window
, •
Dataflow, Wave
•
Wave, Dataflow Dataflow, ,
Source window Source
Dataflow window menu bar (
Dataflow) Dataflow. (
3-
).
New Window Print Print Postscript Page setup Close
ё
Dataflow Dataflow(
Windows) / Dataflow Dataflow;
postscript ,
/ , 180
Undo ё
Redo Cut
( )
Copy
( )
Paste ( ) Erase selected Select all Unselect all ё
Erase highlight Erase all Regenerate
,
Find Find Next
Show Wave Select
,
Zoom
Pan
Default
Expand net to drivers Expand net to readers
( )
, ( )
,
181
Expand net
( )
( )
, Hide selected
Show selected
, ё
View region Add region View all nets Add ports
TM
TraceX
(X) TM
(X)
Chase X Trace next event , Trace event set Trace event reset
Load built-in symbol map Load symlib library Create symlib index
ё
.bsm "Symbol mapping" ё ё
Options
;
Dataflow
Window Initial Layout
Cascade Tile Horizontally Tile Vertically : Layout Style
Default –
5.5
Classic 5.5 182
Cascade Horizontal Vertical Icon Children
Main
Icon All Deicon All
(deicon)
Customize
The Button Adder(
),
; , Source
;
, , ;
"View menu" view (CR-261) . ModelSim.
,
Layout Style, ё
Layout Style ,
Tools > Save Preferences, PrefMain (layoutStyle).
The Dataflow window toolbar(
Dataflow) .
File > Print (Windows) File > Print Postscript (UNIX) View > Select
View > Zoom
View > Pan
Edit > Cut
Edit > Copy
Edit > Paste
183
Edit > Undo
Edit > Redo
Edit > Find
Trace input net to event -
Trace > Trace next event
,
Trace > Trace event set
Trace > Trace event reset Trace > TraceX
Navigate > Expand net to drivers Navigate > Expand net
Navigate > Expand net to readers Edit > Erase highlight
Edit > Erase all
Edit > Regenerate
none
none
none 184
none
View > Show Wave
Exploring the connectivity of your design( ) Dataflow,
"
.
"
– .
ё
/
,
,
.
, .
, ,
,
,
ё
,
,
.
,
, , ,
. ,
, ,
, : Navigate > Expand net to drivers Navigate > Expand net
Navigate > Expand net to readers
,
,
"
"
.
,
-
.
. nb
,
,
,
. Edit > Erase highlight.
185
, Dataflow
.
, window" )
,
" Wave
Wave ( ). View > Show Wave
,
Dataflow,
, ,
.
, (
"Using time cursors in the Wave window"
),
Dataflow.
Dataflow, ,
.
"Tracing events (causality)" .
Zooming and panning (
)
Dataflow . И :
186
И , Zoom Mode,
View > Zoom .
, : • •
: :
( )
• •
: : .
,
10
.
Pan Mode View > Pan.
.
Tracing events (causality)(
(
))
Dataflow
,
. " The embedded wave viewer ( ).
Dataflow ( )"
,
Dataflow ,
,
. : (
1 2 Dataflow 3
log -r / *). ,
. ,
Dataflow (
,
).
,
, . 187
;
4 ,
.
5
Trace > Trace next event.
. 6
Trace > Trace next event .
,
,
.
7
Trace > Trace set..
Dataflow "
"
(
).
, .
, .
,
,
8,
5
. ,
Trace > Trace
reset.
Tracing the source of an unknown (X)( (X)) (X). Wave – , .
: .
1 2
, (log -r /* ). Wave
3
, .
4 5 6
, , Trace > TraceX
Trace > TraceX — Trace > ChaseX — "
. Dataflow,. Trace > ChaseX. :
"
Finding items by name in the Dataflow window( Dataflow)
188
,
Edit > Find, . , (Signal), ё ,
,
a
,
(Instance),
,
(Any). Zoom To. Find Next.
Printing and saving the display(
)
a .eps
UNIX
File > Print Postscript ,
Dataflow UNIX, .
.eps :
Print Postscript
• Print command UNIX
UNIX.
• File name Postscript (.eps) .eps
; .
• Paper size . • Border width . • Font .
"Printer Page Setup" Windows Dataflow
File > Print, . :
• Name . Properties. • Status . • Type . ,
"Print to file" .
• Where 189
. • Comment . • Print to file ,
. . PostScript
, PostScript
P stscript (.ps)
.prn
. File > Print Postscript .
Postscript (.eps)
Configuring page setup(
)
Setup
Postscript (
Print
-
,
File > Page setup)).
:
Dataflow Page Setup • View Full (
)
Current View (
,
).
• Highlight ,
( )")
" Tracking your path through the design ( .
• Color Mode Color (256 (
), Invert Color (
)
Mono
).
• Orientation Landscape (
)
Portrait (
).
• Paper ,
.
Symbol mapping( Dataflow , , ,
) Verilog (
. .).
Verilog, . ,
, ,( DUname. Processname),
, -
. : xorg(only).p1 XOR org(only).p1 OR andg(only).p1 AND 190
: AND1 AND AND2 AND # A 2-input and gate AND3 AND AND4 AND AND5 AND AND6 AND xnor(test) XNOR
,
,
.
Dataflow
dataflow.bsm,
(.bsm 0
" Built-in Symbol Map).
.
, ASCII
. NlviewTM Symlib.
, www.model.com/products/documentation/nlviewSymlib.html. Dataflow
, ,
dataflow .sym ".
Nlview, DU
.
, ,
, .
: symbol adder(structural) * DEF \ port a in -loc -12 -15 0 -15 \ pinattrdsp @name -cl 2 -15 8 \ port b in -loc -12 15 0 15 \ pinattrdsp @name -cl 2 15 8 \ port cin in -loc 20 -40 20 -28 \ pinattrdsp @name -uc 19 -26 8 \ port cout out -loc 20 40 20 28 \ pinattrdsp @name -lc 19 26 8 \ port sum out -loc 63 0 51 0 \ pinattrdsp @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 \ 191
path 0 -7 10 0 , Entity|Module|Process ( ,
,
/
). symlib,
: . , , symlib.
Tools > Create Symbol Index, ( ,
Dataflow) .
Configuring window options(
) ,
Dataflow
,
. . Dataflow Options.
Tools > Options,
:
Dataflow Options • Keep Dataflow . • Show Hierarchy ,
.
,
,
. • Bottom inout pins -
,
. • Disable Sprout /
.
Dataflow
,
5.6.
• Select equivalent nets ,
ModelSim
. • Log nets ,
.
List window(
) , ,
.
, ,
.
192
HDL items you can view(
HDL) VHDL
Verilog HDL
: •
VHDL
•
Verilog
• ;
11 - Waveform Comparison
. •
,
:
(
)
-
List
Wave.
Adding HDL items to the List window( List ) ( List) " ).
HDL
List " Setting List window display properties ( List
. Д List Wave, or Structure.
, ,
Signals, Source, Process,Variables, List.
,
. Д
Main add list (CR-48), ;
:
add list : add list * : add list -r /* 193
Д
List List, . ,
DO
,
List.
: HDL
•
List.
•
, ( "Editing and formatting HDL items in the List window") • , File > Save Form, ( ,
,
List). List,
DO
: •
do (CR-137)
,
:
do •
List.
> Load Format List ,
:
-
; .
,ModelSim HDL,
.
The List window menu bar (
) List.
New Window
List
Open Dataset
WLF
Save Dataset WLF Load Format
DO
Save Format
List, Save Format List DO ( )
;
DO List , , Close View > New
DO List; "The Main window menu bar"
194
Cut
;
. "Editing and
formatting HDL items in the List window" Copy Paste , Delete Select All Unselect All Add Marker
List List
Delete Marker Find... Search...
List List
,
Signal Properties
, \
,
,
Goto
,
Combine Signals
; ;
" Combining items List) "
in the List window ( Window Preferences
:
, ,
Properties
,
, ,
\
,
,
Initial Layout Cascade Tile Horizontally Tile Vertically Layout Style
: Default –
5.5
195
Classic 5.5 Cascade Horizontal Vertical Icon Children Icon All Deicon All Customize
The Button Adder,
;
, ,
;
Source ;
"View menu" (CR-261)
, ,
view
Layout Style,
. ModelSim.
ё
Layout Style ,
Tools > Save Preferences, PrefMain (layoutStyle).
Editing and formatting HDL items in the List window( HDL List) ,
, List , ,, "Adding HDL items to the List
HDL,. ( window(
HDL
List)") :
,
List ,
,
. List Edit menu
. click+drag,
.
: View > Signal Properties (
List List).
, List Signal
Properties ,
,
,
. :
List Signal Properties • Signal . • Display Name List .
196
• ,
. ,
,
List .
, radix (CR-198). ,
Simulate > Simulation Options (
,
,
Main)
DefaultRadix (UM-447) modelsim.ini , , , ASCII .
.
, modelsim.tcl, ,
,
,
,
. List.
( (
) ).
• Width . . • Trigger: Triggers line( : , List. • Trigger: Does not trigger line( ,
ё
– )
:
) List. ,"
. Setting List window display properties (
List) ".
Combining items in the List window( List
List) .
, . , Tools > Combine Signals.
Combine Selected Signals
List,
:
• Name . • Order of Indexes Specifies in which order the selected signals are indexed in the bus. If set to, the first signal selected in the List window will be assigned an index of 0. If set to , the first signal selected will be assigned the highest index number. , . Ascending ( ), , List 0. Descending( ), . 197
• Remove selected signals after combining( ) , .
List ,
Setting List window display properties( ) ,
List
. , Tools > Window Preferences ( List). Properties Window Properties
List, Modify Display Triggers.
Window Properties :
Window Properties • Signal Names ,
List.
. "1"
, "0"
.
• Max Title Rows . :
• Dataset Prefix: Always Show Dataset Prefixes( ) ,
. .
• Dataset Prefix: Show Dataset Prefix if 2 or more( , 2 ) , . • Dataset Prefix: Never Show Dataset Prefixes( )
: 2 : .
Trigger List.
Triggers ,
HDL
List Trigger on: Signal Change,
,
. . .
, Signal Change
Strobe
. :
Triggers • Deltas:Expand Deltas ,
Trigger on: Signals Change , , . 198
• Deltas:Collapse Deltas . • Deltas:No Deltas (
).
• Trigger On: Signals Change .
. ,
View
,
> Signals Properties -notrigger
add list (CR-48).
• Trigger On: Strobe Strobe Period
;
First Strobe at:.
• Trigger Gating: Use Gating Expression( )
: (
1)
(
0)
Expression. • Trigger Gating: Expression , , .
,
• Use Expression Builder ( ) Expression Builder ( . . "The GUI Expression Builder"(" GUI
.
), ")
• Expression , Builder ( List ).
Expression ,
Use Expression Builder). (
• Trigger Gating: On Duration(
:
)
, ,
;
x
. ,
. List
,
. : .list.tbl config -usegating 1 .list.tbl config -gateduration 100 199
.list.tbl config -gateexpr {}
Finding items by name in the List window( List) Find Find ( List) Enter a text string and
List.
Edit >
Find.
ё, List.
(
" Setting List window display properties ( List ") Auto Wrap .
.
,
Searching for item values in the List window ( ) List.
Edit > Search List
( List ) Signal Search.
(
,
) .
• Search Type: Any Transition ( :
List. :
) ( ).
• Search Type: Rising Edge ( :
) ( ).
• Search Type: Falling Edge ( :
) ( ). 200
• Search Type: Search for Signal Value ( : ) , Value; , VHDL Verilog; . "Numbering conventions"( " " (CR-12). ,
: . see "Searching for binary signal values in the GUI( GUI) " (CR-21,)) , std_logic. • Search Type: Search for Expression ( : ) , . Builder )" Builder( GUI
Expression , "The GUI Expression . ,
. .
,
(
, , DO . "Expression syntax .
.
) " (CR-22))
• Search Options: Match Count ( :
) .
n-
n-
.
• Search Options: Ignore Glitches ( :
) VHDL
Search Results(
Verilog. .
)
Setting time markers in the List window ( Markers > Add Marker (
)
List)
. . , ,
. Edit> Delete Marker.
201
gj (
,
,
Goto)
Saving List window data to a file ( File > Write List ( :
View> Goto. .
)
List)
List
• , ns delta /a 0 +0 X 0 +1 0 2 +0 0
/b X 1 1
/cin U 0 0
/sum X X X
/cout U U U
• , @0 +0 /a X /b X /cin U /sum X /cout U @0 +1 /a 0 /b 1 /cin 0 • TSSI TSSI;
.
,
write tssi
(CR-327) 0 00000000000000010????????? 2 00000000000000010???????1? 3 00000000000000010??????010 4 00000000000000010000000010 100 00000001000000010000000010
. List,
write list (CR-323).
List window keyboard shortcuts ( List) ,
List,
: 202
< left arrow >
( )
< right arrow >
( )
< up arrow > < down arrow >
(
) (
) ( HP)
extends selection left/right
Windows UNIX
/
Find,
Process window(
ё
) ,
.
,
View > Active ,
.
Region,
, View > In .
HDL : •
,
, 203
. • < > , VHDL Verilog
ё .
• < > , VHDL . . "Ready",
. Process ,
:
Dataflow Signals Source Structure Variables
VHDL Verilog
The Process window menu bar(
Process) Process.
Process
New Window
notepad
Save List (CR-174) ModelSim Environment
Follow Context Selection ( ): Fix to Current Context(
; ): ,
Close
Process; 204
File > New > Window "The Main window menu bar"
Copy Process
Select All
Process
Unselect All
;
Find Status ( ,
,
),
Process,
:
,
Active
,
In Region
,
,
Sort
,
Initial Layout
Cascade Tile Horizontally Tile Vertically :
Layout Style
Default – Classic Cascade -
5.5 5.5
205
Horizontal Vertical Icon Children Icon All Deicon All The Button Adder ,
Customize
;
, Source
, ;
, ,
; ,
"View menu" the view (CR-261)
Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences,
PrefMain (layoutStyle).
Signals window(
)
Signals
.
HDL
(
). HDL
. Wave ,
, (
ё
Source, ,
, Wave. Source
). List
Wave
. . . HDL
,
,
. HDL
VHDL
Verilog HDL :
VHDL 206
,
(
),
Verilog ,
, ,
( ) ,
.
"Virtual signals" ("
")
VHDL (
) . Verilog
Verilog (
.(
,
.)
ModelSim ), ( ), . "Tree window hierarchical view"( " .
(
). ")
The Signals window menu bar(
Signals) Signals.
New Window
ё
Signals ,
Save List
notepad
(CR-174) ModelSim Environment
Close
Copy
,
ё Signals; "The Main window menu bar" File > New > Window
Signals 207
Signals
Select All
Signals
Unselect All Expand Selected Collapse Selected Expand All
,
ё
ё
Collapse All
;
Force Kind (Freeze/Drive/Deposit), Delay, . force (CR-154)
force (CR-154) noforce (CR-171) , ,
Noforce HDL
;
.
Clock ,
Value,
Cancel;
, . see"Defining clock
, signals"( "
") Signals;
Find Name ;
Value,
: the search (CR-210 )
.
Source,
Signal Declaration
,
Sort
,
Justify Values ,
Filter
(
, InOut
,
)
Wave
,
,
,
,
,
,
Wave List List Log WLF
;
Breakpoints
"
" 208
Initial Layout Cascade Tile Horizontally Tile Vertically : Default – Classic Cascade Horizontal Vertical -
Layout Style
5.5 5.5
Icon Children Icon All Deicon All The Button Adder ,
Customize
;
,
, ;
,
,
;
"View menu"
,
view (CR-
261) . ModelSim.
Layout Style, Layout Style ,
ё
Tools > Save Preferences,
PrefMain (layoutStyle).
Selecting HDL item types to view( )
HDL,
View > Filter , HDL
. .
209
Forcing signal and net values(
) ,
Edit > Force . ; ,
,
force ,
force,
Edit > NoF.
. force (CR-95).
.
:
Force • Signal Name . • Value ,
,
. ,
(
VHDL
Verilog,
): base#value -or- b|o|d|h’value 16#EE
h'EE,
• Kind: Freeze ( :
,
EE.
) (unforced)
Freeze( VHDL,
modelsim.ini;
.
)Drive Freeze ,
, noforce (CR-171). ё
Verilog .
-
ModelSim s. 210
• Kind : Drive , noforce (CR-171).
ё
VHDL.
• Kind : Deposit .
ё
, ,
noforce (CR-171).
• Delay For , . • Cancel After force (CR-154)
.
• OK force (CR-154) .
OK, , ,
,
,
OK. .
Adding HDL items to the Wave and List windows or a WLF file ( HDL Wave List WLF)
Add, Signals
Wave , (WLF
List,
).
, . WLF , Wave
List
, . WLF
211
Wave
. - view , ModelSim List.
, WLF
vsim (CR-296) ,
Add: • Selected Signals ( ),
Signals
• Signals in Region ,
Structure.
• Signals in Design .
Wave , add list (CR-48), add _ wave (CR-57),,
WLF VSIM ( log (CR-164)): List,
add list | add wave | log : add list | add wave | log * : add list | add wave | log -r /* (Wave
List)
, ModelSim
,
.
Finding HDL items in the Signals window ( ) Signals, : Down
HDL Name
Value
Up.
212
. ,
ё
Signals
(
,
) .
Setting signal breakpoints(
)
" Signal breakpoints ( , ,
)"
Signal.
, . , UNIX)
Windows;
,
(2Insert Breakpoint. "Creating and
, .
managing breakpoints( .
)"
Defining clock signals(
) ,
Edit > Clock ,
,
, .
, .
, ,
,
- std_logic, std_ulogic, , 1 0
, ,
:
,
verilog, ,
verilog,
1213
,
0-
.
, .
Source window(
)
Source
HDL
.
, Source
,
. ,
Structure File > Open (
Source) ,
security and -nodebug ( ,
Main .( " Source code
; –nodebug) " . .
:
• • •
-
, –
–
• •
Process ;
, -
,
. ,
Edit > read only.
The Source window menu bar (
Source) Source.
New
(VHDL, Verilog
)
Open Open Design Source Close File
,
Use Source
, ; ;
Source Directory
SourceDir modelsim.tcl
Save Save_As Print 214
Close
Source
,
,
read only
Edit.
: Undo, Cut, Copy, Paste, Select All, Unselect All
Clear highlights Comment Selected
, ,
Uncomment Selected Find ; Find Next
ё
, Find
Replace
,
Previous Coverage Miss Next Coverage Miss read only
Code Coverage, , Code Coverage, ,
Show line numbers Show coverage data
(
)
,
Code Coverage Show language templates Properties
; ,
,
,
Examine
HDL
;
examine (CR-148); Describe
HDL
;
describe (CR-133); Compile Breakpoints
HDL ,
,
-
, 215
" Creating ; and managing breakpoints (
)"
Options
Source;
Colorize Source Highlight Executable Lines Middle Mouse Button Paste Verilog Highlighting VHDL Highlighting Freeze File
,
/
,
, VerilogVHDLSource ( Source; )
Structure, Freeze View Process Auto-Indent Mode
Initial Layout Cascade Tile Horizontally Tile Vertically : Layout Style
Default – Classic Cascade Horizontal Vertical -
5.5 5.5
Icon Children Icon All Deicon All Customize
The Button Adder ,
; ,
,
, ; 216
,
; "View menu"
,
view (CR-261) Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences,
PrefMain (layoutStyle).
The Source window toolbar(
Source) Source
ModelSim. Source
Tools > Compile
Compile this file
vcom VSIM
vlog Compile HDL Source
:
vcom (CR-250)
vlog (CR-286) File > Open
Open Source File
HDL ,
Open File ( Source Source) Save Source File
File > Save
Source Print
File > Print
Print
Cut
Edit > Cut
. : " Mouse and keyboard shortcuts ( )"
Edit > Copy
. : " Mouse and keyboard shortcuts ( )"
Edit > Paste
. : " Mouse and keyboard shortcuts ( )"
Source Copy
Source Paste
Undo
Edit > Undo
217
Find
Edit > Find
(Windows) (UNIX)
Main: Simulate > Run > Restart
restart
.: restart (CR-202) , , , WLF Run Length
Main: Simulate > Simulation Options
run
.: run (CR-208) Run ё Continue Run
Main: Simulate ¾ Run
run
Run > Continue
run -continue
>
.: run (CR-208)
.: run (CR-208)
Run -All
Main: Simulate > Run > Run -All
run -all
, .: run (CR-208) ; tab"
. "Assertions
Main: Simulate > Break
Break
: Simulate > Run > Step
Step
.:
step VSIM step (CR-220)
HDL Step Over
:
step -over 218
HDL
Simulate > Run > Step -Over
VSIM step (CR-220)
.:
,
ё
View > Show Language Templates
Show Language Templates
Setting file-line breakpoints( "
-
-
) "
Source,
.
Source, . ,
-
;
,
. , Remove Breakpoint.
, :
• Disable/Enable breakpoint . • Edit breakpoint ,
;
" Adding a Breakpoint( • Edit all breakpoints "
)"
.
".
Checking HDL item values and descriptions ( HDL
) HDL
,
Source: •
, Source
Tools > Examine
•
Tools > Description
, . examine (CR-148), -
describe (CR-133)
.
219
Finding and replacing in the Source window( Source) Find Source. Find.
Edit > Find Edit > Find,
Edit > Replace , Replace
. Find.
, Replace.
-
.
Regular expression .
Setting tab stops in the Source window and Main window Transcript ( Source Main) Source
Main , Tcl
Edit Preferences PrefSource(tabs) . GUI. Tools > Edit Preferences (Main window).
1 2
By Name.. Source,
3 4
"tabs".
Change Value.
5
,
,
"n"
,
n ,
, .
:
( .
)
c, cm m, mm i, in p u char, chars 220
, . : • •
5, 10c,
5
. 10
•
.
,
: 21 49 77 105 133 161 189 217 245 273 301 329 357 385 413 441 469 : {21 49});
ё
(
, " 21 49 "
GUI.
221
Structure window( :
)
ModelSim
5.5
,
Structure Structure , Structure
, Main. Structure
. Main).
View > Structure (
. . ,
, –nodebug)".
HDL .( . see "Source code security and -nodebug(
HDL HDL
VHDL
Verilog Structure. VHDL ( )
, ,
, Verilog (
) ,
, ,
,
(
)
, . "Virtual Objects (User-defined buses, and more)( ( , ) ") .
, , "+"
"-".
"+" -
.
.
Structure , Structure.
"-"
.
, 222
Structure Structure
,
:
• , . • ,
.
• ,
;
Source
(
Verilog).
Structure, Signals .
, ,
, ,
,
, ,
. Structure, In Region Variables.
Process ;
Process
The Structure window menu bar(
) Structure. Structure
Main.
New window Save List Environment
Close
Copy Expand Selected Collapse Selected Expand All Collapse All Find
ё
Structure notepad
(CR-174) ModelSim 1) ;2) ;3)
,
,
Structure
Structure
ё
ё
, ;
. 223
"Finding items in the Structure window"( " ")
Sort
,
,
Initial Layout Cascade Tile Horizontally Tile Vertically : Default – Classic Cascade Horizontal Vertical -
Layout Style
Icon Children Icon All Deicon All Customize
5.5 5.5
The Button Adder , ; ,
,
, ;
,
;
"View menu" the view (CR-261)
,
Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences, PrefMain (layoutStyle).
Structure window context menu( Structure
, , UNIX-3-
(Windows-2-
Structure) , )
-
Structure
. Structure
.
• View Source Source. . • Add Dataflow, List
Wave
• Sort HDL
Structure
(
), • Find he Find .
"Finding items in the Structure window"
. 224
• Expand Selected HDL
.
• Collapse Selected HDL
.
• Expand All HDL
.
• Collapse All HDL
.
• Save List HDL
Structure
.
• Save Dataset WLF e. • End Simulation .
Structure • Close
.
Finding items in the Structure window( ) Find Edit > Find (
.
Structure Structure)
Find.
Find . , ,
/ . , .
Auto
Wrap, .
Variables window( Variables HDL
) . .
( )
. .( . see "Source code security and -nodebug"( "
, -nodebug " ).
HDL 225
HDL VHDL Verilog Variables. VHDL , generics(
),
Verilog
VHDL (
) .
Verilog. (Verilog , .) ModelSim, ( ) ( ё ). . See "Tree window hierarchical view"( " ") . VHDL Verilog, .
,
, ,
Edit >Change (
,
) .
,
" , VHDL
(
" VHDL Verilog. . ). . Process,
,
Variables.
The Variables window menu bar(
) Variables.
New window Save List Environment
ё
Variables ,
notepad
(CR-174) ModelSim Follow Context Selection ( ): Fix to Context(
Process; ):
, 226
Variables
Close
Variables
Copy
Variables
Select All
Variables
Unselect All Expand Selected Collapse Selected Expand All
,
ё ё
Collapse All
HDL
Change
;
Find Name ;
Value,
:
,
Sort
,
Justify Values
Wave/List/Log
Selected Variables Wave, List,
Variables in Region WLF
Initial Layout Cascade Tile Horizontally Tile Vertically Icon Children : Layout Style
Default – Classic Cascade -
5.5 5.5
227
Horizontal Vertical Icon All Deicon All The Button Adder ,
Customize
; ,
,
, ;
,
;
"View menu" (CR-261)
,
the view
Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences, PrefMain (layoutStyle).
Finding HDL items in the Variables window( Variables )
Ч
Variables, Value
Name : Down
.К , ,
HDL
Up.
Variables
,
ё
Wave window(
)
, .
, ,
,
HDL
.
.
.
, .
Pathname pane(
) .
, ё
, . . 228
.
( . Splitting Wave window panes(
Wave)).
Values pane(
) . ,
,
, ,
, ,
ASCII
. ,
( options"( "
)(
Simulate > Simulation Options . see "Setting default simulation " )).
Signals,
, , (
)
.
Waveform pane(
) , .
20
.
, ,
,
.
,
, .
. , .
. Wave Window Properties (
Cursor panes(
. ." Setting Wave window display properties " )
) 229
. . . "Using time cursors in the Wave indow(
.
20
Wave )"
HDL items you can view( HDL
)
VHDL (
)
Verilog (
) ,
,
(
)
, , "Virtual Objects , (User-defined buses, and more) ( ( .
(
,
. .) "
) ;
:
, generics,
.
11-
Waveform
-
List
Wave . , ,
, ,
.
230
, ,
.
,
, . , .
Format menu. , , (
, . "Adding items with a Wave window format file )".
Adding HDL items in the Wave window( Wave) ( Wave" ).
HDL
Wave . "Setting Wave window display properties( Wave
.
Wave Structure, Wave.
Variables.
List, Process, Signals, Source, ,
,
,
.
HDL
,
(
): VSIM>add wave : VSIM>add wave * : VSIM>add wave -r /* Wave Wave .
: 231
1
,
Wave
2 the Wave window(
, ,
.
. "Editing and formatting HDL items in HDL Wave )",
. 3
,
File > Save Format ( Wave). Wave,
,
DO
: •
DO (CR-137)
,
:
VSIM>do •
File > Load Format (
Wave)
Wave
:
-
,
Wave,
; .
Edit > Select All Edit > Delete, delete (CR-132 )
wave.
The Wave window menu bar( .
)
-
, Wave
New Window
ё
Wave
Open Dataset WLF
Save Dataset Wave .DO
Save Format .DO (
);
Wave,
,
,
.DO (.DO) Save Format
Load Format
Wave, , ;
Page Setup , Print (Windows only)
,
, Wave
,
: ,
, ;
: All signals Current View Selected 232
Print Postscript Postscript; All signals Current View -
:
Selected Close
Wave; "The Main window menu bar(
View > New )"
Wave;
Cut see "Editing and formatting HDL items in the Wave window( HDL
. )"
Copy Paste Delete Edit Cursor Delete Cursor Delete Window Pane Select All Unselect All
,
,
Find Search ;
, . "Searching for item
values in the Wave window"
Zoom
: Full, In, Out, Last, ё
Range ), ,
Mouse Mode Source,
Signal Declaration Cursors Bookmarks
, , ;
Sort ; Justify Values
233
Refresh Display
Wave,
Signal Properties
,
, ,
,
,
( Format,
)
Divider Group
-
,
, (
) ." Signal
;
Breakpoint breakpoints(
)"
Bookmark ; bookmarks(
." Saving zoom range and scroll position with )"
Cursor Window Pane
, waveset
Radix -
Format Literal, Logic, Event,Analog Color Height
Waveform Compare Breakpoints
Bookmarks
;
.
, , Creating and managing breakpoints ( )" , , ё zoom range and scroll position with bookmarks (
;
;
."
. " Saving )" WLF
Dataset Snapshot Combine Signals ,
Window Preferences
,
,
,
,
234
Start Comparison Comparison Wizard Run Comparison End Comparison :
Add Compare by Signal Compare by Region Clocks-
,
Options :
Differences Clear Show-
Wave
Save-
,
Write Report:
Rules Show-
,
SaveReload
Initial Layout Cascade Tile Horizontally Tile Vertically : Layout Style
Default – Classic Cascade Horizontal Vertical -
5.5 5.5
Icon Children Icon All Deicon All 235
The Button Adder ,
Customize
;
,
,
,
,
; ;
"View menu"
,
view (CR-
200) Layout Style,
. ModelSim.
Layout Style ,
ё
Tools > Save Preferences,
PrefMain (layoutStyle).
The Wave window toolbar(
Wave)
Wave
ModelSim
.
Wave
File > Load Format
Load Wave Format (DO)
do wave.do .
Wave ,
Save Format Save Wave Format Wave DO (
-
do (CR-137)
File > Save Format
)
Print Waveform
File > Print
Wave ,
Cut
Edit > Cut > Cut
Wave
Copy
Edit > Copy > Copy
Paste
Edit > Paste > Paste
Add Cursor
Insert > Cursor wave
236
Edit > Delete Cursor
Delete Cursor
Find Previous Transition
Find Next Transition
wave
Edit > Search (Search Reverse)
: Shift + Tab left . left (CR-162)
Edit > Search (Search Forward)
: Tab right . right (CR-206)
View > Mouse Mode > Select Mode
Select Mode
View > Mouse Mode > Zoom Mode
Zoom Mode
View > Zoom > Zoom In
Zoom in 2x 2
:iI +
View > Zoom > Zoom Out -
Zoom out 2x 2
View > Zoom > Zoom Full
Zoom Full
> Zoom In :oO
> Zoom Out :f F
> Zoom Full .wave.tree interrupt
Stop Wave Drawing
, Wave :
Restart ,
Simulate > Run > Restart
,
restart .: restart (CR-202)
,
WLF :
Run ,
Simulate >
run VSIM 237
Run > Run
.: run (CR-208)
: Simulate > Run > Continue
Continue Run
run continue VSIM .: run (CR-208)
:
Run -All ,
run - all
Simulate > Run > Run -All
ё
VSIM .: run (CR-208), "Assertions tab ( )"
Break
Using Dividers(
) ,
,
Insert > Divider ( , .
,
).
,
.
"New Divider." , "Gold." . . , (
, ),
,
.
To move a divider— To change a divider’s name and size — (UNIX)
(Windows) Divider Properties ,
To delete a divider—
Delete
Splitting Wave window panes( ё
Wave)
,
, Insert > Window Pane (
Wave . Wave) .( .)
238
,
, " sim ",
–
"gold." Гл
7 - WLF
лы (
ры д
ы )
, virtuals.
Combining items in the Wave window ( Wave) Wave . -
. , Wave Tools >Combine Signals. Combine Selected Signals : • Name
• Order of Indexes . 0.
Ascending, Descending , .
,
• Remove selected signals after combining , . , Bus1. Wave . ё , .
Wave
Wave , , .
)
Wave . "Virtual Objects (User-defined buses, and more)( , ) )" Wave.
(
239
Editing and formatting HDL items in the Wave window ( HDL HDL, .(
. Wave" ).
Wave)
Wave, , "Setting Wave window display properties(
:
Edit click+drag,
. Wave.
,
,
,
: • Control+click,
:
•
: ,
:
,
View > Signal Properties ( Wave Signal Properties
Wave). : View, Format,
Compare. :
View • Display Name (
)
.
• Radix ( ). , ,
, radix ,
Symbolic.
• Wave Color .
,
. • Name Color .
,
. (
Format ):
240
• Format: Literal ,
(
).
-
,
. • Format: Logic U, X, 0, 1, Z, W, L, H, or -. • Format: Event . • Format: Analog [Step | Interpolated | Backstep] .
. (Backstep) backstep
.
.
,
ё
-
. .
(
1)
(
1)
. Analog: VHDL: - std
,
,
,
Verilog:
• Height (
)
. .
Compare "Adding signals, regions and/or clocks" ). Options (
Add Signal
Setting Wave window display properties ( Wave) Wave ,
Tools > Window 241
Preferences ( Preferences (
Wave) . Main).
,
Tools > Save
:
Window Preferences • Display Signal Path , ( , sim:/top/clk)
(
, sim:clk). .
, - Full Path( ). SignalNameWidth. "Preference variables located in Tcl files"
,
Tcl
.
• Justify Value , . • Snap Distance , (0
).
• Row Margin . • Child Row Margin . • Waveform Popup \
,
,
• Dataset Prefix , Always Show Dataset Prefixes(
. )
("sim"). Show Dataset Prefixes if 2 or more( )
, ,
2
2
.
" sim " -
.
Never Show No Dataset Prefixes( ) .
,
.
Sorting a group of HDL items(
HDL)
View > Sort,
Setting signal breakpoints( "Signal breakpoints (
) )"
Wave. 242
,
,
,
. ,
(2-
Windows; 3-
, UNIX),
Insert Breakpoint. " Creating and
. managing breakpoints ( .
")
Finding items by name or value in the Wave window( Wave) Edit > Find (
Find Wave)
Wave. Find.
Name Value, Find .
ё
Wave. Auto Wrap ( ) . .
Searching for item values in the Wave window ( Wave) Wave, Wave Signal Search.
Edit > Search ,
243
:
Wave Signal Search (
)
,
. : • Search Type: Any Transition ( : ) ( ). • Search Type: Rising Edge(
) ( ).
• Search Type: Falling Edge(
) ( ).
• Search Type: Search for Signal Value( , Value; , VHDL Verilog conventions ( ) " (CR-12).
) . "Numbering
;
,
: . "Searching for binary signal values in the GUI(" GUI) " (CR-21) , std_logic. • Search Type: Search for Expression( , . "The GUI Expression Builder(
) Expression Builder, GUI)"
.
, Wave. DO syntax (
,
.
,
• Search Options: Match Count( n-
. )
n-
; Match Count ,
Search Results(
.
)" (CR-22)
, . "Expression
)
. .
Using time cursors in the Wave window( Wave)
244
Wave .
,
,
.
, Add Cursor, ; , ).
Insert > Cursor ( . Delete Cursor,
(
). Edit> Delete Cursor
Add Cursor
Delete Cursor
Finding a cursor(
) . View > Cursors. .
, ,
Making cursor measurements(
) ,
.
, . ModelSim
, . ,
ё
, .
, . .
-
, 10 Window Preferences(
. Tools > Window Preferences). ,
.
Find Previous Transition
Find Next Transition
:
245
Zooming - changing the waveform display range( ) . ,
,
,
,
. Zoom
View
, .
:
Zoom • Zoom Full(
) ,
0 .
• Zoom In(
) , .
• Zoom Out(
) , .
• Zoom Last(
) , .
• Zoom Range (
) , ,
.
, Zoom in 2x
: Zoom out 2x
Zoom Full
Zoom Mode , zoom ; 0
246
View > Mouse Mode > ZoomMode ( 3 : • Down-Right: Zoom Area (In)( • Up-Right: Zoom Out( : • Up-Left: Zoom Fit( : )
, Wave).
zoom , ()
– ё
:
) )
ё
, .
10
,
. ,
,
. " Wave window keyboard shortcuts(
Wave )" Wave .
Saving zoom range and scroll position with bookmarks ( ) .
. ,
Bookmark. Wave window format file( , ё . ,
Wave (
" Adding items with a Wave)")
. . bookmark add wave (CR-64 ) Insert > Bookmark ( Wave).
Bookmark Properties
.
.
• Bookmark Name , ё View > Bookmarksmarks.
.
• Zoom Range , . • Top Index , 15, Wave
. ,
15-
, .
• Save zoom range with bookmark . 247
• Save scroll location with bookmark . ,
View > Bookmarks, . Tools > Bookmarks ( Wave).
Wave ,
Bookmark Selection • Add (
. )
• Modify
• Delete (
• Goto (
)
) Wave,
Wave window mouse and keyboard shortcuts (
Wave)
,
Wave.
a
< control - left-button - drag down and right> < control - left-button - drag up and right> < control - left-button - drag up and left> < middle-button - drag>
zoom fit( ё ) moves closest cursor ( )
< control - left-button - click on a scroll arrow > (
) ( )
< middle mouse-button - click in scroll bar trough> (UNIX)
a. Mode > Zoom Mode,
,
View > Mouse .
248
i I or +
( )
o O or -
( )
f or F
( )
l or L
- zoom last( )
r or R
( )
< up arrow >/
, /
/
;
, \ ,
, ,
(
(
Windows
UNIX
)
-
)
-
; ( ) ,
,
,
,
Printing and saving waveforms( ) a .eps
.eps
UNIX
File > Print Postscript ( Wave) Wave UNIX, .(
write wave (CR-329)). ,
.
249
:
Write Postscript
•
Print UNIX,
UNIX
.
• File name Postscript (.eps), .eps
; .
• All signals . • Current View . • Selected
• Full Range . • Current view . • Custom .
. "Printer Page Setup(
)" Windows
250
File > Print ( Wave,
Wave)
(
). ,
.
• Name .
• Status . • Type . ,
,
"Print to file".
• Where . • Comment . • Print to file(
) ,
Postscript
. , (.ps),
. File > Print Postscript.
.
Postscript .prn (.eps)
251
• All signals . • Current View . • Selected .
• Full Range . • Current view . • Custom .
. "Printer Page Setup(
Setup
)"
Write Postscript ( File > Page setup).
Print , ,
• ; . • );
Margin
Scale
Page.
• Auto Adjust ,
, .
• . • . • ,
-
.
252
• –
Fixed ; , ;
Fit to,
,
–
. • , Portrait
Landscape.
Compiling with the graphic interface ( ) VHDL
Verilog ,
)". Compile (
Compile HDL Source Files, . " Getting started with projects ( Compile HDL Source Files, Compile >
Main). Compile HDL Source Files
• • •
:
, VHDL
Verilog ,
Default Options, default compile options( . Compiler Options Compile > Compile Options ( ) Project.
. "Setting )" ,
Compile Properties
Edit Source, . "Source window(
Compile.
)" .
Locating source errors during compilation( ) , .
, Source
.
Setting default compile options( ) 253
),
Compile > Compile Options ( Compiler Options . Compiler Options .
,
,
VHDL
VHDL •
: 1993
VHDL93 .
, VHDL93
. 1987vcom (CR-250).
-93 modelsim.ini,
. • , ModelSim.
,
.
, . , –nodebug(
, vcom (CR-250). -NoDebug )" NoDebug modelsim.ini ,
. . "Source code security and .
-nodebug
. • , EDA;
,
,
vcom (CR-250).
–explicit modelsim.ini,
Explicit
ё .
,
,
. std_logic_1164.
=, VHDL
“
”
=.
, 10.3) . ,
=, =, =
,
. (LRM
,
, use ,
,
:
ARITHMETIC.”=”(left, right) =,
. 254
• Main.
, Quiet
vcom (CR-250).
–quiet modelsim.ini,
. • . Show_source
,
vcom (CR-250).
-source modelsim.ini
,
.
: • ,
VHDL, ,
,
. Show_Warning1 .
,
modelsim.ini
•
(WAIT) , .
•
(
Show_Warning2 .
,
modelsim.ini
) ,
Show_Warning3 .
0
4.
,
modelsim.ini
•
(
5ns)
, .
Show_Warning4 .
modelsim.ini
,
• , Show_Warning5 modelsim.ini .
. ,
: • . (
)
;
,
. CheckSynthesis modelsim.ini .
•
,
Vital Vital.
modelsim.ini
,
,
NoVitalCheck . 255
: • StdLogic1164 ,
-
std_logic_1164. .
Std_logic_1164, Optimize_1164 modelsim.ini .
,
• Vital NoVital
Vital. modelsim.ini
,
. Verilog
• . vlog (CR-286).
hazards modelsim.ini
, Hazard
–
,
.
• , ModelSim. , . , and –nodebug(
.
, -nodebug vlog (CR-286). –nodebug " NoDebug modelsim.ini , .
. . " Source code security .
• Verilog
.
, vlog (CR-286).
.
,
, UpCase modelsim.ini
-u ,
. • Main. vlog (CR-286). modelsim.ini ,
,
-quiet Quiet .
• . -source Show_source ) modelsim.ini Verilog
,
vlog (CR-286). ,
.
: 256
• Verilog
, -y
,
. vlog (CR-286).
• .
. +libext + < suffix>
,
vlog (CR-286).
• Verilog ,
,
.
–v
vlog (CR-286).
• , +incdir + < directory>
,
‘include filename. vlog (CR-286).
• , : ‘define macro_name macro_text. , + [= < macro_text >] vlog (CR-286).
. +define
Simulating with the graphic interface( ) , Simulate,. ё . Simulate, Simulate >, Simulate ( Main). - Design, VHDL, Verilog, Libraries, SDF, Options . , ,
Library
Library
,
Load. ,
: ,
,
(
" Creating a design library
) ".
Design tab(
) :
Design • Simulate ( )
,
.
Verilog
VHDL :
-
( .
,
,
)
,
/
: [ < Library_name >.] 257
-
,
-
Add.
,
(
). • Simulator Resolution (-time []) (
- ns).
: 1fs, 10fs, 100fs 1ps, 10ps, 100ps 1ns, 10ns, 100ns 1us, 10us, 100us 1ms, 10ms, 100ms 1sec, 10sec, 100sec , "Simulator resolution limit ( )" • Optimize Verilog, " Compiling for faster performance ( )" .
VHDL tab(
VHDL)
:
VHDL Generics(
+opt.
)
Add
(
), ;
Generics. ,
Delete
Edit.
. Specify a Generic . • Generic Name (-g ) . 258
VHDL (
).
• Generic Value
(
)
(
). .
( )
.
• Override Instance - specific Values ( -
)(-G < Name=Value >) ,
.
, Override
. Generics.
VITAL
• Disable Timing Checks (
) (+notimingchecks) ,
•
VITAL.
VITAL 2.2b SDF (-vital2.2b) SDF VITAL 2.2b (
• Disable Glitch Generation (
– Vital2000).
)(-noglitch) VITAL.
TEXTIO • STD_INPUT (-std_input < , Browse • STD_OUTPUT (-std_output < , Browse
>) VHDL
textio STD_INPUT. .
>) VHDL textio STD_OUTPUT. .
259
Verilog tab (
Verilog) :
Verilog И
• Disable pulse error and warning messages (
) (+no_pulse_msg) .
• Rejection Limit(
) (+pulse_r / < percent>) .
• Error Limit(
) (+pulse_e / < percent >) .
Д • Enable Hazard Checking (
) (-hazards) Verilog.
• Disable Timing Checks in Specify Blocks ( )(+notimingchecks)
ё ($setup, $hold, ...)
ё
.
• Delay Selection(
) (+mindelays | +typdelays | +maxdelays) ,
min:typ:max. • User Defined Arguments ( “ +” , Verilog PLI mc_scan_plusargs. , ModelSim
) (+ < plusarg >) ,
"+" . 260
Libraries tab(
)
:
Libraries • Search Libraries (-L) ,
Verilog.
• Search Libraries First (-Lf) Search Libraries, ).
SDF tab(
‘ uselib(
SDF)
SDF(
)
SDF ё
Add ,
SDF
,
;
Region/File. ,
(
). .
Add SDF File • SDF
([] = ) SDF , .
.
• Apply to region ([] = ) ,
Browse,
SDF.
• Delay (-sdfmin | -sdftyp | -sdfmax) max), simulation(
SDF. SDF
(min, typ , "Specifying SDF files for
. )" .
SDF
261
• Disable SDF warnings SDF (-sdfnowarn) SDF. • Reduce SDF errors to warnings SDF SDF
(-sdfnoerror) ,
.
• Multi-Source Delay (-multisource_delay < sdf_option >) ,
. , .
(Module Input Port Delay-MIPD) SDF . .
Options tab(
, ,
)
:
Options • Enable source file coverage
(-coverage) .
(К
10 - Code Coverage
).
• Treat non-existent VHDL files ... ( (-absentisempty) VHDL , ModelSim
VHDL
)
, .
• Do not share file descriptors... ( (-nofileshare) ModelSim
) VHDL .
,
,
. • WLF File (-wlf ) (WLF)
..
- vsim.WLF. • Assert File (
modelsim.ini (
)(-assertfile ) , " Creating a transcript file (
. TranscriptFile )" ).
• Other options vsim (CR-296). 262
Setting default simulation options( ) Simulate > Simulation Options ( Simulation Options, . :
,
)
Simulation Options – . , modelsim.ini;
,
.
: • Default Radix
.
radix (CR-198), . ,
. (CR-154), examine (CR-148), change (CR-72)Signals, Variables, Dataflow, List,
DefaultRadix
modelsim.ini (force
) Wave.
• Suppress Warnings From Synopsys Packages, Synopsys std_arith. StdArithNoWarnings modelsim.ini , . From IEEE Numeric Std Packages, numeric_std and numeric_bit. NumericStdNoWarnings modelsim.ini , . • Default Run Run 263
RunLength modelsim.ini .
.
,
• Iteration Limit
, IterationLimit
. ,
modelsim.ini .
• Default Force Type . DefaultForceKind modelsim.ini .
,
:
Assertions • Break on Assertion
, BreakOnAssertion
.
,
modelsim.ini
.
• Ignore Assertions For ,
.
. IgnoreWarning, IgnoreNote modelsim.ini .
IgnoreFailure, IgnoreError, ,
,
,
(
).
:
, , . WLF :
WLF Files • WLF File Size Limit WLF WLF
(
)
. , WLFSizeLimit modelsim.ini .
, 0.
.
,
264
• WLF File Time Limit WLF WLF
(
)
.
, .
, WLFTimeLimit modelsim.ini .
. • Compress WLF data WLF WLF,
0. ,
. .
WLFCompress .
,
modelsim.ini
• Delete WLF file on exit WLF , WLF , WLFDeleteOnQuit modelsim.ini
. ,
• Design Hierarchy ,
WLF .
WLFSaveAllRegions .
,
modelsim.ini
Creating and managing breakpoints( ) ModelSim
,
(
,
)
-
.
GUI .
Signal breakpoints(
) (
,
) .
(
when (CR-312) , , .
ModelSim , ). Main
when (CR-312), VSIM >. К
,
. GUI 265
Signals , —UNIX),
3-
(2Insert Breakpoint
Wave. - Windows, .
Breakpoints. Breakpoints .
File-line breakpoints(
-
)
-
, .
,
.
bp (CR-68), VSIM>.
-
К
.
Source.
GUI ,
ё
Source, . -
;
,
. , Breakpoint.
, -
Remove Breakpoints.
Breakpoints dialog(
)
Breakpoints File-line breakpoints. Tools > Breakpoints Wave, .
Signal breakpoints Main,Signals, Source,
:
Breakpoints • Breakpoints
. GUI,
,
.
, • Add
ё
’X‘ .
-
. • Modify . • Disable/Enable . 266
• Delete . • Label .
• Condition . • Command , Д ё Add Add Breakpoint.
,
Next. , .
,
,
. :
Signals Breakpoints • Breakpoint Label
. • Breakpoint Condition ( ), . • Breakpoint Commands ( ), ModelSim Tcl run (CR-208)
(
),
when (CR-312) . ,
. ,
-
.
File Breakpoints • File
• Line . . • Instance Name , . 267
• Breakpoint Condition , • Breakpoint Commands ( ), ModelSim run (CR-208)
.
,
.
Tcl
,
-
.
Miscellaneous tools and add-ons( ) ModelSim.
.
• GUI Edit > Search > Search for Expression > Builder ( Wave List "GUI_expression_format(
Wave)
. GUI)" (CR-18).
• View > Show language templates ( VHDL • Window > Customize (
List
Source) Verilog
)
. • Tools > Macro Helper ( , UNIX ( Linux). • Tcl Tools > Tcl Debugger (
Main) .
Main) Tcl
• Debug Detective ™ Debug Detective -
, ,
(IBD ™),
,
. , ,
, ,
-
-
. 268
ModelSim. Debug Detective, ModelSim ,
. Start Menu , www.mentor.com/hdldesigner/ debug/detective .
Debug Detective, .
The GUI Expression Builder ( GUI) GUI(GUI Expression Builder) Wave List Signal Search, ). "GUI_EXPRESSION_FORMAT" (CR-18).
List trigger properties( ,
: •
Edit > Search (
List
Wave)
•
Search for Expression
•
Builder
EXPRESSION BUILDER , GUI . , , , Wave List Insert Reference Signal Expression Builder. , . Expression Builder "Expression syntax( )" (CR-22). ,
Signal
ё
==.
&&
Insert Selected
AND Wave
’ rising.
ё
Wave,
. ё
Insert Selected Signal . 269
. "Expression syntax(
( )" (CR-22)),
.
"Configuring a List trigger with Expression Builder( List )" .
Language templates(
)
ModelSim
Verilog (wizards) , ,
, :
, ,
VHDL. , . .
,
HDL
.
" VHDL
.
" Verilog, ,
HDL. , File > New ( Source) View > Show language templates . .
,
HDL .
, ,
,
, Verilog
VHDL
Source,
. ,
. ,
. HDL
, ,
.
. .
,
, "
".
,
.
. ё .
,
(
, "block_label" ,
)
. , .
,
"block_declarations" , .
" DELETE ". HDL,
.
270
(
) .
The Button Adder (
)
ё
Button Adder
ё ModelSim.
,
,
, , ( "Making the button persistent( Button Adder ModelSim: Window > Customize
)"
).
: •
, .
•
-
• Run
Step
, ModelSim. Wave.
,
: • Toolbar
.
• Footer(
)
. /
: • Right
/
• Left
.
/
• Top
.
/
.
• Bottom .
/
Button Adder, .
, .
1
,
:
Button Adder.
271
Tcl modelsim.tcl
2 modelsim.tcl
, MODELSIM_TCL
modelsim.tcl
3 Tcl user_hook http://www.model.com/resources/pref_variables/frameset.htm Tcl . .
. .
.
,
Wave, Wave.
: _add_menu wave controls right SystemMenu SystemWindowFrame AddWaves {add wave *}
Tcl PrefWave (user_hook). :
modelsim.tcl modelsim.tcl
proc AddWaves winname { _add_menu wave controls right SystemMenu SystemWindowFrame AddWaves {add wave *} } lappend PrefWave(user_hook) AddWaves
,
ModelSim "AddWaves" ,
Wave, "add wave *".
The Macro Helper ( ) UNIX ( Macro Helper
Linux).
,
, . play (CR-181) .
, Macro Helper ,
( ,
,
, GUI ModelSim , ). Macro Helper,
run (CR-208) .
Tools > Macro Helper (
)
. Macro Helper
• Record a macro , Record. Pause
Stop .
• Play a macro 272
Macro Helper ,
Play.
Macro Helper
notepad (CR-174).
Record/Stop
,
Insert Pause
.5 ,
Play
; ;
Macro Helper,
.
macro_option (CR-168 )
, .
The Tcl Debugger ( Tcl
)
Gregor Schmid . ,
TDebug , ,
; .
Tools > Tcl Debugger ( ModelSim TDebug
)
.
,
,
. TDebug
Help > Technotes > tdebug. README
,
TDebug.
Tdebug ‘td_eval( )’
Tcl/Tk, . . TDebug
, ,
, ,
,
, ,
. .
. . . Tcl’
,
. 273
. .
TDebug. , TDebug . , , vsim.op _.
Tools> Tcl Debugger (
)
.
. ,
ё
ё . ,
ё . ,
ё
, . ,
(Exit) TDebug. vsim.op _, .
TDebug
Popup Chooser,
(Rescan) ,
Popup ModelSim,
.
274
,
(Proc), (Result) (Variables)
, ,
Eval .
, , ) (
,
. (< -1 >, Selection >Restore Proc
, Selection > Prepare Proc ^P ^R). ‘Prepare’( , (
)
‘Restore’( .
,
), )
, ,
.
,
. ! ‘switch (
‘bind (
)’
)’,
, , . ,
(
)’
‘waiting(
‘idle
)’ ,
.
:
,
Stop
,
slow/fast/nonstop ,
Next Slow
, ; ‘ ‘+’
,
’;
‘-’ ,
Fast Nonstop Break
ё ,
,
‘ wmwithdraw( , Debugger > Close.
)’. .
275
/
,
.
, .
ё
.
Eval
,
. ; .
.
, . , Variables (
ё
‘global td_priv ’ , , ).
TDebug, .tdebugrc . . TDebug README Help > Technotes > tdebug TDebug. TclPro Tools TclPro Scriptics . ё ,
, TclPro: 1
Scriptics.
ё
2.
TclPro,
3
ModelSim
,
TclPro Remote Debugging Tools > TclPro Debugger (
Main) 276
,
4 ,
,
TclPro
1.4
. .
ModelSim.
Graphic interface commands( ) , .
; . ModelSim ModelSim).
К
Command Reference(
batch_mode (CR-62)
1, 0;
,
ModelSim
configure (CR-110) List
List Wave
Wave
down (CR-138)
List , Wave
getactivecursortime (CR-157) getactivemarkertime (CR-158) left (CR-162)
List Wave
notepad (CR-174) play (CR-181)
; ASCII Linux) -
UNIX (
property list (CR-193)
HDL
property wave (CR194)
HDL
record (CR-199)
,
, record (CR-199) List
Wave UNIX (
Linux) -
right (CR-206)
Wave
search (CR-210)
ё
seetime (CR-214)
List
, (
transcribe (CR-226)
)
Wave, , 277
up (CR-229)
List ,
write preferences (CR324)
GUI Tcl
Add button (CR-45) Add_menu (CR-51) Add_menucb(CR-53)
ё
ё
Add_menuitem (CR54) Add_separator (CR-55) Add_submenu (CR-56)
ё
,
Change_menu_cmd (CR-73) Disable_menu (CR-136) Disable_menuitem (CR-136) Enable_menu (CR-145) Enable_menuitem (CR146)
-
ё ,
ё
,
;
ё ; , ModelSim
, ModelSim -
278
9 - Performance Analyzer (
Under(%)
)
In(%).
279
, ,
.
-
,
-
, .
,
ASIC
FPGA
.
Introducing Performance Analysis (
) ,
ё ,
ModelSim
.
. . ,
.
•
VITAL
•
,
ё
•
-
,
•
, . ,
VHDL
Verilog,
. 280
A Statistical Sampling Profiler ( ) . ,
,
. ,
,
,
, .
, ,
,
,
. ,
.
,
-nodebug
vsim,
.
,
Samples ,
.
Getting Started (
)
Performance Analyzer, , , run, ,
(
run ModelSim . Tools > Profile > Profile On ( Main). , run . ё Performance Analyzer , .
Performance Analyzer, run ModelSim,
Main).
Tools > Profile > Profile Off ,
. . ON, ,
,
Tools >Profile > Clear Profile Data (
run , . Main ).
281
Interpreting the data(
) , /
.
, 60 % ,
, X.
,
X
,
.
,
, Y,
X, 25 %
30 % 20 %
Z.
, . , ,
, 1%
.
, ,
.
Viewing Performance Analyzer Results ( ) Performance Analyzer
– , Tools > Profile > ) view_profile VSIM. , Tools > Profile > View ranked profile view_profile_ranked VSIM. , view_profile VSIM.
. View hierarchical profile (
Hierarchical Profile ,
, , /
’- ’,
. ’+‘,
.
.
, ,
. (store.vhd:43
retrieve.vhd:35)
.
282
. . .
, . ,
Return
. . ,
, 1% . hierCutoff
rankCutoff
. " Performance Analyzer preference variables ( )". . ,
Ranked and Hierarchical Profile . , . . . profile report (CR-191) .
Interpreting the Name Field( Name, Under(%) .
,
) ,
In(%)
, .
HDL VHDL C,
. Verilog.
PLI/VPI
FLI,
,
. vsim -
,
,
,
. . ,
.
, ,
, .
,
,
,
.
283
Interpreting the Under(%) and In(%) Fields( Under(%) In(%)) In(%) Under(%) , In(%)
Name.
Under(%)
,
. In(%)
,
VHDL. Under(%)
ё .
, ,
%
% , VHDL/Verilog
,
Source
. ,
, retrieve.vhd:35, .
,
Differences in the Ranked and Hierarchical Views (
)
. •
Name
,
,
.
•
%Parent . Name
,
. , , .
, ,
,
3
.
, ,
60 % ,
ё
.
,
.
, 3
,
VHDL . .
%Parent , .
, 284
,
. 10 % 80 % ,
, 10 %,
, , , 80 %
8 %. , ,
,
, ,
. ,
.
Reporting results (
)
save profile report (CR-191 ),
Performance
Analyzer. profile report [] [-hierarchical | -ranked] [-file] [-cutoff ]. , profile report -hierarchical -file hier.rpt -cutoff 4 ё
,
hier.rpt,
.
Performance Analyzer preference variables ( ) 285
Tcl , Hierarchical Profile . Tools > Edit Preferences >By Name > Profile ( Main). Apply, , Save modelsim.tcl. , , . http:// www.model.com/resources/pref_variables/frameset.htm . Profile
Ranked ,
Performance Analyzer commands( ) . .
ModelSim Command Reference
profile clear (CR-186) ,
run; ,
profile interval (CR187)
-
,
profile off (CR-188) profile on (CR-189)
ё
profile option (CR-190) profile report (CR-191)
,
,
286
10 - Code Coverage(
)
Source
overage_summary (
_
)
coverage_summary
, . ModelSim: •
ModelSim, (instrumented)
-
HDL
,
. • (
5 %).
•
, .
ModelSim
5.3
,
.
287
Enabling Code Coverage ( "Options tab" (CR-296).
) Enable Source File Coverage - coverage
Simulate,
vsim
, ModelSim (
). .
Source
coverage_summary .
, (
). : ,
-O0 (
),
.
.
The coverage_summary window (
_
)
overage_summary
. overage_summary, VSIM.
view_coverage
Tools > Source Coverage (
:
"Summary information" Misses
;
ё overage_summary Source) " . Excluded. , Source. coverage_summary
Excluded. " Coverage data in the Source window( , , , Source
Summary information(
Pathname
•
Lines
•
Hits
.
)
coverage_summary . •
Main)
, : . . ,
. •
Percentage –
. .
288
90 %,
( PrefCoverage(cutoff). , , ё
,
. , Lines, Hits, %).
( .
Misses tab(
) .
Misses overage_summary,
,
. . , ,
( ), ,
,
Exclude Selected Lines. Excluded ( " Coverage data in the Source window (
Excluded tab(
"X"
Source Source )" .334)).
)
Excluded .
, Source.
Misses Excluded
.
ё
-
, : : • Include Entire Selected Files . , . ,
Source.
• Revert To Initial Filter
• Clear Out Current Filter
• Load a New Filter
• Disable/Enable Filtering /
.
.
, . • Cancel . 289
The coverage_summary window menu bar( coverage_summary ) overage_summary
Open > Coverage > Merge Coverage Open > Coverage > Apply a Previous Coverage Open > Load a New Filter
: File, Coverage, and Report. .
. " Merging coverage report files ( )" -
. files (
" Exclusion filter
)"
Save > Line Coverage Save > Current Filter
, " Exclusion filter files
. (
)" coverage_summary
Close
Clear Current Coverage Revert To Initial Filter Clear out Current Filter Disable/Enable Filtering
/
. .
Save Summary Coverage Save Line Coverage
,
Save Excluded Lines
,
,
Save Zeroed Lines
Line Coverage, ,
Save Totals
, ,
Save As
ё
Coverage data in the Source window( Source ) 290
Source
, (
,
); "X"
,
.
, coverage_summary. View > Show coverage data ( Source). " " Coverage Miss Edit > Next Coverage Miss, , ) ( ).
,
ё .
.,
Edit > Previous - (
Excluding lines and files(
) ,
.
Source, ё
(
)
:
: • Exclude Coverage Line # . • Exclude Entire File . • Do Not Exclude Coverage Line # . • Do Not Exclude Entire File
Excluded
. Source,
, overage_summary.
Merging coverage report files( ) . > Coverage > Merge Coverage
Merge Coverage Reports
File > Open
coverage_summary .
:
• Coverage File Name to Read From
291
, . • Clear out accumulated coverage data , . • Keep coverage data for files not in the current design , . ё Source, .
,
, Open Source,
Exclusion filter files(
) , .
Source,
coverage_summary. File > Open > Load a New
File > Save > Current Filter ,
Filter.
Syntax(
)
[[ ...] [ ...]] | all ...
Arguments(
)
.
. ,
.
, ... .
.
" # - # ". , 32 - 35.
,
.
, ... ,
.
.
, all ,
.
,
.
Example(
)
control.vhd 72 - 76 84 93 292
testring.vhd all
Default filter file(
)
Tcl
PrefCoverage (pref_InitFilterFrom) ,
,
--coverage. " Code Coverage )"
"Exclude.cov". preference variables( .
Code Coverage preference variables( ) Tcl
, ,
By Name > Coverage ( , ,
Main). Save .
. Options > Edit Preferences > Apply, modelsim.tcl. http://www.model.com/resources/
pref_variables/frameset.htm .
Code Coverage commands (
)
,
Code Coverage –coverage vsim (CR-296).
.
; . .
ModelSim
.
coverage clear (CR-115)
,
coverage reload (CR-120) coverage report coverage report (CR-121)
, ,
coverage exclude clear (CR-116) coverage exclude disable (CR-117) coverage exclude enable (CR-118) coverage exclude load (CR-119)
293
11 - Waveform Comparison(
,
)
-
Wave List
294
Introduction(
)
Waveform Comparison ModelSim (.wlf
),
, .
Wave
List
Main. Waveform Comparison
•
:
,
,
•
,
•
,
•
,
• Wave. , Waveform Comparison ,
. , . - when compare add (CR-83).
,
ё
, ,
,
.
, Wave
List (
Shift- Tab
Main. " Wave window display " Wave . , , .
" Compare objects in the List window ". Tab
,
compare info (CR-
. 93).
295
Two modes of comparison(
)
Waveform Comparison .
:
,
(
(
-
) )
. Wave
List. , .
,
. -
. .
,
-
.
,
, . ,
. (
)
.
, . (
)
Wave.
Comparing hierarchical and flattened designs( ) , ,
, -
. Waveform Comparison ModelSim. •
, ,
, compare add (CR-83),
.
296
•
, compare add (CR-83)
,
, .
•
,
,
, " compare add (CR-83), .
-rebuild
",
.
– ,-
,
Waveform Comparison .
(
,
), Waveform Comparison
.
Graphic interface to Waveform Comparison( Waveform Comparison) Waveform Comparison Tools >Waveform Compare > Start Comparison.
Main
Opening dataset comparison(
Wave,
)
Start Comparison
Reference
Test.
Э
.wlf,
.
, , .
.
.wlf, , 297
,
, .
• Use Current Simulation , . . • Specify Dataset .wlf
,
. ,
, ,
ё
,
Browse. Browse
Select Dataset File, . Reference
Compare Dataset ( -
Test Compare
,
"OK" Main.
, " Adding signals, regions and/or clocks ( )" ), Wave List.
,
Adding signals, regions and/or clocks( ) , Main
, , Tools > Waveform Compare > Add Wave, ( ) .
,
,
-
,
298
ё Tools > Waveform Compare > Add > Compare by Signal Wave structure_browser,
. ё Options . "Comparison Method tab( )" .
ё
Tools > Waveform Compare > Add > Compare by Region Add Comparison by Region, .
Wave
Region Data • ,
.
• , . • All Types Selected Types (In, Out, InOut, Internal, Port). 299
• ,
.
, "When". •
. , Clocks, . Clocks Comparison Clocks. ,
ё
Add, Add Clocks, , ,
,
.
Expression Builder , " " 1
when, . •
, .
. -
. .
, .
• GUI )",
When " The GUI Expression Builder( when , .
"
Setting compare options( Tools > Waveform Compare > Options Main Comparison Options. General Options Comparison Method ( " Comparison Method tab ( )" ).
"
1
) Wave,
• General Options
300
Comparison Limit Count –– -
. ,
VHDL Matching –– X
VHDL
Z VHDL. ,
Verilog Matching –– X
Verilog
Z Verilog.
Verilog
.
Save as Default — . Reset to Default — . Automatically add comparisons to the wave window?— Wave.
Wave window display (
Wave)
Wave
. ё .
. /\refSignalNametestSignalName\. , . , . . .
301
, ,
. Wave Window Properties
. . "Setting Wave window display properties (
( Wave )" ).
Wave
"
"
"
"
, "
.
" -
"
. " .
Compare . • Start Comparison Compare Dataset . • Comparison Wizard , . • Run Comparison , ,
, . Main compare run (CR-101):
compare_info.txt. • End Comparison
. • Add Compare by Signal —
structure_browser .
Compare by Region —
Add Comparison by Region . . 302
Clocks —
Comparison Clocks .
• Options e Comparison Options , . • Differences Clear —
Wave .
compare reset (CR-100) .
Show — Main. Save —
compare info (CR-93). Specify Differences File
, "compare.dif". Write Report— .
ModelSim. ё
,
• Rules Show — .
compare list (CR-95). Specify Rule File
Save — ,
. "compare.rul."
• Reload Reload and Redisplay Compare Differences .
Printing compare differences(
)
, Wave " Printing and saving waveforms ( .
Postscript. )"
Compare objects in the List window(
List) List.
. (
). .
: Diff Info, Annotate Diff,
Ignore/Noignore
. ,
, . 303
Waveform Comparison preference variables ( Waveform Comparison) Tcl . , Main). -Save
(
,
Tools > Edit Preferences > By Name > Compare Apply, modelsim.tcl. ,
, ,
, http://www.model.com/resources/
. pref_variables/frameset.htm
Waveform Comparison commands ( Waveform Comparison) . .
К
.
ModelSim
compare add (CR-83) ,
compare annotate (CR-86)
;
compare clock (CR87)
,
-
-delete,
compare configure (CR-89)
,
ompare continue (CR-90)
compare delete (CR91)
compare end (CR-92) , ;
compare info (CR-93) -write
compare add
compare list (CR-95) compare options (CR-96)
Tcl; , ,
compare reload (CR-
,
99)
,
compare reset (CR100)
start ,
compare run (CR101)
compare
; ,
compare savediffs (CR-102)
compare saverules
(
"
") 304
(CR-103)
,
, ; ,
compare see (CR-104) wave, compare start (CR106)
compare stop (CR108) compare update (CR-109)
compare stop,
.wlf
12 - Signal Spy(
)
init_signal_driver init_signal_spy signal_force signal_release $init_signal_driver $init_signal_spy $signal_force $signal_release Signal Spy TM ,
,
. VHDL
.
305
Introduction(
)
Verilog .
,
testbench. Verilog testbench Verilog , ,
.
VHDL VHDL. VHDL , .
,
,
, .
Signal Spy
. ( VHDL
VHDL modelsim_lib. ,
),
, .
,
" Util package (
)" ,
VHDL
:
library modelsim_lib; use modelsim_lib.util.all; Verilog
"
".
VHDL
Verilog.
Designed for testbenches( Signal Spy
testbenches) . ModelSim, Signal Spy
testbenches,
HDL
Signal Spy .
, .
init_signal_driver 306
init_signal_driver () ( src_object) dest_object).
VHDL VHDL VHDL (
Verilog Verilog (
, testbench).
init_signal_driver
, HDL. , init_signal_driver
Call only once(
, .
)
init_signal_driver .
,
init_signal_driver init_signal_driver,
.
. ,
,
VHDL.
VHDL
init_signal_driver ,
. VHDL init_signal_driver .
Syntax(
wait. .
)
init_signal_driver(src_object, dest_object, delay, delay_type, verbose)
Returns(
)
Arguments(
src_object
)
string
.
( )
VHDL
Verilog.
, (
dest_object
string
,"/"
. VHDL
"."). "/" . ( )
".".
Verilog.
,
(
,"/" "/"
"."). ".".
. delay
time
.
, src_object. . 307
, delay_type
del_mode
.
, mti_inertial mti_inertial. -0 1.
. mti_transport. verbose
integer
. ,
,
src_object - 0,
Related procedures(
dest_object. .
)
init_signal_spy , signal_force , signal_release
Limitations(
)
•
Verilog,
delay_type. ,
mti_transport, mti_inertial. •
, ;
.
•
HDL.
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 -sdftyp [ =] < filename> -sdfmax [ =] < filename> SDF . , -sdfmax, SDF .
, -sdftyp, ,
Instance specification ( SDF
)
,
,
, - ASIC
.
, -sdfmin,
SDF
.
FPGA
, SDF
myasic.SDF
U1
,
testbench :
vsim -sdfmax /testbench/u1=myasic.sdf testbench ,
.Э
SDF
–
, . , .
, ,
SDF
SDF .
,
vsim -sdfmax /system/u1=asic1.sdf -sdfmax /system/u2=asic2.sdf system
SDF specification with the GUI( SDF
GUI) ,
Simulate
SDF
SDF.
321
, , Simulate > Simulate ( ). SDF , "The $sdf_annotate system task( $sdf_annotate )" .
Errors and warnings( ,
Verilog, $sdf_annotate. .
)
SDF , -sdfnoerror vsim (CR-296) , ,
. SDF
,
.
, -sdfnowarn
(
vsim
+nosdfwarn.
). , . " Troubleshooting(
SDF Simulate Disable SDF warnings (-sdfnowarn, +nosdfwarn) Reduce SDF errors to warnings (-sdfnoerror), . )" , .
VHDL VITAL SDF VHDL SDF 1076.4 VITAL ASIC SDF . ,
VITAL. ,
,
, VITAL SDF . , , . VITAL, . " Obtaining the VITAL specification and source code VITAL )" .
(
SDF to VHDL generic matching( SDF
,
VHDL)
SDF . VHDL)
(
.
SDF
VITAL. SDF
.
-
, .
SDF
-
:
SDF
VHDL
( IOPATH y (3))
tpd_a_y
( IOPATH (posedge clk) q (1) (2))
tpd_clk_q_posedge
322
(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(
) ,
,
. , ** Error (vsim-SDF-3240) myasic.sdf(18): Instance ’/testbench/dut/u1’ does not have a generic named ’tpd_a_y’
,
,
VITAL. VITAL.
,
SDF .
VHDL, . VITAL
,
VITAL VITAL ,
.
: •
VITAL.
• SDF
.
, ,
SDF
,
.
•
SDF
VITAL 2.2b. ,
. vsim (CR-296)
-vital2.2b:
vsim -vital2.2b -sdfmax /testbench/u1=myasic.sdf testbench . "Troubleshooting(
)".
Verilog SDF Verilog
, ,
$sdf_annotate ( Verilog). , , 323
. Verilog.
$sdf_annotate ,
.
The $sdf_annotate system task(
$sdf_annotate)
$sdf_annotate:
$sdf_annotate ( [" "], [], [" "], [" "],[ " < Mtm_spec > "], [" < scale_factor > "], [" < scale_type > "]);
" " ,
SDF
.
.
,
. $ sdf_annotate.
, " " , , " " ,
" " , " ", "
(
.
.
.
. logfile. .
.
. ", " - "tool_control".
,
. "tool_control". "tool_control" +mindelays, +typdelays, ",
+maxdelays
+typdelays).
" " , " : : ". , . " " , . < mtm _spec> , ,
, min/typ/max SDF . ё - "from_min", "from_minimum", "from_typ", "from_typical", "from_max",
.
.
SDF
.
324
"from_maximum", "from_mtm",
"from_mtm".
, .
, ,
,
.
,
SDF
: $sdf_annotate ("myasic.sdf", testbench.u1); : $sdf_annotate ("myasic.sdf", testbench.u1,,, "
");
SDF to Verilog construct matching( SDF Verilog) SDF . ё
,
Verilog , SDF,
. ,
.
SDF
, SDF
. SDF Verilog
:
,
IOPATH
:
SDF
Verilog
( IOPATH (posedge clk) q (3) (4))
(posedge clk = > q) = 0;
( IOPATH y (3) (4))
buf u1 (y, a);
IOPATH , . INTERCONNECT SDF
PORT
. ,
,
,
: Verilog
(INTERCONNECT u1.y u2.a (5))
input a;
(PORT u2.a (5))
input a;
inout .
, (MIPD- Module Input Port Delay).
,
ё 325
ё
,
,
, PATHPULSE SDF
MIPD. , Verilog
GLOBALPATHPULSE
:
( PATHPULSE y (5) (10))
( = > y) = 0;
( GLOBALPATHPULSE y (30) (60))
( = > y) = 0; SDF,
. :
DEVICE SDF
Verilog
(DEVICE y (5))
and u1 (y, a, b);
(DEVICE y (5))
(a= > y) = 0; (b = > y) = 0;
SDF –
,
.
, ,
DEVICE (
,
).
,
, (
, SETUP SDF
, ).
$setup
$setuphold: Verilog
(SETUP d (posedge clk) (5))
$setup (d, posedge clk, 0);
(SETUP d (posedge clk) (5))
$setuphold (posedge clk, d, 0, 0);
HOLD SDF
$hold
$setuphold: Verilog
(HOLD d (posedge clk) (5))
$hold (posedge clk, d, 0);
(HOLD d (posedge clk) (5))
$setuphold (posedge clk, d, 0, 0);
SETUPHOLD SDF
$setup, $hold,
( SETUPHOLD d (posedge clk) (5) (5))
$SETUPHOLD: Verilog $setup (d, posedge clk, 0); 326
( SETUPHOLD d (posedge clk) (5) (5))
$hold (posedge clk, d, 0);
( SETUPHOLD d (posedge clk) (5) (5))
$SETUPHOLD (posedge clk, d, 0, 0);
)
RECOVERY( SDF
$recovery: Verilog
(RECOVERY (negedge reset) (posedge clk) (5))
REMOVAL( SDF
$removal: Verilog
)
(REMOVAL (negedge reset) (posedge clk) (5))
RECREM SDF ( RECREM (negedge (5)) ( RECREM (negedge (5)) ( RECREM (negedge (5))
$recovery(negedge reset, posedge clk, 0);
$recovery, $removal,
$removal(negedge reset, posedge clk, 0);
$recrem: Verilog
) (posedge clk) (5)
$recovery (negedge reset, posedge clk, 0);
) (posedge clk) (5)
$removal (negedge reset, posedge clk, 0);
) (posedge clk) (5)
$recrem( negedge reset, posedge clk, 0);
SKEW( ) $skew: SDF (SKEW (posedge clk1) (posedge clk2) (5))
Verilog $skew (posedge clk1, posedge clk2, 0);
WIDTH $width: SDF (WIDTH (posedge clk) (5))
Verilog $width (posedge clk, 0);
PERIOD $period: SDF (PERIOD (posedge clk) (5))
Verilog $period (posedge clk, 0);
NOCHANGE $nochange: SDF (NOCHANGE (negedge write) addr (5) (5))
Verilog $nochange(negedge write, addr, 0, 0);
Optional edge specifications(
)
. 327
, •
,
•
,
•
,
:
SDF
. . SDF
. •
, SDF
. SDF , SDF
Verilog.
, Verilog
, ,
SDF :
SDF
Verilog
(SETUP data (posedge clock) (5))
$setup(posedge data, posedge clk, 0);
(SETUP data (posedge clock) (5))
$setup(negedge data, posedge clk, 0);
,
, ,
SDF
, .
, SDF
,
.
SDF
Verilog
(SETUP (posedge data) (posedge clock) (4))
$setup(data, posedge clk, 0);
(SETUP (negedge data) (posedge clock) (6))
$setup(data, posedge clk, 0);
,
SDF ,
, SDF posedge 10, 1x, x0, x1. [01, 0x, x1] negedge.
, . posedge (+ negedge . posedge , ,
)
,
negedge(-
). - 01, 0x, [10, 1x, x0] SDF
. ,
SDF
Verilog
328
(SETUP data (posedge clock) (5))
$setup(data, edge[01, 0x] clk, 0);
Optional conditions(
)
.
, :
•
,
SDF
.
•
, .
•
,
SDF
SDF
. , ,
.
, SDF
Verilog
(SETUP data (COND (reset!=1) (posedge clock)) (5))
$setup(data, posedge clk &&& (reset==0), 0);
,
.
,
. , 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
, r2
r1
.
Rounded timing values( ) SDF TIMESCALE , 10ps ( 16ps
SDF .
.016 timescale), 20ps. , MIPD.
.
SDF SDF TIMESCALE - 1ns,
, ,
20ps.
SDF
,
329
SDF for Mixed VHDL and Verilog Designs( SDF VHDL Verilog) VHDL
Verilog
. VHDL VITAL SDF
Verilog SDF $sdf_annotate Verilog Verilog . .
.
.
vsim (CR-296) .
SDF
Interconnect delays(
)
. ModelSim Verilog, VHDL/VITAL,
..
vsim .
. , ,
.
,
,
, ,
.
Troubleshooting(
)
Specifying the wrong instance(
) SDF
SDF ,
.
.
-
, ASIC
SDF
FPGA, . VHDL
Verilog
.
, ,
.
VHDL testbench entity testbench is end; architecture only of testbench is component myasic 330
end component; begin dut : myasic; end; Verilog testbench module testbench; myasic dut(); endmodule - myasic,
- dut.
, :
vsim -sdfmax /testbench/dut=myasic.sdf testbench ,
:
vsim -sdfmax /dut=myasic.sdf testbench , , SDF ,
SDF
. ,
,
ё,
, environment (CR-146).
, SDF.
Mistaking a component or module name for an instance label (
) ,
.
,
testbenches: vsim -sdfmax /testbench/myasic=myasic.sdf testbench : ** Error (vsim-SDF-3250) myasic.sdf(0): Failed to find INSTANCE ’/testbench/myasic’.
Forgetting to specify the instance(
)
, SDF,
.
,
vsim -sdfmax myasic.sdf testbench 331
: ** 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. ( .) ,
,
, :
** Warning (vsim-SDF-3440) myasic.sdf: Failed to find any of the 358 instances from this file. ( 358 ). ** Warning (vsim-SDF-3442) myasic.sdf: Try instance ’/testbench/dut’ - it contains all instance paths from this file.( ’/testbench/dut ’ – ) ,
ё . " Resolving errors( VHDL VITAL SDF.
. )"
332
14 - Value Change Dump (VCD) Files ( (VCD))
VCD ModelSim
VCD
VCD -
1— 2— 3—
ё
VCD VCD VCD
Verilog VHDL HDL
VCD VHDL VCD VCD 333
TSSI
VCD
VCD dumpports
Verilog VCD Model Technology’s VCD
1364. ,
ModelSim. ASCII
,
. VCD VCD
Verilog , Verilog. ModelSim VCD Verilog VHDL.
VHDL;
ModelSim
: ASIC , ASIC.
,
VCD,
ModelSim VCD commands and VCD tasks ( ModelSim VCD VCD )_ ModelSim VCD VCD VCD
1364 VCD . .
VCD vcd add (CR-231) vcd checkpoint (CR-232)
VCD $dumpvars $dumpall $dumpfile
vcd file(CR-241) vcd flush (CR-245)
$dumpflush
vcd limit (CR-246)
$dumplimit
vcd off (CR-247)
$dumpoff
vcd on(CR-248)
$dumpon 334
ModelSim 5.5 dumpports). .
VCD ( dumpports VCD
dumpports VCD
VCD
vcd dumpports (CR-234)
$dumpports
vcd dumpportsall (CR-236)
$dumpportsall
vcd dumpportsflush (CR-237)
$dumpportsflush
vcd dumpportslimit (CR-238)
$dumpportslimit
vcd dumpportsoff (CR-239)
$dumpportsoff
vcd dumpportson (CR-240)
$dumpportson
ModelSim
5.5
VCD . Std 1364. $dumpfile, $dumpvar, , ,
, , $fdumpfile, VCD,
. .
.
VCD
VCD
vcd add (CR-231) -file
$dumpvars
vcd checkpoint (CR-232)
$dumpall $dumpfile
vcd files(CR-243) vcd flush (CR-245)
$dumpflush
vcd limit (CR-246)
$dumplimit
vcd off (CR-247)
$dumpoff
vcd on(CR-248)
$dumpon
:
,
(vcd file
vcd files)
, 335
VCD. Vcd file VCD ModelSim
5.5. Vcd files ,
VCD 5.5
ModelSim
Creating a VCD file(
.
VCD)
ModelSim
VCD
.
VCD
0, 1, x, ;
z
VCD . , . К
, .
ё
Flow for four-state VCD file( VCD) % % % %
:
cd ~/modeltech/examples vlib work vlog counter.v tcounter.v vsim test_counter
,
,
VSIM VSIM VSIM VSIM
1> 2> 3> 4>
vcd file (CR-
VCD vcd add (CR-231):
241) vcd file myvcdfile.vcd vcd add /test_counter/dut/* run quit -f
VCD
.
Flow for extended VCD file( % % % %
ModelSim.
VCD) :
cd ~/modeltech/examples vlib work vlog counter.v tcounter.v vsim test_counter
,
, vcd dumpports (CR-234):
VCD
,
VSIM 1> vcd dumpports -file myvcdfile.vcd /test_counter/dut/* VSIM 3> run VSIM 4> quit –f
VCD
Case sensitivity(
.
)
336
VHDL
, , ,
ModelSim ё VCD .
ModelSim
, Verilog ,
Resimulating a design from a VCD file ( VCD :
ё VCD
.
)
ModelSim 5.5c . www.model.com/products/documentation/resim_vcd.pdf , . VCD
, .
VHDL, Verilog,
HDL. . VCD VCD
1
:
vcd dumpports (CR-234).
,
,
2
-vcdstim vsim (CR-296).
Example 1 — Verilog counter( -
,
VCD
1-
ё
Verilog )
vcd dumpports:
% 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
ё
-vcdstim:
% vsim -vcdstim counter.vcd counter VSIM 1> add wave /* VSIM 2> run 200
Example 2 — VHDL adder( -
,
VCD
2-
VHDL)
vcd dumpports:
% cd ~/modeltech/examples % vlib work % vcom gates.vhd adder.vhd stimulus.vhd % vsim testbench VSIM 1> vcd dumpports -file addern.vcd /testbench/uut/* VSIM 2> run 1000 VSIM 3> quit -f
ё
-vcdstim
% vsim -vcdstim addern.vcd addern -gn=8 -do "add wave /*; run 1000"
337
Example 3 — Mixed-HDL design( -
,
3-
VCD ,
HDL
)
:
% 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 dumpports -file proc.vcd /top/p/* VSIM 2> vcd dumpports -file cache.vcd /top/c/* VSIM 3> vcd dumpports -file memory.vcd /top/m/* VSIM 4> run 1000 VSIM 5> quit -f
,
VCD :
% 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
A VCD file from source to output(VCD ) VHDL,
,
VCD.
VHDL source code( VHDL:
VHDL) ,
338
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 ’0’) ; elsif (CLK’event and CLK = ’1’) then Q
:
(testfixture)
(dut)
D
L
U
H
N
X
Z
T
0 1 ? f
C b B
(
) (
) ( ( ( ( ( ( (
) ) ) ) ) ) ) 340
Strength values(
)
< strength > Strength(
Verilog
)
0 highz( 1 2 3 4 5 pull( 6 7 supply
: std_logic VHDL
)
’Z‘
)
’W‘, ’H‘, ’L‘ ’U‘, ’X‘, ’0‘, ’1‘, ’- ’
Port identifier code ( -
) ,
sml.vhd % vlib lmc % vcom -work lmc sml.vhd
344
SmartModels SmartModels. sml ( ),
VHDL, , :
lmc
% sm_entity -all -c -xe -xa > smlcomp.vhd ,
smlcomp.vhd SmartModel
:
library ieee; use ieee.std_logic_1164.all; package sml is
end sml; lmc : % vcom -work lmc smlcomp.vhd SmartModels library
, use
:
library lmc; use lmc.sml.all;
y7c285 SmartModel.
,
sm_entity
library ieee; use ieee.std_logic_1164.all; entity cy7c285 is generic (TimingVersion : STRING := "CY7C285-65"; DelayRange : STRING := "Max"; MemoryFile : STRING := "memory" ); port ( A0 : in std_logic; A1 : in std_logic; A2 : in std_logic; A3 : in std_logic; A4 : in std_logic; A5 : in std_logic; A6 : in std_logic; A7 : in std_logic; A8 : in std_logic; A9 : in std_logic; A10 : in std_logic; A11 : in std_logic; A12 : in std_logic;
345
A13 : in std_logic; A14 : in std_logic; A15 : in std_logic; CS : in std_logic; O0 : out std_logic; O1 : out std_logic; O2 : out std_logic; O3 : out std_logic; O4 : out std_logic; O5 : out std_logic; O6 : out std_logic; O7 : out std_logic; WAIT_PORT : inout std_logic ); end; architecture SmartModel of cy7c285 is attribute FOREIGN : STRING; attribute FOREIGN of SmartModel : architecture is "sm_init $MODEL_TECH/libsm.sl ; cy7c285"; begin end SmartModel;
•
-
SmartModel (
). •
-
, SmartModel
). sm_entity -93,
SmartModel ( .
, -93
93
, , wait
•
WAIT WAIT, VHDL.
. \WAIT\. WAIT_PORT,
- std_logic. SmartModel.
•
DelayRange, TimingVersion, MemoryFile . SmartModel ( ). Sm_entity SmartModel. , SmartModel
•
VHDL, sm_entity
(sm_init) -
SmartModel
sm_entity.
SmartModels. 346
• modelsim.ini. •
($MODEL_TECH/libsm.sl
(cy7c285 SmartModel
,
libsm
SmartModel. .
Vector ports(
)
,
-
sm_entity
,
. , SmartModel SWIFT ,
ModelSim . , ,
. . ,
!
-
, CY7C285 SmartModel:
Command channel(
)
-
ModelSim
SmartModel, SmartModel . " SmartModel"(http://www.synopsys.com/products/lm/docs/swift_r41/intro.html). . SmartModel:
lmc |-all "" instance_name (
.
SmartModel. environment (CR-147)). SmartModel /top/u1:
,
lmc /top/u1 "SetConstraints Off" -all,
SmartModel. 347
, SmartModel: lmc -all "SetConstraints Off" , SmartModel:
SmartModel, , ,
.
lmcsession "" SmartModel "(http://
, " www.synopsys.com/products/lm/docs/swift_r41/intro.html) .
SmartModel Windows(
Windows) SmartModel SmartModel Windows. SmartModel(
web
site Synopsys’) . . Windows
, , \z1I10. GSR.OR\ (
.
5.3c ModelSim, VHDL Verilog VHDL. z1I10. GSR.OR, Modelsim , lmcwin, add wave, examine). . ,
add wave /top/swift_model/\z1I10.GSR.OR\ ,
.
ReportStatus ReportStatus ,
,
.
lmc /top/u1 ReportStatus SmartModel Windows: WA "Read-Only (Read Only)" WB "1-bit" WC "64-bit" ,
wa, wb, wc. (lmcwin).
348
lmcwin SmartModel : • lmcwin read [-] • lmcwin write • lmcwin enable • lmcwin disable • lmcwin release , . , /top/u1/wa
wa
/top/u1.
lmcwin read
. -hexadecimal )( , wc
lmcwin read (-
,
-binary, -decimal, -
,
,
64-
). std_logic.
: lmcwin read /top/u1/wc –h
lmcwin write .
lmcwin write , ,
, 1
. wb,
1’
wc:
lmcwin write /top/u1/wb 1 lmcwin write /top/u1/wc X"FFFFFFFFFFFFFFFF" lmcwin enable .
lmcwin enable, ( std_logic add list (CR-48)
std_logic_vector. , . .
) , ,
,
wa:
349
lmcwin enable /top/u1/wa add list /top/u1/wa lmcwin disable .
lmcwin disable, , . ,
, wa:
lmcwin disable /top/u1/wa lmcwin release -
, . lmcwin write
Memory arrays (
lmcwin write lmcwin release .
) .
,
. . ,
5
mem:
lmcwin read /top/u2/mem(5) 0.
,
. .
Verilog SmartModel interface(Verilog ) SWIFT SmartModel,
r40b, PLI,
Verilog PLI
SWIFT. , , Logic Modeling's SmartInstall.
Verilog (LMTV). "Verilog",
Linking the LMTV interface to the simulator( LMTV ) 350
Synopsys ModelSim
, LMTV.
5, "
Synopsys, " " Synopsys " ( ,
MTI Verilog
Synopsys) .
16 - Logic Modeling Hardware Models (
)
VHDL hm_entity
ModelSim VHDL Verilog.
, 351
, . ,
.
, ModelSim.
,
: .
ModelSim SE.
VHDL Hardware Model interface ( VHDL) ModelSim VHDL
. , .
, .
ModelSim , hm_entity (
modelsim.ini. )
. 352
[lmc]
modelsim.ini, ModelSim. :
[lmc] ; ModelSim’s interface to Logic Modeling’s hardware modeler SFI software libhm = $MODEL_TECH/libhm.sl ; ModelSim’s interface to Logic Modeling’s hardware modeler SFI software (Windows NT) ; libhm = $MODEL_TECH/libhm.dll ; Logic Modeling’s hardware modeler SFI software (HP 9000 Series 700) ; libsfi = /lib/hp700/libsfi.sl ; Logic Modeling’s hardware modeler SFI software (IBM RISC System/6000) ; libsfi = /lib/rs6000/libsfi.a ; Logic Modeling’s hardware modeler SFI software (Sun4 Solaris) ; libsfi = /lib/sun4.solaris/libsfi.so ; Logic Modeling’s hardware modeler SFI software (Window NT) ; libsfi = /lib/pcnt/lm_sfi.dll ; Logic Modeling’s hardware modeler SFI software (Linux) ; libsfi = /lib/linux/libsfi.so
ModelSim,
libhm
. libsfi ,
. libhm .
, ModelSim ,
libsfi
libhm libhm.sl, MODEL_TECH. ModelSim MODEL_TECH
,
, .
Windows , libhm ( libhm
";")
Windows. ,
libsfi
. M_LIB
, .
LM_DIR
Creating foreign architectures with hm_entity ( hm_entity) hm_ entity ModelSim . : С hm_entity [-xe] [-xa] [-c] [-93] 353
ы -xe . -xa . -c . -93 .
(
.
). , stdout
hm_entity . (-xe),
(-c),
, (-xa). ,
.
, LMTEST:
% hm_entity LMTEST.MDL > lmtest.vhd % vlib lmc % vcom -work lmc lmtest.vhd VHDL, .
, , .
stdout
LMTEST.
% hm_entity -c -xe -xa LMTEST.MDL . CY7C285
,
hm_entity
:
CY7C285 library ieee; use ieee.std_logic_1164.all; entity cy7c285 is generic ( DelayRange : STRING := "Max" ); port ( A0 : in std_logic;
354
A1 : in std_logic; A2 : in std_logic; A3 : in std_logic; A4 : in std_logic; A5 : in std_logic; A6 : in std_logic; A7 : in std_logic; A8 : in std_logic; A9 : in std_logic; A10 : in std_logic; A11 : in std_logic; A12 : in std_logic; A13 : in std_logic; A14 : in std_logic; A15 : in std_logic; CS : in std_logic; O0 : out std_logic; O1 : out std_logic; O2 : out std_logic; O3 : out std_logic; O4 : out std_logic; O5 : out std_logic; O6 : out std_logic; O7 : out std_logic; W : inout std_logic ); end; architecture Hardware of cy7c285 is attribute FOREIGN : STRING; attribute FOREIGN of Hardware : architecture is "hm_init $MODEL_TECH/libhm.sl ; CY7C285.MDL"; begin end Hardware;
•
-
(
). •
-
,
). VHDL, hm_entity hm_entity
( . -93,
, -93. ,. . •
•
- std_logic.
,
DelayRange .
-" ).
, ", " "
",
"
"(
".
355
•
(hm_init) – .
•
($MODEL_TECH/libhm.sl) , modelsim.ini.
•
libhm
(CY7C285. MDL) -
. .
Vector ports(
)
,
-
hm_entity
,
. ,
, , . .
,
! -
, CY7C285:
component cy7c285 generic ( DelayRange : STRING := "Max"); port ( A : in std_logic_vector (15 downto 0); CS : in std_logic; O : out std_logic_vector (7 downto 0); WAIT_PORT : inout std_logic ); end component; for all: cy7c285 use entity work.cy7c285 port map (A0 => A(0), A1 => A(1), A2 => A(2), A3 => A(3), A4 => A(4), A5 => A(5), A6 => A(6), A7 => A(7), A8 => A(8), A9 => A(9), A10 => A(10), A11 => A(11), A12 => A(12), A13 => A(13), A14 => A(14), A15 => A(15), CS => CS, O0 => O(0), O1 => O(1), O2 => O(2), O3 => O(3), O4 => O(4), O5 => O(5), O6 => O(6), O7 => O(7), WAIT_PORT => W );
356
Hardware model commands(
) .
. Lm_vectors on|off [] /
.
Lm_measure_timing on|off [] / . Lm_timing_checks on|off / . Lm_loop_patterns on|off / . Lm_unknowns on|off /
.
17- Tcl and macros (DO files) ( Tcl (DO files)) Tcl
ModelSim
Tcl Tcl Tcl if 357
set .
Tcl
ModelSim Tcl ModelSim Tcl
Ma
Tcl (DO DO
) DO files DO Tcl ( ModelSim.
) ModelSim Tcl. Tcl
ModelSim ,
Tcl ,
ModelSim. ModelSim C.
Tcl
,
Tcl
ё
;
Tcl ModelSim . ,
,
ModelSim Tcl,
Tcl features within ModelSim (
, .
Tcl
Tcl ModelSim • •
(
ModelSim) :
,
C) C
• • • • 358
• •
(
)
ё
•
Tcl References(
Tcl)
Tcl - Tcl Tk К , Addison-Wesley Publishing Company, Inc., Practical Programming in Tcl Tk ,Brent Welch , Prentice Hall.
.
: •
Help > Tcl Man Pages (
).
• Model Technology www.model.com/resources/tcltk.asp
Tcl tutorial(
Tcl:
Tcl ) Tcl ModelSim,
. " Tcl/Tk
ModelSim "
ModelSim SE.
Tcl commands (
Tcl) Tcl,
( Tcl "
).
Help > Tcl Man Pages
."
, Tcl.
ModelSim,
Tcl, Tcl.
ы щ я ModelSim continue format list | wave if
.
: я
run (CR-208)
я)
(
-continue
write format (CR-321) wave Tcl if,
list ."
if " 359
list
add list (CR-48)
nolist | nowave
delete (CR-132)
list
set
Tcl set,
wave
."
set " source
vsource (CR-311)
wave
add wave (CR-57)
Tcl command syntax(
Tcl) Tcl. set
if . 1 Tcl
-
,
. .
("]") ( .
2 ё
, .
.
)
.
Tcl
.
,
,
. ,
,
,
,
,
Tcl.
,
3
,
.
(
,
). (""")
4
,
. ,
(
, )
, .
,
,
, . .
5
-
("{") , ("}"). : (
, 360
, ). , ,
,
,
,
,
. , . ("["), Tcl
6
Tcl,
. ,
Tcl. , ("]").
ё
(
) . . ,
.
("$")
7
Tcl,
: . :
$name -
; ,
,
,
.
$name (index) .
, .
,
,
, .
${name} -
.
, . . ,
8
.
("\") .
,
,
, .
,
,
,
. , ,
,
.
\a \b
(
) (0x7). (0x8). 361
\f
(0xc).
\n
(0xa).
\r
(0xd).
\t
(0x9).
\v
(0xb).
\ whiteSpace
, ,
. , .
,
, , , . \\
("\"). ooo (
\ooo
,
,
)
. \xhh
hh .
.
, backslash-newline
,
. ("#")
9
,
,
Tcl ,
,
, . .
,
Tcl
10 .
,
,
, ;
.
, Tcl; . .
11 (
)
,
,
,
, .
if command syntax (
if) 362
Tcl if
.
, "?"-
,
.
if expr1 ?then? body1 elseif expr2 ?then? body2 elseif ... ?else? ?bodyN?
.
expr1
if (
,
0
else,
,
,
,
);
body1,
Tcl. ,
body2 then
, ",
"
else .
expr2, . .
bodyN
. BodyN
elseif, ,
.
else
,
,
, bodyN.
set command syntax(
set )
Tcl set
.
,
"?"
.
set varName ?value?
,
varName. ,
varName ,
, .
varName
, -
ё
: , varName
. .
ё ), .
, varName
,
(
ё ё (
varName
,
), . ё (
, ё ).
varName ,
ё ,
varName
,
363
, variable Tcl,
,
varName varName
Command substitution (
ё .
) []
ё
,
.
: set a 25 set b 11 set c 3 echo "the result is [expr ($a + $b)/$c]" : "the result is 12" VHDL,
Verilog
: [examine - name] %name
. %name [examine - name], .
Command separator(
, .
)
(;) .
.
Multiple-line commands(
)
Tcl , .
(
C)
. ,
{, if
else.
,
Tcl
,
, ,
.
if { [exa sig_a] == "0011ZZ"} { echo "Signal value matches" do macro_1.do 364
} else { echo "Signal value fails" do macro_2.do }
Evaluation order (
) Tcl , {}
,
,
,
ё
. ,
.
Tcl relational expression evaluation( Tcl) ,
:
• Tcl
, .
,
,
.
if {[exa var_1] == 345}... : if {[exa var_1] == "345"}... • , , Tcl . :
,
if {[exa var_2] == 001Z}... . if {[exa var_2] == "001Z"}... . •
:
if {[exa var_3] == ’X’}... . if {[exa var_3] == "X"}... . •
, -
,
Variable substitution(
C "==". C "! = ".
)
365
$ , , .
Tcl ,
ModelSim
: Tcl
. ,
:
$env() echo My user name is $env(USER) ,
env:
set env(SHELL) /bin/csh ."
" .
ModelSim-
System commands (
) UNIX
DOS,
exec Tcl : echo The date is [exec date]
List processing ( Tcl "
)
"-
,
Tcl
. ,
,
,
С
К
.
:
ы
lappend var_name val1 val2 ...
val1, val2,
. .
var_name lindex list_name index linsert list_name index val1 val2 ... list val1, val2 ... llength list_name
- th -0 val1, val2, . . list_name Tcl,
list_name; - th val1, val2,
. .
list_name
366
lrange list_name first last
list_name, ; "end",
lreplace list_name first last val1, val2,... , lsearch .
.
val1, val2, . . lsort,
Tcl Man Pages) . ModelSim Tcl: lecho (CR-161)
.
ModelSim Tcl commands (
ModelSim Tcl) Tcl
ModelSim.
; ModelSim .
К
ы
alias (CR-61)
Tcl, ;
find (CR-152)
incrTcl
lecho (CR-161) lshift (CR-166)
ё
,
Tcl Tcl 367
,
0-
lsublist (CR-167)
Tcl, Tcl glob
printenv (CR-186)
ModelSim Tcl time commands (
ModelSim Tcl)
ModelSim Tcl ,
Tcl. , (
. 10ns, " 10 ns "). , Time Scale Units.
64-
, UserTimeScale. .
, 0.
Conversions(
)
368
intToTime
32) 64-
( (
ModelSim - 64-
)
RealToTime
64-
scaleTime
,
Relations( К
)
ы
eqTime neqTime gtTime gteTime ltTime lteTime
1
0
, Tcl.
,
-
, if {[eqTime $Now 1750ns]} { ... }
Arithmetic ( К
)
ы
addTime divTime mulTime
6464-
subTime
369
Tcl examples(
Tcl)
Example 1(
1) Tcl/ModelSim
UNIX ё
, VHDL
. Tcl
,
Verilog HDL, VHDL
STRING. (DO_ECHO) , :
(
Windows, ,
, VHDL. exec Tcl , .
VHDL):
370
signal datime : string(1 to 28) := " spaces (
";# 28
VSIM):
proc set_date {} { global env set do_the_echo [set env(DO_ECHO)] set s [exec date] force -deposit datime $s if {do_the_echo} { echo "New time is [examine -value datime]" } } bp src/waveadd.vhd 133 {set_date; continue} --sets the breakpoint to call set_date
-
while Tcl , :
b, set b "" set i [expr[llength $a]-1] while {$i >= 0} { lappend b [lindex $a $i] incr i -1 }
...
for Tcl , :
b,
set b "" for {set i [expr [llength $a] -1]} {$i >= 0} {incr i -1} { lappend b [lindex $a $i] } foreach Tcl, (
b,
foreach
): set b "" foreach i $a { set b [linsert $b 0 $i] } 371
, break Tcl :
,
,
set b "" foreach i $a { if {$i = "ZZZ"} break set b [linsert $b 0 $i] }
-
,
,
continue Tcl: set b "" foreach i $a { if {$i = "ZZZ"} continue set b [linsert $b 0 $i] } switch Tcl: switch a b c }
$x { {incr t1} {incr t2} {incr t3}
Example 2(
2) Tcl ,
Wave
, ,
, .
. Main, ModelSim SE.
## This file contains procedures to manage multiple wave files. ## Source this file from the command line or as a startup script. ## source /wave_mgr.tcl ## add_wave_buttons ## Add wave management buttons to the main toolbar (new, save and load) ## new_wave ## Dialog box creates a new wave window with the user provided name ## named_wave ## Creates a new wave window with the specified title ## save_wave ## Saves name, window location and contents for all open ## wave windows ## Creates .do file for each window where is 1 ## to the number of windows. Default file-root is "wave". Also ## creates windowSet.do file that contains title and geometry info.
372
## load_wave ## Opens and loads wave windows for all files matching .do ## where are the numbers from 1-9. Default is "wave". ## Also runs windowSet.do file if it exists. ## Add wave management buttons to the main toolbar proc add_wave_buttons {} { _add_menu main controls right SystemMenu SystemWindowFrame {Load Waves} load_wave _add_menu main controls right SystemMenu SystemWindowFrame {Save Waves} save_wave _add_menu main controls right SystemMenu SystemWindowFrame {New Wave} new_wave } ## Simple Dialog requests name of new wave window. Defaults to Wave proc new_wave {} { global dialog_prompt vsimPriv set defaultName "Wave[llength $vsimPriv(WaveWindows)]" set dialog_prompt(result) $defaultName set windowName [GetValue . "Create Named Wave Window:" ] ## Debug puts "Window name: $windowName\n"; if {$windowName == "{}"} { set windowName "" } if {$windowName != ""} { named_wave $windowName } else { named_wave $defaultName } } ## Creates a new wave window with the provided name (defaults to "Wave") proc named_wave {{name "Wave"}} { global vsimPriv view -new wave set newWave [lindex $vsimPriv(WaveWindows) [expr [llength $vsimPriv(WaveWindows)] - 1]] wm title $newWave $name } ## Writes out format of all wave windows, stores geometry and title info in ## windowSet.do file. Removes any extra files with the same fileroot. ## Default file name is wave starting from 1. proc save_wave {{fileroot "wave"}} { global vsimPriv set n 1 set fileId [open windowSet_$fileroot.do w 755] foreach w $vsimPriv(WaveWindows) { echo "Saving: [wm title $w]" set filename $fileroot$n.do write format wave -window $w $filename puts $fileId "wm title $w \"[wm title $w]\"" puts $fileId "wm geometry $w [wm geometry $w]" puts $fileId "mtiGrid_colconfig $w.grid name -width / [mtiGrid_colcget $w.grid name -width]" puts $fileId "mtiGrid_colconfig $w.grid value -width / [mtiGrid_colcget $w.grid value -width]"
373
flush $fileId incr n } if {![catch {glob $fileroot\[$n-9\].do}]} { foreach f [lsort [glob $fileroot\[$n-9\].do]] { echo "Removing: $f" exec rm $f } } } ## Provide file root argument and load_wave restores all saved widows. ## Default file root is "wave". proc load_wave {{fileroot "wave"}} { global vsimPriv foreach f [lsort [glob $fileroot\[1-9\].do]] { echo "Loading: $f" view -new wave do $f } if {[file exists windowSet_$fileroot.do]} { do windowSet_$fileroot.do } }
Macros (DO files)(
(DO
))
ModelSim ( DO ModelSim , , Tcl. ( Main) Tools > Execute Macro
Creating DO files(
DO
DO
)do (CR-137).
)
,
Tcl, .
MAIN Main " ). -
DO
,
DO
(
,
,
" Main. ModelSim. DO
Wave, ,
.
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
374
run 200 force rst 0 10 run 1500
Using Parameters with DO files( ) DO
DO ,
.
, $1
$9 bp $ 1 $ 2.
.
,
"testfile" ,
design.vhd
127:
do testfile design.vhd 127
, ,
. shift (CR-215),
.
Making macro parameters optional( ) If you want to make macro parameters optional (i.e., be able to specify fewer parameter values with the command than the number of parameters referenced in the macro), you must use the argc (UM-455) simulator state variable. The argc simulator state variable returns the number of parameters passed. The examples below show several ways of using argc. ( , do, ), argc. argc . argc.
,
1
0-2 ModelSim
ё
.
,
.
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. } }
2
. variable Files "" set nbrArgs $argc for {set x 1} {$x / < Project_Name > .mpf). .
,
(
500 ); . " see "Improve performance by locking memory n HPUX 10.2( , HPUX 10.2 )"
1,
(0) numeric_std
PathSeparator
numeric_bit ;
/
Datapath 389
Resolution
fs, ps, ns, us, ms, sec –
ns ; t; , ;
1, 10 100
(
, 10fs,
10 fs)
RunLength
100 UserTimeUnit
Startup
= do ;
ModelSim; do (CR-137)
.
(;)
StdArithNoWarnin gs
(do) 0, 1
1,
(0) Synopsys std_arith
TranscriptFile
UnbufferedOutput
;
0, 1
VHDL ;0=
Verilog ,
0 ,
1=
UserTimeUnit
fs, ps, ns, us, ms, sec
ns ,
, force (CR-154) run (CR-208); , , , Resolution ,
Veriuser Verilog PLI/VPI; . " Verilog PLI/VPI"
(;)
ё 390
WaveSignalName Width
0,
0 , Wave; ,
ё (
WLFCompress
0, 1
)
WLF
.(1)
1
.(0) WLFDeleteOnQuit 0, 1
,
WLF
, 0, 1, , WLF
WLFSaveAllRegio 0, 1 ns
0 ; ; 0
(1) ,
,
(0)
WLFSizeLimit
0–
WLF WLF (
;
,
0
) ;
MB ; WLFTimeLimit
0(
0 WLF; WLF ) .
,
0
MB ;
0
[lmc] Logic Modeling variables( [lmc] )
ModelSim’s
VHDL) " HDL "
, ё [lmc] INI/MPF . " "VHDL SmartModel interface ( " VHDL Hardware Model interface ( .
Setting variables in INI files (
INI
;
) 391
, . : = (;). : INI
vmap (CR-295) .
Reading variable values from the INI file( INI ) Tcl
modelsim.ini.
GetIniInt . GetIniReal . GetProfileString [] ё
.
,
.
Tcl
modelsim.ini Tcl
.
,
set MyCheckpointCompressMode [GetIniInt "CheckpointCompressMode" 1] set PrefMain(file) [GetProfileString vsim TranscriptFile ""]
Commonly used INI variables (
INI) modelsim.ini
.
. ($)
.
:
[Library] work = $HOME/work_lib test_lib = ./$TESTNUM/work ... [vsim] 392
IgnoreNote = $IGNORE_ASSERTS IgnoreWarning = $IGNORE_ASSERTS IgnoreError = 0 IgnoreFailure = 0 , MODEL_TECH, . MODEL_TECH Model Technology. ё VCOM VLOG . MODEL_TECH Technology, .
-
—
" others"
, , VSIM Model
modelsim.ini, . modelSim.ini,
,
ModelSim " others".
[Library] asic_lib = /cae/asic_lib work = my_work others = /install_dir/modeltech/modelsim.ini ,
" others"
" others", INI
.
, :
, , TranscriptFile modelsim.ini , ModelSim. ; Save the command window contents to this file TranscriptFile = trnscrpt . .
,
,
,
do ,
.
,
:
; VSIM Startup command Startup = do mystartup.do ,
ModelSim mystartup.do.
; VSIM Startup command Startup = run –all 393
,
VSIM .
.,
do (CR-137)
do
.
VHDL, , .
modelsim.ini.
[vsim] IgnoreNote = 1 IgnoreWarning = 1 IgnoreError = 1 IgnoreFailure = 1 . " Preference variables TCL )" .
Tcl; located in TCL files(
,
[vsim]
synopsys modelsim.ini.
,
[vsim] NumericStdNoWarnings = 1 StdArithNoWarnings = 1 Tcl; variables located in TCL files( )".
,
. " Preference TCL
Force force ). ,
-freeze, -drive, , -drive
–deposit(
, - freeze,
,.
4.1 . -freeze ,
modelsim.ini
. [vsim] ; Default Force Kind ; The choices are freeze, drive, or deposit DefaultForceKind = freeze
restart
-force, -nobreakpoint, -nolist, -nolog,
-nowave. 394
, modelsim.ini: DefaultRestartOptions = < options > nowave.
-force, -nobreakpoint, -nolist, -nolog,
-
: DefaultRestartOptions = -nolog -force : Tcl
modelsim.Tcl. .ini . VHDL93 VHDL93 INI
:
[vcom] ; Turn on VHDL-1993 as the default. Default is off (VHDL-1987). VHDL93 = 1 VHDL VHDL VHDL DelayFileOpen .
,
INI
.
,
. ,
[vsim] DelayFileOpen = 1
Preference variables located in TCL files ( , )
TCL
ModelSim TCL ,
,
, .
, ,
Tcl , ,
, . Tcl,
.
URL(uniform resource locator ):
http://www.model.com/resources/pref_variables/frameset.htm ModelSim
, 395
pref.tcl. GUI ModelSim (Tools > Edit Preferences ( ( Tcl ), ,
Main)),
. - modelsim.tcl. :
modelsim.tcl • MODELSIM_TCL
ModelSim
MODELSIM_TCL, ,
ModelSim
( ,
); •
./modelsim.tcl;
•
$ (HOME)/ /modelsim.tcl, :
modelsim.tcl , , MODELSIM_TCL .
User-defined variables (
)
,
set
Tcl.
, ,
.
set: set user1 7 : ECHO " user1 = $user1 "
ё
More preferences(
modelsim.ini ; files(
) . " Preference variables located in INI , INI )" .
Variable precedence(
)
,
.tcl
.ini. A
.tcl .ini .
,
modelsim.ini : TranscriptFile = transcript modelsim.tcl: set PrefMain(file) {} modelsim.tcl .
modelsim.ini
,
396
Simulator state variables( ) ,
,
. ,
DO
(
)
ModelSim.
argc
,
architecture
, Verilog
; configuration
,
, ;
delta entity
VHDL
library MacroNestingLevel n
Verilog
,
,
n
1-9 Now
, (
, 1000 ns)
now (
, 1000)
resolution
Referencing simulator state variables( ) , $. now
resolution
echo
,
:
echo "The time is $now $resolution." , : The time is 12390 10ps. ё "\".
,
, , \$now .
Special considerations for $now(
$now) 397
ModelSim
$now
, –
,
vsim (CR-296). , , 1ps),. :
-t $now ( ModelSim> vsim -t 1ps VSIM > echo $now # 0 ,
(
, 10ps), .
- 500ps, 500ps?
, - 10ps, ModelSim
, $now 3-
50
500 .
: ModelSim> vsim -t 10ps VSIM > echo $now # 0 ps ,
when (CR-312), $now. 100,
" when { $now = 100} ... ", ,
.
B - ModelSim shortcuts (
ModelSim) .Wave List
Main
-
Source
, 398
ModelSim GUI.
Wave window mouse and keyboard shortcuts( Wave) ,
< control - left-button - drag down and right>a < control - left-button - drag up and right> < control - left-button - drag up and left> < middle-button - drag> < control - left-button - click on a scroll arrow >
Wave
zoom fit (
) ,
(
) ( )
< middle mouse-button - click in scroll bar trough> (UNIX) a. , Mode > Zoom Mode,
iI
,
+
View > Mouse .
( )
oO
-
( )
f
F
l
L
r
R
( ) ( ) ( )
< up arrow >/ < down arrow >
,
, < left arrow > < right arrow >
Windows UNIX
( (
),
-
),
-
;
399
,
,
,
,
,
,
List window keyboard shortcuts( List) ,
List,
:
(
< left arrow >
) (
< right arrow >
) < up arrow > < down arrow >
(
),
(
),
(
HP)
Windows UNIX
/ ё
Command shortcuts(
Find,
) , , , ModelSim
, .
ё
ё
.
. . .
Command history shortcuts( )
400
, , ModelSim/VSIM:
!! !n
n; n (
,
!abc ^xyz^ab^
VSIM : VSIM 12 >, n =12) , " abc"
"xyz"
"ab"
up and down arrows click on prompt
( ModelSim
)
VSIM ,
-
,
his or history
(
50)
Mouse and keyboard shortcuts in the Main and Source windows( Main Source) , . notepad
, ModelSim ,
- UNIX < left-button - click >
Source
Notepad ( Notepad).
- Windows
< left-button - press > + drag < shift - left-button - press > < left-button - double-click > < left-button - double-click > + drag < control - left-button - click >
< left-button - click > VSIM
+
ModelSim
401
< middle-button - click > < middle-button - press > + drag
UNIX Windows < left | right arrow > < control > < left | right arrow > < shift > < left | right | up | down arrow > < control > < shift > < left | right arrow > < up | down arrow >
| |
(
Source, )
| < control > < up | down > < control > < home > < control > < end > < backspace >, < control-h> < delete >, < control-d > none < alt > < alt > < F4 > < control - a >, < home > < control - b > < control - d > < control - e >, < end > < control - f > < control - k > < control - n >
UNIX < control - o > < control - p > < control - s > < F3 > < control - t > < control - u > < control - v >, PageDn < control - w >, < control - x >,< control -s> < control - y >, F18 none
|
< backspace > < delete > esc
< home >
< end >
( Source
Windows)
Source
Windows)
Windows none ( < control - f >
PageDn < control - x > < control - s > < control - v > < control - a >
widget ( )
< control - \ >
widget 402
< control - - >,< control /> < meta - "" > < meta - v > , PageUp < Meta - w>
< control - Z > Source none none PageUp < control - c >
< F8 > ( Main) < F9> < F10 > < F11 > < F12>
(step-over)
Main
; (
, )
.
Right mouse button(
) .
8 - Graphic Interface(
ModelSim)
C - ModelSim messages(
.
ModelSim)
ModelSim . VCOM VLOG VSIM
403
Tcl
2
,
ё ModelSim.
ModelSim message system(
ModelSim)
ModelSim . Main. (
, "Saving the Main window transcript file( ).
Message format(
Main)"
) :
** : ([[-]]-) :
404
-
Note Warning
,
Error Fatal -
, [email protected] ModelSim , vcom, vdel, vsim, . . .
ERROR ,
Tool Group FLI,PLI, VCD,
,
.
. .
# ** Error: (vsim-PLI-3071) ./src/19/testfile(77): $fdumplimit : .
Getting more information(
) Tool-MsgNum. ,
verror (CR-258).
:
% verror 3071 Message # 3071: Not enough arguments are being passed to the specified system task or function( ).
Suppressing warning messages( ) .
, ,
.
Suppressing VCOM warning messages( VCOM) –nowarn
.
vcom (CR-250), :
vcom -nowarn 1 . , modelsim.ini (
"[vcom] VHDL compiler control variables( [vcom] VHDL )". : 405
1 2 ) 3 4 5
= unbound component( = process without a wait statement(
) wait
= null range( ) = no space in time literal( = multiple drivers on unresolved signal( ) 6 = compliance checks( ) 7 = optimization messages(
)
)
Suppressing VLOG warning messages( VLOG) +nowarn vlog (CR-286), . ,
, .
: vlog +nowarnDECAY
Suppressing VSIM warning messages( VSIM) +nowarn vsim (CR-296), . ,
, .
: vlog +nowarnTFMPC ..
Exit codes(
) ,
ModelSim. Exit code 0 1 2 3
Description (
(execv, ,
4 5 6 7 8
)
,
. .)
create/open/find/read/write create/open/find/read/write open/read/write/dup (open, lseek, write, mmap, munmap,fopen, fdopen, fread, dup2, etc. , ,
9 10 406
11 12 13 14 15
(
create/read/write/close
/
) 16 19 found/unreadable/unexecutable (vlm/mgvlm) 42 43 44
(
)
Modeltech
#44 45
(
) #45 (SEVERITY_QUIT)
90
Modeltech
99 202
(SIGINT)
204
(SIGILL)
205
(SIGTRAP)
206
(SIGABRT)
208 Exit code 210
(SIGFPE) Description (SIGBUS)
211
(SIGSEGV)
213
(SIGPIPE)
214
(SIGALRM)
215 (SIGTERM) 216
1 (SIGUSR1)
217 218
2 (SIGUSR2) (SIGCHLD)
(
)
230 (SIGXCPU) 231
(SIGXFSZ) 407
Miscellaneous messages(
) ,
ModelSim.
Lock message(
)
"waiting for lock by user@user. Lockfile is /_lock"
ё ,
_lock
,
, .
.
,
, ModelSim _lock..
,
_lock .
Tcl Initialization error 2(
2
Tcl_Init Error 2 : : ./. ./tcl/tcl8.3.
Tcl)
Init.tcl
, ModelSim,
Unix.
3
ftp. : • modeltech-base.tar.gz • modeltech-docs.tar.gz • modeltech-.exe.gz < platform >,
Tcl,
. 408
, .
ModelSim
.
Too few port connections(
)
# ** Warning (vsim-3017): foo.v(1422): [TFMPC] # 2, found 1. Region: /foo/tb
.
, . ,
–
;
, ,
Verilog, .
-
, .
,
, , .
: module foo (a, b, c, d); ,
,
:
foo inst1(e, f, g, ); – positional association foo inst1(.a(e), .b(f), .c(g), .d()); – named association ,
,
:
foo inst1(e, f, g); – positional association foo inst1(.a(e), .b(f), .c(g)); – named association d -
,
.
:
foo inst1(e, , g, h); foo inst1(.a(e), .b(), .c(g), .d(h));
•
, (a, b,)).
.( ,
Verilog .
,
,
409
•,
, ,
+nowarnTFMPC
vsim.
D - Using the FLEXlm License Manager (
FLEXlm)
daemon
FLEXlm
daemon
410
Lmstat lmdown lmremove lmreread Windows Model Technology's FLEXlm ModelSim. Globetrotter (FLEXlm Globetrotter Software’s Flexible License Manager) -
,
,
.
FLEXlm FLEXlm Model Technology's. FLEXlm End User’s, Globetrotter: http://www.globetrotter.com/manual.htm
,
Starting the license server daemon( )
daemon
Locating the license file(
)
daemon . c:\flexlm\license.dat ,
, - /usr/local/flexlm/licenses/license.dat , daemon
Windows.
•
: , LM_LICENSE_FILE
•
to find our documentation( [email protected].
Unix
-c . .
ModelSim Model Technology's Start Here for ModelSim, )", email
. " Where
Controlling the license file search(
) 411
Technology
, ModelSim Mentor Graphics.
Model vsim
, MTI,
MGC
vsim (CR-296) :
.
,
-lic_nomgc
MGC
-lic_nomti
MTI ,
-lic_noqueue -lic_plus
PLUS
-lic_vlog
VLOG
-lic_vhdl -lic_viewsim
VHDL ,
License [vsim]
.
modelsim.ini ,
;
.
, License. License nomgc
, -lic_plus
, vsim
MTI SE/PLUS.
Manual start(
)
Unix daemon , //modeltech/
:
cd //modeltech/ lmgrd -c license.dat >& report.log
linux.
sunos5, hp700_1020, hp700, hppa64, rs6000, rs64,
; . Windows daemon modeltech cd \\modeltech\win32 lmgrd -app -c license.dat
Windows, :
412
Automatic start at boot time( ) Unix daemon ,
/etc/rc.boot /etc/rc.local: : //modeltech//lmgrd -c / /license.dat & Windows FLEXlm, .
. FLEXlm End
.
What to do if another application uses FLEXlm( FLEXlm) 1: , ,
SERVER DAEMON, FEATURE,
FEATURESET . / /license/license.dat .
,
2: , . LM_LICENSE_FILE ,
, ,
:
setenv LM_LICENSE_FILE \ lic_file1:lic_file2://license.dat (;)
Windows
. daemon
-c,
.
: lmgrd > report.log
Format of the license file( DAEMON,
ModelSim FEATURE.
) :
SERVER,
:
SERVER hostname hostid [TCP_portnumber] DAEMON daemon-name path-to-daemon [path-to-options-file] FEATURE name daemon-name version exp_date #users_code \ “description” [hostid] : 413
• hostname(
)
• TCP_portnumber •
-daemon
DAEMON
• •
DAEMON -
daemon (
Feature names(
)
)
ModelSim. . ’_c ’
,
dataflow hdlcom, hdlcom_c hdlsim, hdlsim_c vcom, vcom_c vlog, vlog_c vsim, vsim_c vsim-vlog, vsimvlog_c vsim-compare, vsimcompare_c vsim-coverage, vsimcoverage_c vsim-profile, vsimprofile_c vsim-viewer, vsimviewer_c
daemon MGCLD.
(vhdl
verilog)
vhdl verilog vhdl verilog
GUI
Format of the daemon options file( daemon) ModelSim, , ModelSim,
daemon.
, .
RESERVE(
) ,
ModelSim .
INCLUDE(
) , ModelSim.
414
INCLUDE(
) ModelSim
GROUP(
.
) .
NOLOG(
)
daemon's. daemon, daemon DAEMON modeltech. daemon
, :
RESERVE number feature {USER | HOST | DISPLAY | GROUP} name INCLUDE feature {USER | HOST | DISPLAY | GROUP} name EXCLUDE feature {USER | HOST | DISPLAY | GROUP} name GROUP name NOLOG {IN | OUT | DENIED | QUEUED} REPORTLOG file ,
(#) REPORTLOG
logfile
. (+),
. ,
vsim , hostname
, QUEUED vsim.
,
logfile.
RESERVE 1 vsim USER walter RESERVE 3 vsim USER john RESERVE 1 vsim HOST bob EXCLUDE vsim USER rita NOLOG QUEUED : /usr/local/options DAEMON
:
DAEMON modeltech ///modeltech \ /usr/local/options
License administration tools( ) 415
lmstat lmstat. lmstat FLEXlm ,. lmstat
, ,
•
daemons
:
;
•
;
•
,
DAEMON. :
lmstat -a -A -S -c -f -s -t
-a
ё.
-A . -S ,
daemon's.
-c ,
.
-f ( ). -s (
)
.
-t < value > lmstat
.
lmdown lmdown daemons
daemons ( lmgrd )
. 416
lmdown -c [< license_file_path >] , /user/local/flexlm/licenses/license.dat, LM_LICENSE_FILE . ,
lmdown, . since shutting down the servers will cause loss of licenses. .
lmremove lmremove .
, , ,
. . lmremove .
lmremove -c lmremove )c . -c , lmremove, .
(
, . ,
lmreread daemon ,
lmreread daemons daemons
.
,
.
lmreread [daemon] [ -c < license_file >] : daemon, , lmreread
-c, ,
lmgrd. lmgrd
.
, 417
.
daemons
lmreread.
Administration tools for Windows ( Windows) Unix, . , Windows, "lmutil".
Windows ,
lmstat, :
lmutil lmstat [-args] Windows -
,
Unix.
E - System initialization(
)
ModelSim
, .
, , ,
,
. .
Files accessed during startup( ) 418
,
.
,
.
modelsim.ini
; "
,
INI " modelsim.INI location map file
ModelSim ,
, " soft ";
- mgc_location_map;
" How location mapping )"
works( pref.tcl
, , , " Preference variables located in Tcl files , Tcl)" pref.tcl
, ; ( modelsim.tcl ,
,
,
, ;
" Preference variables ,
located in Tcl files ( Tcl)" modelsim.tcl
Environment variables accessed during startup( ) , , ,
. . " Environment variables (
)"
. MODEL_TECH
ModelSim
, (
, ../modeltech /
platform < > /) MODEL_TECH_ OVERRIDE MODELSIM MGC_WD MGC_LOCATION_MAP
; MODEL_TECH – modelsim.ini Mentor Graphics ; ModelSim,
MODEL_TECH_TCL
Tcl, ModelSim
HOME MGC_HOME TCL_LIBRARY
( MGC ModelSim
UNIX)
Tcl; MODEL_TECH_TCL; 419
,
Model Technology Tk; ModelSim MODEL_TECH_TCL; , Model Technology [incr] Tcl; ModelSim MODEL_TECH_TCL; , Model Technology [incr] Tk; ModelSim MODEL_TECH_TCL; , Model Technology Tcl, ModelSim; ModelSim MODEL_TECH_TCL; , Model Technology mti_trace_cosim, FLI/PLI/VPI; . Tcl, ModelSim modelsim.tcl ; ё , (Windows) (UNIX)
TK_LIBRARY
ITCL_LIBRARY
ITK_LIBRARY
VSIM_LIBRARY
MTI_COSIM_TRACE
MTI_LIB_DIR MODELSIM_TCL (
Initialization sequence(
) ModelSim. ,
. , (
MTI_LIB_DIR, ,
Tcl). $(NAME) $ (MTI_LIB_DIR)
( Tcl).
1 MODEL_TECH , , MODEL_TECH MODEL_TECH_OVERRIDE 2 • • • • • •
(../modeltech / < platform > /). MODEL_TECH_OVERRIDE
modelsim.ini,
:
MODELSIM ; $(MGC_WD)/modelsim.ini; ./modelsim.ini; $(MODEL_TECH)/modelsim.ini; $(MODEL_TECH)/../modelsim.ini; $(MGC_HOME)/lib/modelsim.ini; 420
•
,
. /modelsim.ini ,
3 •
:
MGC_LOCATION_MAP "no_map", ModelSim
• • • • • • • •
(
);
mgc_location_map ; $(HOME)/mgc/mgc_location_map; $(HOME)/mgc_location_map; $(MGC_HOME)/etc/mgc_location_map; $(MGC_HOME)/shared/etc/mgc_location_map; $(MODEL_TECH)/mgc_location_map; $(MODEL_TECH)/../mgc_location_map; no map [vsim] modelsim.ini "
4 " [vsim]
. .
, .
5 ModelSim
,
:
6 • • • • • • •
MODEL_TECH_TCL ; MODEL_TECH_TCL=$(MODEL_TECH)/../tcl TCL_LIBRARY=$(MODEL_TECH_TCL)/tcl8.3 TK_LIBRARY=$(MODEL_TECH_TCL)/tk8.3 ITCL_LIBRARY=$(MODEL_TECH_TCL)/itcl3.0 ITK_LIBRARY=$(MODEL_TECH_TCL)/itk3.0 VSIM_LIBRARY=$(MODEL_TECH_TCL)/vsim Tcl
7
.
(
8
, ).
modelsim.ini .
Tcl "MTI_LIB_DIR"=MODEL_TECH_TCL
9 10
$(MTI_LIB_DIR)/pref.tcl. , project init , , (Windows) $ (HOME) /.modelsim (UNIX).
11 12
:
modelsim.tcl,
•
MODELSIM_TCL , ,
(
MODELSIM_TCL ,
); •
./modelsim.tcl; 421
•
$(HOME)/modelsim.tcl .
modelsim.ini : • [vcom],
ModelSim, modelsim.ini.
[vlog]
[
],
vmap, . • pref.tcl [GetPrivateProfileString]. .ini, , pref.tcl.
.ini
Tcl ,
F - Tips and Techniques(
) /
–nodebug
(DO
)
bit_vector 32-
64422
HP-UX 10.2 Sun/Solaris
VHDL
, , .
How to use checkpoint/restore( / ) checkpoint (CR-82)
restore (CR-204) vsim
vsim. restore (CR-
vsim, 204) ,
" warm restore(
) ". -
vsim , -restore
vsim (CR-296)
" cold restore(
) ".
423
/
: ,
, .
, , .
, :
restore • • vsim.wlf •
,
•
VHDL
•
,
Verilog $fopen
• •
PLI ,
:
• •
,
( Tcl)
• • ,
,
checkpoint , ,
:
restore ModelSim, : vsim -restore [-nocompress]
vsim
. , ,
Tcl.
:
424
set CheckpointCompressMode 0 ,
:
set CheckpointCompressMode 1 , 0
[vsim] (
modelsim.ini 1):
[vsim] CheckpointCompressMode = , ,
checkpoint/restore. .
FLI
The difference between checkpoint/restore and restarting ( / ) , VHDL
restart (CR-202) ,
,
Verilog $fopen. . ,
. ,
,
checkpoint/restore.
Using macros with restart and checkpoint/restore (
checkpoint/restore.) ,
restart (CR-202) , .
restart
.. ,
. ,
, . checkpoint/restore
checkpoint (CR-82)
,
ModelSim, restore (CR-
204) . ,
checkpoint
restore
.
Running command-line and batch-mode simulations ( ) 425
ModelSim GUI (
:
).
ModelSim: GUI, . •
,
:
GUI -
;
, .
,
,
-
.
• ,
; .
vsim UNIX
c
, DOS WINDOWS .
-
• UNIX ,
,
, , vsim
. ,
“ Windows , vsim
-
”.
-c. WINDOWS .
“here-
document”: vsim ent arch / < Project_Name > .mpf).
MODELSIM
Batch mode(
) ModelSim
,
,
stdout. ,
stdin –c vsim ,
-c .
Tcl user_hook
Tcl
. "Making the button persistent(
)"
.
Source code security and -nodebug( nodebug) -nodebug .
vcom (CR-250)
–
vlog (CR-286) -
. :
-nodebug ,
. Verilog,
protect Cadence,
ModelSim , Model Technology. 427
,
Source
-nodebug, Structure
, Signals Process
),
( ,
Variables
. , Dataflow
ModelSim. ,
-nodebug -nodebug
.
, vsim (CR-296) .
, , ,
-nodebug ,
-nodebug. , .
-nodebug,
vcom -nodebug=ports vlog -nodebug=ports vlog -nodebug=pli
VHDL Verilog PLI
vlog nodebug=ports+pli ( =pli+ports)
-nodebug=ports
:
-nodebug=pli
,
=ports ;
,
.
, -nodebug=ports , -nodebug. vcom (VHDL ). PLI Verilog.
= pli
,
Saving and viewing waveforms in batch mode( ) ,
vsim . 1
vsim, WLF (wave log format),
,
-wlf, stdin, :
.
vsim - wlf wavesav1.wlf counter < command.do command.do,
log (CR-164), ,
428
,
.
,
vsim
,
. ,
2
,
vsim :
.wlf vsim -view wavesav1.wlf
Waveform
List
.
Setting up libraries for group use ( “
”
, ModelSim
modelsim.ini . modelsim.ini, “
,
)
”
.
: [library] asic_lib = /cae/asic_lib work = my_work others = /usr/modeltech/modelsim.ini
Using a DO file to test for assertions ( DO
)
onbreak (CR-177) DO .
,
, BreakOnAssertion ( " ). ;
" [vsim] .
,
onbreak
: set broken 0 onbreak { set broken 1 resume } run -all if { $broken } { puts "failure" } else { puts "success" }
Sampling signals at a clock change( ) 429
add list (CR-48 )
, notrigger. -notrigger
-
.
:
add list clk -notrigger a b c ,
List
clk, a, b,
.
clk
,
:
List
1
, .
2 , Builder(
"
"
List, " Configuring a List trigger with Expression )"
. List
Converting signal values to strings( ) . " idle(
) ".
, virtual type (CR-283)
, .
,
GUI.
: ,
1
:
virtual type { state0 state1 state2 state3} myState 2 virtual function {(mystate)mysignal} myConvertedSignal 3 add wave myConvertedSignal myConvertedSignal "state0" mysignal == 0, "state1" mysignal == 2, . . virtual type (CR-283) .
Wave, List Signals, mysignal == 1, "state2" К
ModelSim
Converting an integer into a bit_vector( bit_vector) ,
bit_vector.
library ieee; 430
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 Simulation Options , modelsim.ini , , Tcl IterationLimit . . " Preference variables located in INI files( , INI )" modelsim.ini. . " Preference variables 434
located in TCL files(
,
TCL
Tcl
)"
.
,
.
,
,
.
, .
-
,
,
,
.
Referencing source files with location maps (
) ,
. . ModelSim, , •
: , .
•
,
, .
, . , .
,
,
-
Using location mapping(
) , . .
ModelSim , MGC_LOCATION_MAP. MGC_LOCATION_MAP , ModelSim , "mgc_location_map" ,
:
• • • •
,
ModelSim ModelSim
435
,
:
1
MGC_LOCATION_MAP
. 2
:
$SRC /home/vhdl/src /usr/vhdl/src $IEEE /usr/modeltech/ieee
Pathname syntax(
) $,
/. .
, (
).
How location mapping works( ) ,
, .
, ,
. , "/usr/vhdl/src/test.vhd"
. ,
" $SRC/test.vhd ". ,
.
. , ModelSim , (
). ModelSim
,
. , ModelSim
. ,
ё "/home/vhdl/src".
Mapping with Tcl variables( Tcl SourceMap.
SRC, ModelSim
Tcl)
, ; SourceDir . http://www.model.com/resources/pref_variables/frameset.htm. 436
Improve performance by locking memory on HP-UX 10.2 ( UX 10.2) ModelSim 5.3 10.2
,
HPHP-UX
. -
500
(.
>
2x
.)
Configuring memory locking(
)
,
HP-UX 10.2,
. .
1 ,
,
.
MLOCK,
, ModelSim:
/usr/sbin/setprivgrp -g MLOCK MLOCK,
:
/usr/sbin/setprivgrp MLOCK .
.
MLOCK,
2 modelsim.ini,
[vsim]:
LockedMemory = ,
, , vsim
.
, .ini).
(
Limitations(
)
ModelSim
. ,
( ModelSim , ,
: ) - 100 , ,
=
. . . 437
System parameter setting(
)
,
/ (
)
"sam" ,
, HP-UX. "Kernel Configuration"). .
"Configurable Parameters" ( ,
,
. "shmmin"
"shmmax" "shmseg"
"shmem"
1.
. ,
ok. .
Improve performance of large simulations on Sun/Solaris( Sun/Solaris) ModelSim 5.5b Sun/Solaris
. Verilog, .
Enabling shared memory( ) ,
: ,
1 /etc/system: set shmsys:shminfo_shmmax=0xffffffff .
2 ,
3 vshminit (
, modeltech).
.
,
, vshminit
,
:
/sunos5/vshminit 700 700 ё.
. ,
,
: vshminit .(
ё
,
.)
. ,
vshminit, 438
.
50-80 % ,
, .
,
:
vshminit,
/bin/ipcrm -M 0x10761364
How it works(
)
Solaris,
TLB, .
, TLB -
,
OS, .
TLBs
, ;
TLB Solaris), ,
(8192 524,288 .
4GB
, TLB. (pothole)-
TLB .
TLB
-
,
. OS ( ),
, HP, . .
Solaris
. , Solaris
«
» OS, TLB.
,
, , OS TLB
. -
,
,
. , uses/frees/reclaims . ,
,
, ,
. (vshminit),
, ,
vsim. ,
, .
ipcrm (
) ,
ё
. vshminit
,
, ё
, ,
.
Performance affected by scheduled events being cancelled( ё ) 439
, ,
, .
,
.
VHDL
.
–
. : signals synch : bit := ’0’; ... p: process begin wait for 10 ms until synch = 1; end process; synch -
.
,
write wave (CR-329)
$w xwaveview
Wave.
.
$w xview ...
Wave tree zoom commands( Wave) Wave. $w zoomstart $w zoomdrag $w zoomend .
zoomstart zoomdrag, .
zoomend ,
,
.
$w zoomfull , . $w zoomlast .
. 460
$w zoomrange [ ] , . / zoomrange ё
, . , .
ASCII, ,
. $w zoomscale [ []] , 1.
$w waveconfig -wavescale. ,
- 0, .
. zoomscale
,
.
Wave tree cursor commands(
Wave) Wave.
$w addcursor ё
Wave.
10
Wave
. $w cursorcount ,
.
$w deletecursor . $w dragcursor [snap] , c
< y>.
"snap",
.
$w getactivecursortime . $w getcursortime .
,
1.
$w grabcursor
461
.
< y> $w releasecursor ,
.
Tree widget default bindings( ) Tk
ё
, – Motif(
ё
UNIX).
Mode, . ,
.
1
,
. ,
1. ,
,
.
1
,
, .
,
1
,
, ;
1 ,
. ;
,
, .
, : , Shift:
1
,
.
,
. Control ,
1
: –
ё
,
.
. 1,
; ,
,
. 1,
, .
,
ё
,
,
,
. 2,
. , .
Up
Down
,
( .
) 462
, . . , Shift-Up
Shift-Down
) ,
1
( .
, .
MTI vlist widget(
MTI vlist )
-vlist ,
,
,
. , . , .
vlist
,
List ModelSim. vlist ,
.
,
.
Vlist
STRING; Tcl. , ,
.
, ,
vlist
. ;
,
. Vlist xScrollCommand
, yScrollCommand.
Vlist widget commands (
Vlist)
,
vlist MTI.
, "$w"
vlist.
$w activate ,
.
,
.
$w addmarker ё
vlist.
10
vlist. $w busy 0|1 1, $w cget
.
.
463
, " Vlist widget options(
,
Vlist
)" . $w configure [] [] [ ...] . , Tk_ConfigureInfo
pathName ( ).
.
,
,
,
/ ( )
,
.
. ,
" Vlist widget options(
Vlist )" . $w curselection ,
, ,
. . $w delete [] . ( ,
, .
, $w remove .
).
$w deletemarker . $w down [-noglitch] [-value ] [] vlist .
,
, ,
.
, , seetime (CR-214)
down. , 138)
. down (CR-
.(
.)
$w find [-reverse] [-all] [-field ] [-toggle] ... . 210) .
search (CR-
$w fixwidth n
. 464
$w get [] , .
.
,
,
, .
$w getactivemarkertime . $w getfontheight . $w getheaderheight ,
.
$w getmarkertime [-delta] ,
. ,
- delta
1.
.
$w gotomarker ,
.
,
.
$w grabmarker < dragging > - 0, .
,
ё < dragging > - 1,
, .
$w index ,
,
. $w insert [...] ... , .
.
"
",
add list (CR-48),
, :
.
.
$w itemcget 465
ё
.
$w itemconfigure [] []... "
"
, . , / (
)
. ,
.
,
,
.
. :
-width
-label -radix Radix value used when displaying bus values. Must be one of
-position -trigger 0|1
, ,
, .
, . "symbolic", "binary", "octal", "decimal" (interpreted as signed),"unsigned", "hexadecimal"(" ", " ", " ", " "( ), " ", " " , . 1, . 0, .
$w itemindex , .
, $w index.
$w iteminfo .
$w markercount ,
.
$w next $w find . $w pack
466
. $w property [ ]* pre-5.0 " .list sig_prop ... " .
.
$w quickupdate vlist
.
$w remove | ... , $w delete.
$w delete, .
),
$w restart ,
. ,
$w restartprepare . $w restartprepare .
. $w save Save the vlist format information to file vlist
.
$w see vlist ,
,
,
.
.
,
-
,
.
,
.
$w seetime [-select] , - select, ,
. .
.
$w selection anchor , –
.
, "anchor"
. .
$w selection clear [] 467
(
Run (
) 5.6. Main).
477
Compare menu( Compare
)
5.6. Tools > Waveform Compare (
Macro menu(
)
Macro
5.6.
Options menu( Options
Main).
) 5.6.
478
Dataflow window changes ( Dataflow,
ё
5.6 . .
Dataflow) Dataflow " Dataflow window ( Dataflow) " 4)
List window changes(
List) List 5.6.
Edit menu(
) Edit 5.6.
479
Markers menu( .
)
Markers
5.6.
Prop menu( Prop
) 5.6.
480
Signals window changes(
Signals) Signals 5.6.
Edit menu (
) Edit
View menu (
View 5.6.
) View
Add 5.6.
Context menu (
) Tools 5.6.
Source window changes(
Source)
Source
5.6.
Source) "
" Source window (
.
File menu(
)
Compile
File
Edit menu(
)
Breakpoint
Edit
Object menu ( Object
Tools 5.6.
Tools 5.6.
) 5.6. 481
Options menu( Options
) -
Tools 5.6.
Structure window changes(
Structure)
Structure 5.6 Edit
Sort,
View.
Variables window changes(
Variables) Variables 5.6.
Edit menu (
) Edit
View menu(
View 5.6.
) Add.
Wave window changes(
Wave)
Menu bar and toolbar (
) Wave
5.6.
" The Wave window menu bar ( .
File menu (
Wave) "
)
File menu File 5.6.
482
Edit menu (
)
" The Wave window menu bar( .
Cursor menu ( Cursor
Wave) "
) 5.6.
483
Zoom menu ( Zoom View > Zoom (
) 5.6. Wave).
Compare menu ( Compare
)
5.6. Tools > Waveform Compare (
Bookmark menu ( Bookmark
Wave).
) 5.6.
484
License Agreement(
)
,
-
"
"
,
, ,
Mentor Graphics, Mentor Graphics ( Limited,
, ) Limited, Mentor Graphics ( ) Private ( " Mentor Graphics "). , .
,
,
,
10
1.
. ,
, ,
,
("
,
,
")
, Mentor Graphics (licensors), ,
, .
Mentor Graphics
, ,
,
, : (a) (
-
, ;
(c)
,
, Mentor Graphics. Mentor Graphics, , , : ; ,
(a) (b) ё
; (b)
,
( 800
).
,
( ); (c) (d)
,
,
;
.
.
2. .
(ESD)
, (ESD - Embedded Software , Mentor Graphics , , ESD
Development)
ESD,
C
, , C++ ESD,
, . Mentor Graphics Mentor Graphics ESD, Mentor Graphics
,
.
3. BETA 3.1. ("Beta "), Mentor Graphics. Graphics , Mentor Graphics
Mentor ,
, ,
Beta , Beta
Mentor Graphics. Beta
, 3.2.
Mentor Graphics
, , Mentor Graphics,
Mentor Graphics. Beta ё
Mentor Graphics . Beta
Beta
,
,
. Mentor Graphics
Beta .
, 3.3.
,
,
, ,
,
, Mentor Graphics
, ,
,
, Mentor Graphics. Mentor Graphics , . . 534
4.
. .
,
ё
, Mentor
Mentor Graphics. Graphics
. ,
,
, Mentor Graphics
. , ,
, Mentor Graphics,
. ,
.
,
, E ,
,
, . ,
, Mentor Graphics. . 5. 5.1. Mentor Graphics ,
, , , . Mentor Graphics
, .
- 90
,
15-
,
.
Mentor
Graphics .
, , . MENTOR GRAPHICS
,
MENTOR GRAPHICS , (A)
MENTOR GRAPHICS
,
(B) , ,
, .
MENTOR GRAPHICS : (A)
; (B)
, 535
; BETA
; "
5.2.
, .
(C)
.
"
5 MENTOR GRAPHICS , Ё
Ё LICENSORS ,
, LICENSORS
. MENTOR GRAPHICS
.
6.
. , , MENTOR , ( ,
GRAPHICS
LICENSORS ,
, )
,
MENTOR GRAPHICS
LICENSORS , ,
.
Ё LICENSORS' ,
MENTOR GRAPHICS
. , , MENTOR GRAPHICS
LICENSORS .
7
., MENTOR GRAPHICS ,
. LICENSORS ,
LICENSORS
,
. MENTOR GRAPHICS , , , ,
,
, .
8. 8.1. Mentor Graphics ё
, ,
,
,
, ,
,
, 536
,
,
,
,
. Mentor Graphics , , : (a) ; (b) , Mentor Graphics
, , Mentor Graphics Mentor Graphics ;
(c)
. 8.2.
, Mentor Graphics
,
,
, ,
(b) .
Mentor Graphics
, ,
Mentor Graphics , . ё
8.3. Mentor Graphics
,
: (a) Graphics; (b) (c)
,
Mentor
Mentor Graphics; , ;
(d) (e) (f) (g) ,
;
ё ; Beta
,
; ,
8.4. GRAPHICS
Mentor Graphics Mentor Graphics.
8 LICENSORS
MENTOR
. 9.
. .
, ,
,
, 30
Mentor Graphics. ё
, .
,
,
Mentor Graphics , Mentor Graphics.
537
10.
. , , ,
. , , .
11.
. , .
,
, , DFARS 227.7202-3 (a) Computer Software – / , Wilsonville,
( C) (1)
(2) Commercial Restricted Rights FAR 52.227-19, . Mentor Graphics, 8005 Boeckman Road, 97070-7777 .
12.
. ,
Mentor Graphics licensor -
licensors, Microsoft
Microsoft
, . 13.
. , , ,
E
,
,
,
,
, , ,
,
, ,
,
,
,
,
, -
. 14.
(SEVERABILITY). ,
,
,
, . 15.
. , ,
,
,
, ,
Mentor Graphics. Mentor Graphics.
538
. , ,
, .
539
540