DVT SystemVerilog IDE User Guide Rev. 3.5.32 18 December 2014 Technical Support: [email protected] Copyright (C) 2005-2014 AMIQ EDA s.r.l. (AMIQ). All rights reserved. License: This product is licensed under the AMIQ's End User License Agreement (EULA). Trademarks: The trademarks, logos and service marks contained in this document are the property of AMIQ or other third parties. DVT™, eDT™, VlogDT™, VhdlDT™ Verissimo™ are trademarks of AMIQ. Eclipse™ and Eclipse Ready™ are trademarks of Eclipse Foundation, Inc. All other trademarks are the property of their respective holders. Restricted Permission: This publication is protected by copyright law. AMIQ grants permission to print hard copy of this publication subject to the following conditions: 1.The publication may not be modified in any way. 2. Any authorized copy of the publication or portion thereof must include all original copyright, trademark, and other proprietary notices and this permission statement. Disclaimer: This publication is for information and instruction purposes. AMIQ reserves the right to make changes in specifications and other information contained in this publication without prior notice. The information in this publication is provided as is and does not represent a commitment on the part of AMIQ. AMIQ does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy, or usefulness of the information contained in this document. The terms and conditions governing the sale and licensing of AMIQ products are set forth in written agreements between AMIQ and its customers. No representation or other affirmation or fact contained in this publication shall be deemed to be a warranty or give rise to any liability of AMIQ whatsoever. DVT SystemVerilog IDE www.dvteclipse.com Table of Contents 1. Installation Checklist .......................................................................................................... 1 2. Predefined Projects ............................................................................................................. 5 3. Getting Started .................................................................................................................... 9 3.1. What is a Workspace ............................................................................................... 9 3.2. What is a Project ..................................................................................................... 9 3.3. Project Natures ....................................................................................................... 10 3.4. Workspace and Workbench ................................................................................... 11 3.5. Refresh ................................................................................................................... 12 3.6. Linked Resources ................................................................................................... 13 3.7. Backup and Local History ..................................................................................... 14 3.8. Basic Tutorial ......................................................................................................... 15 3.8.1. Switch to the DVT Perspective .................................................................. 15 3.8.2. Open a Project ............................................................................................ 17 3.8.3. Configure the Build .................................................................................... 18 3.8.4. Build the Project ......................................................................................... 19 3.8.5. Inspect the Compilation Errors ................................................................... 19 3.8.6. See Comments in Tooltips .......................................................................... 21 3.8.7. Use Hyperlinks to Move Around in the Code ............................................ 23 3.8.8. Quickly Open a Type (Class, Module, Interface) ....................................... 24 3.8.9. Quickly Inspect the Class Hierarchy .......................................................... 24 3.8.10. Quickly Open a File ................................................................................. 25 3.8.11. Quickly Move Inside the Editor ............................................................... 27 3.8.12. Inspect the Class Hierarchy and Class Members ...................................... 28 3.8.13. Inspect the Design Hierarchy .................................................................... 29 3.8.14. Inspect the Verification Hierarchy ............................................................ 30 3.8.15. Browse Through All the Available Types (Classes, Modules, Interfaces) .............................................................................................................. 31 3.8.16. Look for the Implementation of an Extern Function or Task .................... 32 3.8.17. Search for Entities .................................................................................... 33 3.8.18. Use Content Assist (Autocomplete) .......................................................... 34 3.8.19. Use Code Templates ................................................................................. 35 3.8.20. Use Module Auto Instance ....................................................................... 37 3.8.21. Expand Macros (Apply Preprocessing) .................................................... 38 3.8.22. Trace Macro Errors ................................................................................... 39 3.8.23. Track Tasks using TODO Markers ........................................................... 40 3.8.24. Quickly See the Current Scope in the Status Bar ..................................... 40 3.8.25. Fold Code Regions in Order to Improve Readability ............................... 41 3.8.26. Access the Context Sensitive Help ........................................................... 41 4. Build Configurations ......................................................................................................... 43 4.1. default.build ........................................................................................................... 43 4.2. Emulating compiler invocations ............................................................................ 44 4.3. Multiple .build Files ............................................................................................... 44 4.4. Compatibility Modes ............................................................................................. 46 4.4.1. Default DVT Compatibility Mode .............................................................. 47 4.4.2. vcs.vlogan Compatibility Mode .................................................................. 49 4.4.3. vcs.vhdlan Compatibility Mode .................................................................. 50 © AMIQ i Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com 4.4.4. ius.irun Compatibility Mode ....................................................................... 50 4.5. Paths ....................................................................................................................... 54 4.6. Strings .................................................................................................................... 54 4.7. Comments .............................................................................................................. 55 4.8. Environment Variables .......................................................................................... 55 4.9. Including Other Argument Files ............................................................................ 56 4.10. Build Persistence .................................................................................................. 56 4.11. DVT Auto-Linked ................................................................................................ 58 4.12. Run a Script Before Build ................................................................................... 59 4.13. All Build Directives ............................................................................................. 60 4.14. e Language Test Files .......................................................................................... 69 4.15. e Language SPECMAN_PATH ........................................................................... 69 4.16. SystemVerilog OVM or UVM Library Compilation ........................................... 70 5. Compile Checks ................................................................................................................ 72 5.1. Compile Waivers ................................................................................................... 72 5.2. Semantic Checks .................................................................................................... 74 5.3. Non Standard Checks ............................................................................................ 77 6. Content Assist (Autocomplete) ......................................................................................... 84 6.1. Content assist for CamelCase and Underscore ...................................................... 85 6.2. Code Templates ..................................................................................................... 85 6.3. Module Automatic Instantiation ............................................................................ 86 6.4. Override Functions Using Autocomplete .............................................................. 87 7. Content Filters .................................................................................................................. 88 7.1. Content Filters XML syntax .................................................................................. 88 7.2. Content Filters Examples ....................................................................................... 91 7.3. Predefined Content Filters ..................................................................................... 92 8. Code Templates .............................................................................................................. 101 8.1. Code Templates in Autocomplete ....................................................................... 101 8.2. Global Code Templates ....................................................................................... 102 8.3. Project Level Code Templates ............................................................................. 102 8.4. Code Templates View .......................................................................................... 103 9. File Templates ................................................................................................................ 106 10. Project Templates ......................................................................................................... 107 10.1. What is a project template? ............................................................................... 107 10.2. How to generate code from a project template .................................................. 108 10.2.1. Step 1. Specify Directories ..................................................................... 108 10.2.2. Step 2. Specify Parameters ..................................................................... 109 10.3. template.config ................................................................................................... 110 10.4. Add from Template ........................................................................................... 110 11. Code Formatting ........................................................................................................... 113 11.1. Whitespace ......................................................................................................... 113 11.2. Indentation .......................................................................................................... 113 11.3. Vertical Alignment ............................................................................................. 114 11.4. Line Wrapping ................................................................................................... 115 11.5. External .............................................................................................................. 116 12. Override Functions ....................................................................................................... 117 12.1. Override Annotation .......................................................................................... 117 12.2. Inspect Overrides in the Quick Type Hierarchy View ....................................... 117 © AMIQ ii Rev. 3.5.32 DVT SystemVerilog IDE 13. 14. 15. 16. 17. 18. 19. 20. 21. www.dvteclipse.com 12.3. Inspect Overrides in the Layers View ............................................................... 12.4. Override Using the Dialog ................................................................................. 12.5. Override Using Autocomplete ........................................................................... 12.6. Override Using the Type Hierarchy View ......................................................... Generate Getters and Setters ........................................................................................ Module Automatic Instantiation ................................................................................... 14.1. Autoinstance Using Autocomplete .................................................................... 14.2. Autoinstance Using Drag and Drop ................................................................... Semantic Search ............................................................................................................ Search for References (Usages) .................................................................................... Quick Search in Views ................................................................................................. 17.1. CamelCase .......................................................................................................... 17.2. Simple Regex ..................................................................................................... 17.3. Hierarchical Search ............................................................................................ 17.4. Search for Members ........................................................................................... 17.5. Search Port in Design Hierarchy ....................................................................... 17.6. Search Port in Verification Hierarchy ............................................................... 17.7. Search all UVM Phase Overrides ...................................................................... 17.8. Search Global API ............................................................................................. Trace Port Connections ................................................................................................ 18.1. Trace Connections from Design Hierarchy ....................................................... 18.2. Trace Connections from Editor ......................................................................... 18.3. Trace Connections View .................................................................................... 18.4. Trace Path .......................................................................................................... Code Factory ................................................................................................................. Refactoring .................................................................................................................... 20.1. Rename Refactoring ........................................................................................... 20.2. Refactoring Scripts ............................................................................................. 20.2.1. Writing a Refactoring Script ................................................................... 20.2.2. Applying a Refactoring Script ................................................................ 20.3. Connect Instances Across the Design Hierarchy ............................................... 20.3.1. Connect Instances Using New Ports ....................................................... 20.3.2. Connect Instances Using Existing Ports ................................................. 20.3.3. Preview Structural Changes in the Design Hierarchy ............................. 20.3.4. Connect Instances Toolbar ...................................................................... 20.4. Add Port to Module from Selected Field .......................................................... 20.5. Add New Port to Module .................................................................................. Diagrams ....................................................................................................................... 21.1. Class Diagrams .................................................................................................. 21.1.1. Class Diagrams - Select Classes ............................................................. 21.1.2. Class Diagrams - Preferences ................................................................. 21.1.3. Class Diagrams - Legend ........................................................................ 21.2. Architecture UML Diagrams ............................................................................. 21.3. Sequences UML Diagrams ................................................................................ 21.4. Module Diagrams ............................................................................................... 21.4.1. Module Diagrams - Select Modules ....................................................... 21.4.2. Module Diagrams - Preferences .............................................................. 21.4.3. Module Diagrams - Breadcrumb Navigation .......................................... © AMIQ iii 118 119 120 120 122 124 124 124 125 127 128 128 129 129 131 133 134 135 136 138 138 138 140 143 146 147 147 148 148 150 152 152 155 157 160 161 161 163 163 164 166 167 168 169 169 173 175 183 Rev. 3.5.32 DVT SystemVerilog IDE 22. 23. 24. 25. www.dvteclipse.com 21.5. Diagram Toolbar ................................................................................................ 21.6. Diagram Preferences .......................................................................................... Export HTML Documentation ...................................................................................... 22.1. Export HTML Documentation Wizard .............................................................. 22.2. Comments Formatting ........................................................................................ 22.2.1. JavaDoc ................................................................................................... 22.2.2. NaturalDocs ............................................................................................. 22.3. Customizing Documentation .............................................................................. External Tools Integration ............................................................................................ 23.1. Run Configurations ............................................................................................ 23.1.1. Run Configuration Session Type ............................................................ 23.1.2. Custom Shortcut and Button for a Run Configuration ............................ 23.1.3. Using environment variables in DVT Generic Run Configurations ........ 23.1.4. Using an alias in a DVT Generic Run Configuration ............................. 23.1.5. DVT Generic Run Configuration Variables ........................................... 23.2. Smart Log .......................................................................................................... 23.2.1. Smart Log - Filters ................................................................................. 23.2.2. Smart Log - Hyperlinks .......................................................................... 23.2.3. Smart Log - Styles .................................................................................. 23.3. External Builders ............................................................................................... 23.3.1. How to define a new external builder ..................................................... 23.3.2. How to invoke external builders ............................................................. 23.3.3. External Builder Output .......................................................................... 23.3.4. Source Code Markers - errors warnings ................................................. 23.4. External Documentation .................................................................................... 23.4.1. Configure External Documentation ........................................................ 23.4.2. Browse External Documentation ............................................................ 23.4.3. Search External Documentation .............................................................. Custom Dialogs ............................................................................................................. 24.1. Quick Steps ........................................................................................................ 24.2. Customizing the Dialog Output ......................................................................... 24.3. SWT/XML Reference ........................................................................................ 24.3.1. Layouts .................................................................................................... 24.3.2. Widgets ................................................................................................... Command Line Interface .............................................................................................. 25.1. dvt_cli.sh ............................................................................................................ 25.2. Syntax ................................................................................................................. 25.3. Notes .................................................................................................................. 25.4. Examples ............................................................................................................ 25.5. Makefile Example .............................................................................................. 25.6. Commands .......................................................................................................... 25.6.1. Create a Project (Mixed-Language Capable) .......................................... 25.6.2. Create a Project From an Existing Template .......................................... 25.6.3. Import an Existing Project ...................................................................... 25.6.4. List Compiled Files ................................................................................. 25.6.5. Launch a Run Configuration .................................................................. 25.6.6. Open a File ............................................................................................. 25.6.7. Open a Custom Dialog ........................................................................... © AMIQ iv 183 183 185 185 190 191 195 196 198 198 201 203 204 205 205 207 207 210 213 214 214 217 217 218 219 220 220 221 222 224 224 227 228 229 235 235 235 236 236 237 237 237 239 239 239 240 240 240 Rev. 3.5.32 DVT SystemVerilog IDE 26. 27. 28. 29. www.dvteclipse.com 25.6.8. Refresh a project ..................................................................................... 25.6.9. Quit .......................................................................................................... 25.6.10. Query the running status ....................................................................... 25.6.11. Print version .......................................................................................... Macros Support ............................................................................................................. 26.1. Inactive Code Highlight ..................................................................................... 26.1.1. Overview ................................................................................................. 26.1.2. Settings .................................................................................................... 26.2. Macro Expansion ............................................................................................... 26.2.1. Overview ................................................................................................. 26.2.2. Triggering ................................................................................................ 26.2.3. Tips .......................................................................................................... 26.2.4. IMPORTANT NOTE .............................................................................. 26.3. Macros and Quick Macros Views ..................................................................... Reminders (TODO Markers) ........................................................................................ OVM Support ............................................................................................................... 28.1. OVM Compliance Review ................................................................................. 28.1.1. Architecture Tab ..................................................................................... 28.1.2. Checks Tab ............................................................................................. 28.1.3. Statistics Tab ........................................................................................... 28.1.4. Waivers Tab ............................................................................................ 28.1.5. HTML Report ......................................................................................... 28.1.6. Problems View Integration ..................................................................... 28.2. OVM Field Editor .............................................................................................. 28.2.1. Triggering ................................................................................................ 28.2.2. Interface ................................................................................................... 28.2.3. Problems .................................................................................................. 28.2.4. Tips .......................................................................................................... 28.3. OVM Smart Log ................................................................................................ 28.4. Quick OVM Documentation Access ................................................................. 28.5. OVM Templates ................................................................................................. UVM Support ............................................................................................................... 29.1. UVM Browser .................................................................................................... 29.2. UVM Compliance Review ................................................................................. 29.2.1. Architecture Tab ..................................................................................... 29.2.2. Checks Tab ............................................................................................. 29.2.3. Statistics Tab ........................................................................................... 29.2.4. Waivers Tab ............................................................................................ 29.2.5. HTML Report ......................................................................................... 29.2.6. Problems View Integration ..................................................................... 29.3. UVM Content Filters ......................................................................................... 29.4. UVM Factory Queries ....................................................................................... 29.5. UVM Field Editor .............................................................................................. 29.5.1. Triggering ................................................................................................ 29.5.2. Interface ................................................................................................... 29.5.3. Problems .................................................................................................. 29.5.4. Tips .......................................................................................................... 29.6. UVM Smart Log ................................................................................................ © AMIQ v 240 241 241 241 242 242 242 242 243 243 243 244 245 245 246 247 247 248 248 249 250 252 256 256 256 256 258 259 259 260 260 262 262 265 266 266 267 268 269 273 273 273 276 276 276 278 279 279 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com 29.7. UVM Templates ................................................................................................. 280 29.8. UVM Verification Hierarchy ............................................................................. 280 29.9. OVM to UVM Migration .................................................................................. 281 29.9.1. Triggering ................................................................................................ 281 29.9.2. Preferences .............................................................................................. 281 29.9.3. Review changes ...................................................................................... 282 30. VMM Support ............................................................................................................... 284 30.1. VMM Smart Log ............................................................................................... 284 30.2. Quick VMM Documentation Access ................................................................. 285 30.3. VMM Templates ................................................................................................ 285 31. Settings Management .................................................................................................... 287 31.1. Managed Settings ............................................................................................... 287 31.2. Unmanaged Settings .......................................................................................... 291 31.3. User and Common Settings Location ................................................................ 291 31.4. Use Cases ........................................................................................................... 292 31.4.1. Memory Allocation Thresholds .............................................................. 292 31.4.2. Workspace Preferences ........................................................................... 293 31.4.3. Run Configurations ................................................................................. 293 31.4.4. Compile Waivers .................................................................................... 293 31.4.5. Content Filters ......................................................................................... 293 31.4.6. External Builders .................................................................................... 293 31.4.7. Export HTML Documentation ................................................................ 294 31.5. Examples ............................................................................................................ 294 31.6. Deprecated Settings Management (before DVT 3.5) ......................................... 295 31.6.1. Workspace Settings ................................................................................. 295 31.6.2. Project Settings ....................................................................................... 295 31.6.3. Other Settings .......................................................................................... 296 31.6.4. Importing Preferences From a Different Workspace .............................. 296 31.6.5. Customizing Default Settings Using dvt.ini ............................................ 297 32. Reference ...................................................................................................................... 300 32.1. Common Shortcuts ............................................................................................. 300 32.2. Editor Right Click Menu ................................................................................... 301 32.2.1. Folding .................................................................................................... 301 32.2.2. Macros ..................................................................................................... 301 32.2.3. Source ...................................................................................................... 301 32.2.4. Code Factory ........................................................................................... 301 32.2.5. Show ........................................................................................................ 302 32.2.6. References ............................................................................................... 302 32.2.7. Trace ........................................................................................................ 302 32.2.8. Refactor ................................................................................................... 302 32.3. Icons and Decorations ........................................................................................ 302 32.3.1. Icons ........................................................................................................ 302 32.3.2. Decorations ............................................................................................. 304 32.4. Scripts ................................................................................................................. 304 32.4.1. dvt.sh ....................................................................................................... 304 32.4.2. dvt_cli.sh ................................................................................................. 306 32.4.3. dvt_from_rawtokens.sh ........................................................................... 306 32.4.4. dvt_kit_installer.sh .................................................................................. 307 © AMIQ vi Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com 32.4.5. dvt_updater.sh ......................................................................................... 308 32.5. Toolbar Actions ................................................................................................. 310 32.6. Views ................................................................................................................. 310 32.6.1. Checks View ........................................................................................... 310 32.6.2. Code Templates View ............................................................................. 312 32.6.3. Compile Order View ............................................................................... 312 32.6.4. Console View .......................................................................................... 313 32.6.5. Coverage View ........................................................................................ 314 32.6.6. Design Hierarchy View .......................................................................... 315 32.6.7. Layers View ............................................................................................ 319 32.6.8. Macros View ........................................................................................... 321 32.6.9. Outline View ........................................................................................... 322 32.6.10. Problems View ...................................................................................... 326 32.6.11. Tasks View ........................................................................................... 327 32.6.12. Trace Connections View ....................................................................... 329 32.6.13. Types View ........................................................................................... 329 32.6.14. Type Hierarchy View ............................................................................ 331 32.6.15. UVM Browser View ............................................................................. 334 32.6.16. Verification Hierarchy View ................................................................. 334 33. Tips and Tricks ............................................................................................................. 338 34. Application Notes ......................................................................................................... 370 34.1. Encrypted VIP Support ...................................................................................... 370 35. Q & A ........................................................................................................................... 371 35.1. I am new to Eclipse, where should I start from? ............................................... 371 35.2. Where can I find DVT Help? ............................................................................ 371 35.3. How do I see and configure the key shortcuts? ................................................. 371 35.4. Are there any backup files in Eclipse? .............................................................. 372 35.5. Workspace in use, cannot launch eclipse... ....................................................... 372 35.6. Locking is not possible in the directory... ......................................................... 372 35.7. How to start DVT Eclipse with a different eclipse.ini ....................................... 372 35.8. Save could not be completed ............................................................................. 373 35.9. IBM Clearcase Plugin ........................................................................................ 373 35.10. Non existing package mti_fli ........................................................................... 373 35.11. libxul.so undefined symbol .............................................................................. 374 35.12. How to use Working Sets for filtering Problems/Task/Search views? ............. 374 35.13. How can I do an incremental textual search in any view? ............................... 377 35.14. Diagram error - image has not been created .................................................... 377 35.15. How to handle Simulator and Command Line Macros .................................... 378 35.16. How do I Access Files Outside Project Dir - Working with Linked Resources ..................................................................................................................... 379 35.17. Mapping Linux to Windows (/proj/ to Z:\proj\) .............................................. 380 35.18. Subversive vs Subclipse ................................................................................... 380 35.19. How do I associate a project with both DVT and CDT? ................................. 381 35.20. Can I use vi/vim along with DVT? ................................................................. 381 35.21. Can I perform dos2unix or unix2dos from DVT? ........................................... 382 35.22. How can I configure Eclipse to use a local CVS repository? .......................... 382 35.23. I am using the Common Desktop Environment via Citrix and experiencing crashes. What can I do? .............................................................................................. 383 © AMIQ vii Rev. 3.5.32 DVT SystemVerilog IDE 36. 37. 38. 39. www.dvteclipse.com 35.24. How do I change the background color of the Editor? .................................... 383 35.25. How do I change the color of the interface? ................................................... 383 35.26. How to apply the dark color theme or other themes? ...................................... 383 35.27. How do I change the tooltip colors? ................................................................ 384 35.28. How do I change Internet Proxy Settings? ...................................................... 384 35.29. Eclipse does not start, there is no Workspace, metadata or log file created ..... 385 35.30. Workspace permissions .................................................................................... 385 35.31. How to install our server as a service in Windows? ........................................ 386 35.32. How do I link mylyn with Bugzilla? ............................................................... 386 35.33. How do I print source code? ........................................................................... 387 35.34. How do I disable Eclipse Software Sites? ....................................................... 388 35.35. How do I revert to a previous version? ........................................................... 388 35.36. What are the most common shortcuts in DVT? ............................................... 389 35.37. How does DVT integrate with emacs? ............................................................ 389 35.38. How does DVT integrate with CVS? .............................................................. 389 35.39. How to set an environment variable within a Run Configuration? .................. 389 35.40. How to run a remote Unix commnad from DVT Eclipse for Windows? ......... 390 35.41. Rebuild shortcut (Ctrl + Alt + R) does not work ............................................. 390 35.42. Sometimes I experience DVT GUI hangs, what should I do? ......................... 391 35.43. Sometimes I experience DVT GUI hangs when switching from another X application to DVT ..................................................................................................... 391 35.44. I want to use an alias in a DVT Generic Run Configuration, but it's not recognized .................................................................................................................... 392 35.45. How to set multiple paths as sources of predefined projects ? ......................... 392 35.46. Lines are suddenly changing indentation when I edit text or move the cursor through the editor. ....................................................................................................... 392 35.47. How to change the directory where the build log file is saved ? ...................... 393 35.48. How to find the DVT logs on Linux/Unix ? .................................................... 393 35.49. How to create resource filters ? ....................................................................... 393 35.50. How to create custom shortcut and button for a Run Configuration? .............. 394 35.51. I know that file.foo is present in the project location, but I can't see it in the Navigator View ........................................................................................................... 394 35.52. How to copy the full path to the file in the current editor? .............................. 395 35.53. How to adjust the console logs filters matching parameters? .......................... 395 35.54. When I switch to Block (Column) Selection mode the font changes ............... 395 35.55. In Block (Column) Selection mode I see strange editng artifacts .................... 396 35.56. How to modify the font size in the code editors? ............................................ 396 35.57. How to automatically checkout/lock files from the revision control system ? ...................................................................................................................................... 398 35.58. How can I see if a file is read-only? ............................................................... 398 35.59. How can I open a file in DVT from the terminal? .......................................... 399 35.60. How do I change the name of the xterm opened by a DVT Generic Run Configuration? ............................................................................................................. 399 What is New? ............................................................................................................... 401 How to Report an Issue? .............................................................................................. 529 Legal Notices ................................................................................................................ 530 Third Party Licenses ..................................................................................................... 531 © AMIQ viii Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com List of Tables 21.1. ..................................................................................................................................... 179 21.2. ..................................................................................................................................... 179 © AMIQ ix Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 1. Installation Checklist Eclipse Version You must use Eclipse 3.6 or newer. To check the Eclipse version use menu Help > About Eclipse Platform. In the snapshot the Eclipse version is 3.6. Java Version You must use Java 1.6 or newer. To check the Java version use menu Help > About Eclipse Platform, then click on Configuration Details and select Configuration tab. In the snapshot the Java version is 1.6. © AMIQ 1 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 1. Installation Checklist www.dvteclipse.com DVT Plug-in To check the DVT plugin is installed use menu Help > About Eclipse Platform. You should see the DVT button. © AMIQ 2 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 1. Installation Checklist www.dvteclipse.com To see more details, for example the version, click the button. DVT License To check the DVT license go to menu Window > Preferences and inspect the DVT > License. The DVT license is pointed to by $DVT_LICENSE_FILE system variable or in case of a FlexLM license by' $DVTLMD_LICENSE_FILE' and $LM_LICENSE FILE system variables. © AMIQ 3 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 1. Installation Checklist www.dvteclipse.com DVT is activated lazily. In other words it doesn't look for a license until you try to use its functionality. Before checking the license status, it is recommended to open a predefined project. © AMIQ 4 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 2. Predefined Projects The predefined projects capability allows you to quickly access pre-configured project repositories. For example training labs or golden reference projects or projects that you commonly use. DVT looks for predefined projects in the directory indicated by the $DVT_PREDEFINED_PROJECTS system variable. In order to support directories spread on the disk, DVT also scans all directories indicated by any other system variable whose name starts with $DVT_PREDEFINED_PROJECTS_EXT_. For example, if you installed DVT from a distribution, by default $DVT_PREDEFINED_PROJECTS points to $DVT_HOME/predefined_projects. This is a project repository that you can use to explore the DVT features without the initial effort of configuring a project. At any time, if you wish to change the default you just need to point $DVT_PREDEFINED_PROJECTS to location. Or add another pre-configured projects repository by $DVT_PREDEFINED_PROJECTS_EXT_MY_NEW_REPOSITORY to it. location, another pointing For example if you installed DVT as a plug-in on top of an existing Eclipse installation, $DVT_PREDEFINED_PROJECTS is unset. But you can download the predefined projects separately, and point the system variable to the folder where you extracted the predefined projects. Opening a Predefined Project To open a predefined project use the Predefined Project Wizard by selecting File > New > DVT Predefined Project. You can also open the wizard from the DVT Project Wizard by clicking on the Predefined Projects link: © AMIQ 5 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 2. Predefined Projects www.dvteclipse.com Preferences In the wizard's main window you can select the predefined project and the target directory. A copy of the selected project will be placed in the target directory. Keep in mind that: 1. The target directory must not be a parent of or inside of the eclipse workspace path 2. The target directory must be writable 3. The selected project must not exist in the current workspace © AMIQ 6 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 2. Predefined Projects www.dvteclipse.com 1. Quick filter - by project name; 2. Available predefined projects; 3. A short description of the selected project; 4. If you want to change the default target directory (by default is the $HOME/ dvt_predefined_projects_target ); 5. Override target directory (if it already exists) © AMIQ 7 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 2. Predefined Projects www.dvteclipse.com 6. A message dialog will pop up, with info about all $DVT_PREDEFINED_PROJECTS & $DVT_PREDEFINED_PROJECTS_EXT_* environment variables (indicates the directories where DVT scans for predefined projects); See the picture below: If all the settings are correct, click Finish. © AMIQ 8 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 3. Getting Started 3.1 What is a Workspace When you start Eclipse you are asked to indicate a workspace directory. • The workspace is a directory on the disk where the Eclipse platform and all the installed plug-ins store preferences, configurations and temporary information. Subsequent Eclipse invocations will use this storage to restore the previous state. • As the name suggests, it is your "space of work". It defines your area of interest during an Eclipse session. • In a workspace you define projects that reference your disk resources. You don't have to move source files into the workspace. And projects don't import or copy source files into the workspace. Instead projects point to any folder or files on your disk. • We don't recommend keeping source code files in the workspace. Each time you start Eclipse you can create a new workspace directory or indicate an existing one. You can create many workspaces, each one dedicated to some activity. You may use one workspace for developing your current project and another for maintaining the previous one. If the two activities are unrelated, in doing so you minimize clutter and improve performance by using two workspaces. You can launch several Eclipse applications in parallel, but one workspace can be used only by one Eclipse instance that locks it (<workspace_dir>/.metadata/.lock). If you try to use an workspace already in use by an existing Eclipse instance, you'll be signaled "Workspace in use or cannot be created, choose a different one". You can switch at anytime to another workspace from menu File > Switch Workspace..., but launching different Eclipse for different workspaces is common practice. Workspace and Workbench Refresh 3.2 What is a Project In order to see the contents of a specific directory on the disk, you need to define a project using various wizards. Create a New Project Menu File > New > DVT Project © AMIQ 9 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com The first time when you create a project, the Eclipse platform creates a .project file in the directory you specified, right before it presents the directory contents. This is the only operation the platform performs. It will not move or copy any files to your workspace from the directory you specified. It will just create the .project file. Some plug-ins might create other information holders in the project directory. For example DVT creates a .dvt directory to store project level configurations specific to DVT. NOTE: There are ways to create projects directly from a revision control system, for example from a CVS repository. As expected, in this case files will be brought into your workspace. Import an Existing Project Menu File > Import... (> General > Existing Projects into Workspace) If a project was created for a directory on the disk (a .project file is already there), you cannot create another project in that directory. Instead you import an existing project into your workspace. Automatic Create or Import The DVT plug-in merges the create and import wizards. It automatically detects that a project already exists at the specified location and imports it. Otherwise it guides you through the project creation. Build Configurations 3.3 Project Natures In Eclipse a project can have zero to many project natures. Various plug-ins provide functionality for a project if it is tagged with a specific nature. For example DVT builds a project only if it has one of the natures it knows about, for example Verilog, VHDL or e Language. Project natures are stored in the project definition, that is in the .project file. To turn on/off a specific nature for a project, select the project in Navigator and choose Change DVT Nature from the right click menu. © AMIQ 10 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.4 Workspace and Workbench Work Workspace and workbench are different terms for different concepts, however they sound quite similar to be mistakenly interchanged. The "work" prefix has a tendency to make us lose the interest, so I guess we don't get to hear clearly the "space" or "bench" that follow, hence both workspace and workbench collapse under the annoying "something about work". Workspace One of the first things you specify when you start Eclipse is the workspace location. The workspace is a directory that holds information about the projects you work on, as well as the Eclipse preferences (from layout to behavior). We can say that the workspace "holds" the Integrated Development Environment: the data you work on (organized in projects) and how you work with it (preferences). It is your "space of work" or "working space" or "working universe". Depending on your style, you can do all your work in a single workspace, no matter how different projects in your life, for example a Web project to publish your photos, a Verification © AMIQ 11 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com project and a Java project where you learn how to program. Or you can chose to have several workspaces, each one dedicated to a specific state of mind or universe of thinking. Workbench The workbench is practically the Eclipse main window. It is the bench where you organize your instruments, except that now you don't have power supplies, signal generators or oscilloscopes, but different views and editors. Views and editors are your instruments to manipulate sources and data. You arrange them at hand for a specific task (exploring, debugging, coding etc.). What instruments you use and how you lay them out on your bench ( workbench) is known as a perspective: with what and from what angles you look at your data. Eclipse allows you quickly to reorganize your workbench, by choosing a different perspective. Don't have to spend time moving the signal generator away, just switch to another perspective. Workspace Again The projects (your data) are not necessarily physically located in the workspace directory. They can be simple pointers to other locations on the disk. However the workspace aggregates all your "relevant" projects for a specific development universe. When you create a new empty project in the workspace, it is located in the actual workspace directory. When you create a project from existing source, the workspace keeps a pointer to the project folder. When you import a project in your workspace, again the workspace keeps a pointer to the project folder. (Importing is an interesting concept, documented separately). You can switch at any time from one workspace to another (menu File > Switch workspace...). You can start several Eclipse instances looking at various workspaces (chose when prompted at start or in batch mode "eclipse -d <workspace location>"). However, you cannot have two Eclipse instances looking at the same workspace at once. Eclipse locks the workspace, as indicated by the .metadata/.lock file in the workspace directory. What is a Workspace 3.5 Refresh Once you start Eclipse, the workspace is usually read from the disk (not necessarily, caches are also kept from the previous invocation). From this point on, usually, what ever changes you do outside of Eclipse on resources in the workspace are not reflected immediately. You need to request for a refresh (right click on a project and chose Refresh from the drop down menu). "Usually" above because it can be customized. To customize the way refresh behaves and eventually switch it to fully detect each change whenever it occurs, use menu Window > Preferences > General > Workspace. From here you can customize if refresh is done on startup, how often etc. Refresh is a basic and primitive support of concurrency and also has to do with performance. Maybe I don't want to be notified of every change on resources in my projects if somebody © AMIQ 12 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com is also processing part of the data outside Eclipse. It may take a while, even not be relevant and stop me from working until the external processing is complete. For example compilation. Hence maybe I want to trigger it when I know for sure I am interested in some external changes. This does not imply that conflicts (for example editing a file that changed on the disk) are not promptly signaled by Eclipse. It happens often that you don't find some files in your workspace (of course inside a project) although from explorer or console it seems they are there. Maybe you forgot to refresh? What is a Workspace Workspace and Workbench What is a Project 3.6 Linked Resources Linked resources are very similar with file system links, except they are registered in the .project file, not created on the disk. To create a linked resource, right click on the project in the Navigator and select from the popup menu New > Linked Resource. In the wizard you must specify the path the link will point to (for example /apps) and the linked directory name (for example apps): 1. Target: the file system path the link will point to; 2. Name: the linked directory's name; 3. Location: location (inside the selected project) where the link directory will be created. Tip: You can also use system variables in the path, for instance: ${DVT_ENV-SYSTEM_VARIABLE_NAME}/work equivalent to © AMIQ 13 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com $SYSTEM_VARIABLE_NAME/work in a terminal. This way you can share the project with your team and the linked folders will work seamlessly. Note: When you press Finish, if the directory the link points to is too big (for example it has more than 3000 children), a Resource Filter dialog will pop-up. You can use it to exclude those children that you don't need and that may slow down the platform (you can find out more about it here). Linked resources will appear in the Navigator with a small "link" icon: Tip: You can also use drag & drop from a filesystem navigator (like Nautilus in Gnome, Dolphin in KDE or Explorer in Windows): drag the external folder and drop it on the desired target location (Project or Folder) in the Navigator View. In the dialog that pops-up specify that you want to "Link to files and folders". A linked resource will be automatically created. What is a Workspace What is a Project 3.7 Backup and Local History The Eclipse platform provides a similar to autosaved backup files functionality (<name>.bak in win, <name>~ in emacs etc.). It is more elaborated, quite similar with revision control systems in capabilities (compare, multiple versions across time etc.) To quote from the platform manual: "A local edit history of a file is maintained when you create or modify a file. Each time you edit and save the file, a copy is saved so that you can replace the current file with a previous edit or even restore a deleted file. You can also compare the contents of all the local edits. Each edit in the local history is uniquely represented by the date and time the file was saved. Only files have local history; projects and folders do not." Some quick access hints: 1. Right click on a file > Compare With > Local History... and compare with various file snapshots taken over time © AMIQ 14 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 2. From menu Window > Preferences > General > Workspace > Local History you can configure how often snapshots are taken and for how long preserved. Right click in the editor and chose Compare With/Replace With > Local History.... 3.8 Basic Tutorial This tutorial provides a step by step walk-through of the SystemVerilog development environment. 3.8.1 Switch to the DVT Perspective The DVT Perspective provides a workbench layout with many useful views and shortcuts at hand for developing SystemVerilog code, for example the type browser, class hierarchy browser etc. From menu Window > Open Perspective > Other... choose DVT © AMIQ 15 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com You can customize and save a perspective. In order to further speed-up the development, at any time you can switch between various perspectives with different tool (views) layouts. For example you can use one perspective for writing code (the editor will take most of the real estate) and another perspective for code navigation (type browser will be a significant component). The default DVT perspective looks like this: © AMIQ 16 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.2 Open a Project A project corresponds to a specific directory on the disk. The project is presented in the Navigator View - a file browser component that helps you browse the project directory contents. For more details see What is a Project. Create a New Project Invoke the New Project Wizard: choose menu File > New > DVT Project. © AMIQ 17 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 1. Specify the Project Directory It can be a directory that already contains sources or a new directory that will be created. 2. Specify the Project Name By default, the project's name is the last segment of the project's directory path (e.g. /tmp/path1/path2/p_name > p_name). You can change this name by selecting Custom. NOTE: If Project Directory points to an existing project, you cannot change its name. 3. Open a Predefined Project You may open one of the predefined projects that DVT ships with and continue to explore the DVT features. For more details see Predefined Projects. 4. Specify the Project Nature. If the poject does not exist or it does not contain any nature, you must select at least one nature. This way DVT will compile the respective sources. 3.8.3 Configure the Build As soon as you create a project, you'll be notified there is nothing to build. To configure the build follow the link in the build notification dialog or open the .dvt/ default.build file. © AMIQ 18 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com In order to provide advanced functionality (like hyperlinks, autocomplete, design and class hierarchy, error signaling, etc.) DVT analyzes the source code files in your project. This analysis process is called build. By default, DVT doesn't build anything. In order to build, DVT uses the arguments that you specify in one of the <name>.build files located in the .dvt folder of your project. The default build configuration is .dvt/default.build. Here you list compilation directives in a similar way you would pass arguments to any simulator. For more details see Build Configurations. 3.8.4 Build the Project Once you specified the files you want to compile, the incdirs to be used for `include and so on, you should rebuild the project. In general, every time you change the .build configuration, you should rebuild. In order to rebuild you click the Rebuild button . While editing source files, a project is incrementally compiled as soon as you save, unless the menu option Project > Build Automatically is un-checked. The building progress is reported in the Progress View. Depending on your configuration, you may also see detailed information in the Console View. 3.8.5 Inspect the Compilation Errors Syntax errors are detected as you type. © AMIQ 19 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com They are indicated in the vertical bars of the editor (right - for the visible code, left - for the full file). If you keep the mouse over the marker on the left you'll see more details about the error. Same tooltip will appear if you keep the mouse over the marker on the editor right bar. You can also click on the marker to jump to the error. If a project contains errors, for example syntax errors, it will be indicated using decorators: © AMIQ 20 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com You can use the Problems View to inspect the errors. You can show the Problems View from menu Window > Show View > Other... > General > Problems. Double clicking on some error will jump to the source location. 3.8.6 See Comments in Tooltips When you position the mouse over a type, method, field etc., a tooltip will pop-up showing information on corresponding declaration. Some examples are presented below. In a similar way you'll see information on fields, events, variables etc., predefined or not. © AMIQ 21 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com Type Info Macro Info Task Info The information presented in the tooltip is created using the comment on top of the declaration. For example, given the following declaration of a field: the corresponding tooltip will look like this: © AMIQ 22 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.7 Use Hyperlinks to Move Around in the Code If you place the mouse over a type, method, field etc. and press the Ctrl key, a hyperlink will be presented. Click on the hyperlink to jump to definition. You can also jump to a definition if you put the cursor on the relevant name and press F3. You can hyperlink and jump to an imported file. You can hyperlink and jump to a macro. © AMIQ 23 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.8 Quickly Open a Type (Class, Module, Interface) You can quickly open a specific type definition. Press Ctrl+Shift+T. The Quick Types View will pop-up and you can enter any regular expression to locate a type. Select and press Enter or click to jump to its definition. 3.8.9 Quickly Inspect the Class Hierarchy You can quickly see inheritance tree for a class, task, function etc. Put the cursor over the entity name and press Ctrl+T. © AMIQ 24 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com For example for functions you can also see the implementations along the hierarchy (icons are not grayed). 3.8.10 Quickly Open a File You can quickly open a file that is included via the top files. Just press Ctrl+I.The Quick Compile Order View will pop-up and you can enter any regular expression to locate a file. Select and press Enter or click to open the file. © AMIQ 25 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com You can also see the include tree of the files in your project in the Compile Order View. Open the view from menu Window > Show View > Other... > DVT > Compile Order . © AMIQ 26 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com This is the Compile Order View. 3.8.11 Quickly Move Inside the Editor Press Ctrl+O to open the Quick Outline for an overview of your file. You can enter any regular expression to locate an entity to jump to the current file. You can also see the outline in the Outline View. Open the view from menu Window > Show View > Other... > General > Outline . © AMIQ 27 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.12 Inspect the Class Hierarchy and Class Members Position the cursor on the relevant name and press F4 or right click and choose Show > Type Hierarchy from the menu. The Type Hierarchy View will present: • the inheritance tree (for example parents and children of a class) • members © AMIQ 28 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.13 Inspect the Design Hierarchy Position the cursor on a module name and press Shift+F4 or right click and choose Show > Design Hierarchy from the menu. The Design Hierarchy View opens with the chosen element set as the top of the hierarchy. © AMIQ 29 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.14 Inspect the Verification Hierarchy Position the cursor on a UVM class name and press Shift+F6 or right click and choose Show > Verification Hierarchy from the menu. The Verification Hierarchy View opens with the chosen class set as the top of the hierarchy. © AMIQ 30 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.15 Browse Through All the Available Types (Classes, Modules, Interfaces) You can explore all the types like classes, modules, interfaces or structs... that are defined in your project using the Types View. Go to menu Window > Show View > Other... > DVT > Types to open the Types View. © AMIQ 31 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.16 Look for the Implementation of an Extern Function or Task Position the cursor on the relevant name and press Shift+F3 or right click and choose Show > Layers from the menu. © AMIQ 32 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.17 Search for Entities You can search for a specific type, method etc. in the current project or whole workspace. Press Ctrl+H to pop-up the search dialog. © AMIQ 33 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com The results are presented in the Search View. 3.8.18 Use Content Assist (Autocomplete) Content assist provides you with a list of suggested completions for partially entered text. Proposals are context dependent and include accessible fields, methods, variables, OVM macros etc. as well as templates for various constructs. © AMIQ 34 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com Press Ctrl+Space to trigger content assist. Content assist is triggered automatically in some contexts, for example when you type in a . (dot) in the editor after a class type field name. Proposals are presented in a list for you to choose from. Moving through proposals you can quickly see the related documentation. Press Enter or click to select a proposal or Esc to cancel the assist. 3.8.19 Use Code Templates When you trigger autocomplete using Ctrl+Space, template suggestions may appear in the proposal list. © AMIQ 35 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com To define templates go to the DVT > Code Templates preference page (via menu Window > Preferences) and select SystemVerilog from Select Nature:. Click the New button to define a new template. The template name is important for proposal filtering based on already typed text. © AMIQ 36 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.20 Use Module Auto Instance You need to type the first letters of the module name, then press Ctrl+Space three (3) times. You can recognize module instances by their icon, it looks like a chip with ports ready to be glued in. © AMIQ 37 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.21 Expand Macros (Apply Preprocessing) You can apply preprocessing over a selected section of code in order to see how macros are expanded. You have multiple options in the right-click context menu Macros. To expand them in the source file, choose Expand One Level Inline or Expand All Levels Inline. To expand them in a temporary file, choose Expand One Level or Expand All Levels. © AMIQ 38 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.22 Trace Macro Errors To debug macro usage errors (especially if macros in macros are used) you can see how the error is propagated from macro to macro (the error trace) either by: • going with the mouse over the error marker on the left and right click • or selecting the error in the Problems View, right click and choosing Macro Trace The macro error trace will be presented in the Console View with hyperlinks to source. © AMIQ 39 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.23 Track Tasks using TODO Markers If you place TODO markers in your code they are recognized and presented in the Tasks View. This is a mean to insert reminders, preserve, track and share them with your team. You can use TODO markers inside comments. FIXME (high priority), TODO and XXX (low priority) are recognized. Go to menu Window > Show View > Other... > General > Tasks to open the Tasks View. Double click on a task to jump to the marker definition. 3.8.24 Quickly See the Current Scope in the Status Bar The scope at cursor (current function/class/module...) is always presented in the status bar. © AMIQ 40 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 3. Getting Started www.dvteclipse.com 3.8.25 Fold Code Regions in Order to Improve Readability Use the Expand All button or the Collapse All button from the toolbar or from right click menu Source > Folding to unfold/fold the current file. 3.8.26 Access the Context Sensitive Help A focused set of help topics that is related to the current context can be shown to users on demand using context-sensitive help. This form of user assistance is delivered to users when a platform-specific trigger is activated (e.g. F1 key on Windows, Ctrl+F1 on GTK, Help key on Carbon): © AMIQ 41 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 3. Getting Started 42 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 4. Build Configurations In order to provide advanced functionality (like hyperlinks, autocomplete, design and class hierarchy, error signaling, etc.) DVT analyzes the source code files in your project. This analysis process is called build and it is performed by the DVT internal builder (also referred to as internal builder or DVT builder or DVT parser). For convenience, build is synonym with code compilation or code analysis. The internal builder performs an initial full build of your project (a full build can also be triggered on demand). As you change sources, DVT performs an incremental build (incremental compilation), that is it analyzes only the changes. Unless the build automatically preference is turned off, an incremental build is performed as soon as you save or as soon as DVT detects some idle time after you changed the code. DVT includes standard compliant code parsers. During the build process it creates an internal representation of the code. This representation is called the internal DVT dictionary, index, database or model. This model is partially serialized on the disk, so that subsequent tool invocations don't require a full build. See Build Persistence for more details. In order to build, the internal builder uses the arguments that you specify in the current build file. A build file is one of the <name>.build files located in the .dvt folder of your project. Blue bullet decorations indicate if a file is compiled, for example in the Navigator View. This is a compiled file. This file is not compiled. 4.1 default.build .dvt/default.build is an argument file that configures DVT's internal builder. By default, whenever a full build is performed, DVT starts by reading this file. It may contain: • comments • directives in two forms: • +directive+arg1+arg2+ • -directive arg1 arg2 • top files. Anything that is not a directive or comment is regarded as path to a top file. Note: Unknown directives are ignored. In general, DVT-specific directives start with +dvt_. Unknown directives that start with this prefix are flagged with a warning. The internal builder parses each top file, following includes/imports as specified by the language. Some directives ( parsing directives) allow you to control how files are compiled © AMIQ 43 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com based on their extension, for example using System Verilog 1800-2012 for *.sv, Verilog 2001 for *.v, VHDL 1076-2008 for *.vhdl and e Language 1647-2011 parser for *.e. The parsing directives are either generic or mode specific. Note: A project is built by analyzing source code with one or more of DVT's parsers depending of the Project Natures. Even if build configuration files in the .dvt folder specify certain files to be compiled with a specific language syntax, they will not be analyzed unless the corresponding nature is enabled for the project. The language syntax to project nature mapping is: e Language e Nature Verilog, SystemVerilog vlog Nature VHDL vhdl Nature In general, the directives are similar with the arguments (or flags) that you would pass to any compiler/simulator. A build file may include other argument files and so on. The internal builder follows the included files as it encounters them (as if part of a continuous stream). Note that the way a file is included (for example with '-f' or '-F') has an influence on how paths inside the included files are interpreted. For more details see Including Other Argument Files. To simplify the flow integration, DVT supports several Compatibility Modes. This capability allows you to reuse existing arguments or argument files that you already use for a particular simulator invocation. 4.2 Emulating compiler invocations Sometimes a design is compiled across multiple invocations. For example, environment variables or preprocessing directives may change their values between invocations, or sources may be compiled into different libraries. The +dvt_init+<mode> directive is equivalent with a new compiler invocation, where <mode> represents the compiler compatibilty mode. The directive resets the DVT builder to the mode specific default state and clears all the previous directives (preprocessing defines, system variables, libraries, etc.). You may specify any number of +dvt_init directives inside a build file. The compatibility mode is enforced until the next +dvt_init directive. Even if there is no +dvt_init directive specified, there is always an initial reset equivalent to +dvt_init+dvt. 4.3 Multiple .build Files You can have multiple build files inside the .dvt directory, and tell DVT which one to use for compilation by using the Set current build button from the toolbar: © AMIQ 44 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com The current build name is saved in the .dvt/build.config.xml file. The project state is saved per build file after each build, and this allows you to easily switch between multiple views of the project (see Build Persistence for more information). Use Cases Depending on your current focus (browsing rtl.build contains all directives needed to the design, writing testbench code, debugging) compile the design you only want to load in DVT the relevant code testbench.build contains all the directives needed to compile the verification environment default.build includes both the rtl.build and testbench.build Quickly switch between synthesizable and default.build contains all directives needed to non-synthesizable version of the design compile all the code hierarchy synth.build contains +dvt_preprocess_translate_pragmas +synthesis and a -f directive to include default.build You switch often between several versions compile.f contains directives needed to of the same code base. The paths to the compile all the code few different files are controlled by the $VERSION environment variable. version1.build contains +dvt_env +VERSION=1 and a -f directive to include compile.f version2.build contains +dvt_env +VERSION=2 and a -f directive to include compile.f ... You want to change the active build before Change the build name in .dvt/ launching DVT, as designers compile just the build.config.xml before launching DVT, for RTL by rtl.build, while others all.build. example by a wrapper script "run_dvt.sh -rtl". © AMIQ 45 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com 4.4 Compatibility Modes A compatibility mode defines how DVT decides what top files to parse and with what language syntax to parse them. File Extension to Language Syntax Mapping File extensions can be mapped either to a specific language syntax or skipped (that is they will not be parsed). Each mode has a default file extension to syntax mapping. You control the extensions mapping by using various directives, like for example +verilog2001ext in vcs.vlogan Compatibility Mode. The +dvt_ext_unmap_all directive clears the syntax mapping, including skipped. This means that all top files will be parsed using the Language Syntax for Unmapped Extensions. Note that the syntax for unmapped extensions can be Skip, for example in the Default DVT Compatibility Mode, as a result nothing will be compiled. Language Syntax for Unmapped Extensions An unmapped top file will be parsed using this syntax or skipped, depending on the compatibility mode. Can be controlled by various directives, like for example +dvt_ext_unmapped_syntax+<syntax> in the Default DVT Compatibility Mode or +v2k in vcs.vlogan Compatibility Mode. Language Syntax for Included Files Where relevant, for example for Verilog/ SystemVerilog, the included files are parsed either with the same syntax as the including file, or as specified by the extension mapping. See also each compatibility mode documentation. Note: A compatibility mode might also introduce specific predefined API, like for example Verilog preprocessing macros. List of Compatibility Modes The following compatibility modes are supported: • dvt - This is the default mode. • vcs.vlogan • vcs.vhdlan • ius.irun • TBD questa.vlog © AMIQ 46 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com • TBD questa.vcom How to Specify the Compatibility Mode The +dvt_init+<mode> directive changes the compatibility mode, where <mode> can be any of the above modes. A +dvt_init+<mode> directive: 1. Resets the dvt builder to the mode specific default state. 2. Clears all the previous directives (preprocessing defines, system variables, libraries, etc.). You can see it as the equivalent of a new tool invocation. You may specify any number of +dvt_init directives inside a build file. The compatibility mode is enforced until the next +dvt_init directive. 4.4.1 Default DVT Compatibility Mode The +dvt_init+dvt directive resets the builder to the dvt default state. File Extension to Language Syntax Mapping Syntax Extensions Verilog 2001 .v, .vh System Verilog 1800-2012 .vp, .vs, .vsh, .v95, .v95p, .sv, .svh, .svp, .svi, .sva VHDL 1076-2008 .vhd, .vhdl e Language .e 1647-2011 Skipped Files .c, .cpp, .so, .a, .o, .cc Language Syntax for Unmapped Extensions: Skip unmapped extensions. Language Syntax for Included Files: Included files are parsed as specified by the extension mapping. Mode Specific Directives Directive Description +dvt_ext_map Files with <ext> extension are parsed using the specified <syntax>. See the list +<syntax> below for more details regarding <syntax>. +<ext> +dvt_ext_unmap Files with <ext> extension are parsed using the Language Syntax for +<ext> Unmapped Extensions. © AMIQ 47 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com +dvt_ext_unmapped_syntax Set the Language Syntax for Unmapped Extensions. See the list below for +<syntax> more details regarding <syntax>. +dvt_ext_unmap_all All files are parsed using the Language Syntax for Unmapped Extensions. +dvt_ext_included by_ext: The included files are parsed using the syntax as specified by directives, +by_ext that is using by ext syntax (if explicit) or the syntax for unmapped extensions +dvt_ext_included by_parent: Included files are parsed using the syntax that was used for parsing +by_parent the including file Specifying a <syntax> To specify the <syntax> for the directives above, one should use any of the following strings, case-insensitive: 1364-1995, Verilog_95 1364-2001-noconfig, Verilog_2001_noconfig 1364-2001, Verilog_2001 1364-2005, Verilog_2005 1800-2005, SystemVerilog_2005 1800-2009, SystemVerilog_2009 1800-2012, SystemVerilog_2012, SystemVerilog 1647-2011, e_2011, e 1076-1987, VHDL_87 1076-1993, VHDL_93 1076.1-1999, VHDL_AMS_99 1076-2000, VHDL_2000 1076-2002, VHDL_2002 1076.1-2007, VHDL_AMS_2007 1076-2008, VHDL_2008, VHDL SKIP The dot (.) for specifying <ext> is optional. For example +dvt_ext_map +verilog_1364_1995+.svh and +dvt_ext_map+verilog_1364_1995+svh are equivalent. You can specify more extensions +verilog_1364_1995+.svh+svp. at once, for example +dvt_ext_map When several directives change the syntax of a specific <ext>, the last one wins. © AMIQ 48 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com Examples • I want to parse .c and .v files as SystemVerilog: +dvt_init+dvt // By default .c are skipped and .v are parsed with Verilog 2001 syntax +dvt_ext_map+SystemVerilog_2012+.v+.c // Now .c and .v are parsed with SystemVerilog 2012 Note Every time you re-map an already mapped extension, DVT will warn you. For the example above, you get the following warnings: .v was previously mapped to Verilog_2001 .c was previously mapped to Skip • I want the .vp files to be parsed with the Language Syntax for Unmapped Extensions: +dvt_init+dvt // By default .vp is parsed with SystemVerilog 2012. +dvt_ext_unmap+.vp // Because by default the unmapped extensions are skipped, .vp files will be skipped • I want to change the Language Syntax for Unmapped Extensions: +dvt_init+dvt // By default the unmapped extensions are skipped +dvt_ext_unmapped_syntax+Verilog_95 // Now unmapped extensions, for example .foo, will be parsed as V • I want to configure everything from scratch: +dvt_init+dvt +dvt_ext_unmap_all // All files are skipped +dvt_ext_unmapped_syntax+Verilog_95 // Compile all files with unmapped extensions as Verilog 95 +dvt_ext_map+skip+.cpp // Skip .cpp files +dvt_ext_map+SystemVerilog_95+.sv // Compile .sv as SystemVerilog +dvt_ext_map+VHDL_1076_1_1999+.vhd // Compile .vhd as VHDL-AMS • I want to parse everything as SystemVerilog +dvt_init+dvt +dvt_ext_unmap_all // All files are skipped +dvt_ext_unmapped_syntax+SystemVerilog // All files are parsed as SystemVerilog 4.4.2 vcs.vlogan Compatibility Mode The +dvt_init+vcs.vlogan directive resets the builder to the vcs.vlogan default state. File Extension to Language Syntax Mapping Syntax Extensions Skipped Files .c, .cpp, .so, .a, .o, .cc Language Syntax for Unmapped Extensions: Verilog 1995 Language Syntax for Included Files: Included files are parsed using the syntax that was used for parsing the including file. Mode Specific Directives © AMIQ 49 Rev. 3.5.32 DVT SystemVerilog IDE Directive Chapter 4. Build Configurations www.dvteclipse.com Description +verilog1995ext All files with <ext> extension are parsed using the Verilog 1995 syntax. +<ext> +verilog2001ext All files with <ext> extension are parsed using the Verilog 2001 syntax. +<ext> +systemverilogext All files with <ext> extension are parsed using the SystemVerilog syntax. +<ext> -sverilog Sets the syntax for unmapped extensions to SystemVerilog. This directive has precedence over +v2k. +v2k Sets the syntax for unmapped extensions to Verilog 2001. -extinclude The included files are parsed using the syntax as specified by directives, that is using by ext syntax (if explicit) or the syntax for unmapped extensions. It overrides the default behavior. The dot (.) for specifying <ext> is optional. For example +verilog1995ext+.svh and +verilog1995ext+svh are equivalent. You can specify more extensions at once, for example +verilog1995ext+.svh+svp. When several directives change the syntax of a specific <ext>, the last one wins. Predefined API VCS Defined as preprocessing macro without value. 4.4.3 vcs.vhdlan Compatibility Mode The +dvt_init+vcs.vhdlan directive resets the builder to the vcs.vhdlan default state. File Extension to Language Syntax Mapping Syntax Extensions Skipped Files .c, .cpp, .so, .a, .o, .cc Language Syntax for Unmapped Extensions: VHDL 1076-1993 Mode Specific Directives Directive Description -w <lib> Compile intro library <lib> -work <lib> -vhdl87 Sets the syntax for unmapped extensions to VHDL 1076-1987 4.4.4 ius.irun Compatibility Mode The +dvt_init+ius.irun directive resets the builder to the ius.irun default state. © AMIQ 50 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com File Extension to Language Syntax Mapping Syntax Extensions Verilog 1995 .v95, .v95p Verilog 2001 .v, .vp, .vs System Verilog 1800-2012 .sv, .svp, .svi, .svh, .vlib, .vcfg VHDL 1987 .vhd, .vhdl, .vhdp, .vhdlp, .vhcfg VHDL AMS .vha, .vhams, .vhms 1999 e Language .e 1647-2011 Skipped Files .vams, .pslvlog, .pslvhdl, .pslsc, .c,.cpp, .cc, .s, .o, .a, .so, .sl, .scs, .sp Language Syntax for Unmapped Extensions: Skip Language Syntax for Included Files: Included files are parsed using the syntax that was used for parsing the including file. Mode Specific Directives Note: in IUS compatibility mode all directives are case-insensitive except for -f / -F Directive Description -default_ext <syntax> Set the Language Syntax for Unmapped Extensions. See the list below for more details regarding the <syntax> argument. Files with <ext> extension will be parsed using the specified <syntax>. If <syntax>_ext the optional + is specified, the mapping will be added to the default File [+]<ext>[,<ext>] Extension to Language Syntax Mapping. Otherwise, the default mapping of the specified <syntax> is overridden. If you specify the override directive multiple times for the same <syntax>, the default File Extension to Language Syntax Mapping will be overridden only the first time. You can specify more extensions at once, comma-separated, for example - vlog_ext .svh,.svp. The dot (.) for specifying <ext> is mandatory. The following directives are supported: -a_ext, -amsvhdl_ext, -amsvlog_ext, -as_ext, -c_ext, -cpp_ext, -dynlib_ext, -e_ext, -o_ext, -spice_ext, -sysv_ext, vhcfg_ext, -vhdl_ext. See the list below for more details regarding <syntax>. -asext Equivalent to -as_ext +<ext>[,<ext>] <ext>[,<ext>] -ccext <ext> Equivalent to -c_ext +<ext>[,<ext>] -cxxext <ext> Equivalent to -cpp_ext +<ext>[,<ext>] -objext <ext> Equivalent to -o_ext +<ext>[,<ext>] © AMIQ 51 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com -vhdlext <ext> Equivalent to -vhdl_ext +<ext>[,<ext>] -vlogext <ext> Equivalent to -vlog_ext +<ext>[,<ext>] -sv All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a Verilog syntax flavor will be parsed with SystemVerilog 2012 instead. Has precedence over -v1995. -v1995 All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with Verilog 2001 will be parsed instead with a reduced keywordset variant of Verilog 2001. The reduced keywordset does not contain the keywords automatic, localparam, generate, endgenerate, and genvar. -v95 -v200x All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor (but not VHDL AMS) will be parsed with VHDL 2000 instead. Has precedence over -v93. -v93 All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor (but not VHDL AMS) will be parsed with VHDL 93 instead. -ams All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor will be parsed with VHDL AMS 1999 instead. Has precedence over -v93 and -v200x. -snpath <path> Equivalent to +dvt_env+SPECMAN_PATH=$SPECMAN_PATH:<path> -sndefine <arg> Equivalent to +define+<arg> -ovm Load the OVM / UVM library from the irun installation location. -uvm For ovm: `irun -location -nolog`/tools/ovm. For uvm: `irun -location -nolog`/tools/uvm/uvm_lib/uvm_sv. -ovmhome <path> Load the OVM / UVM library from the specified <path>. Has precedence over -ovm / -uvm. -uvmhome <path> How to specify <syntax> for - default_ext <syntax> and - <syntax>_ext directives Language Syntax - default_ext <syntax> - <syntax>_ext Verilog 2001 -default_ext verilog -vlog_ext © AMIQ 52 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com Verilog 1995 -default_ext verilog95 SystemVerilog 2012 -default_ext systemverilog, - -sysv_ext default_ext vcnf VHDL 1987 -default_ext vhdl, -default_ext -vhdl_ext vhcfg e Language -default_ext e -e_ext VHDL AMS 1999 -default_ext vhdl-ams -amsvhdl_ext SKIP -default_ext verilog-ams, - -a_ext, -amsvhdl_ext, default_ext psl_vlog, amsvlog_ext, -default_ext psl_vhdl, default_ext psl_sc, default_ext c, N/A - - -as_ext, -c_ext, -cpp_ext, -dynlib_ext, -e_ext, -o_ext, -default_ext cpp, -default_ext -spice_ext, -sysv_ext, assembly, -default_ext o, vhcfg_ext, -vhdl_ext - -default_ext a, -default_ext so, -default_ext scs Predefined API INCA Defined as preprocessing macro without value. Examples • I want to parse .sv, .c and .v files as SystemVerilog: +dvt_init+ius.irun // By default .c are skipped and .v are parsed with Verilog 2001 syntax -sysv_ext +.v,.c // Now .c and .v are parsed with SystemVerilog 2012; however, the default extensions mappe Note Every time you re-map an already mapped extension, DVT will warn you. For the example above, you get the following warnings: .v was previously mapped to Verilog_2001 .c was previously mapped to Skip • I want the .vp files to be parsed with the Language Syntax for Unmapped Extensions: +dvt_init+ius.irun // By default .vp, .v, .vs are parsed with Verilog 2001 -vlog_ext .v, .vs // We override the mapping for Verilog 2001 with only the other two extensions. // Now .vp is not mapped to any Language Syntax. // Because by default the unmapped extensions are skipped, .vp files will be skipped • I want to change the Language Syntax for Unmapped Extensions: +dvt_init+ius.irun // By default the unmapped extensions are skipped © AMIQ 53 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com -default_ext verilog95 // Now unmapped extensions, for example .foo, will be parsed as Verilog 95 • I want to parse all Verilog source files and all files with unmapped extensions as SystemVerilog, and all VHDL files as VHDL 2000: +dvt_init+ius.irun -default_ext systemverilog // All files with unmapped extensions are parsed as SystemVerilog -sv // All Verilog source files are parsed with SystemVerilog -v200x // All VHDL source files are parsed with VHDL 2000 4.5 Paths You can specify absolute or relative paths. Relative paths are resolved relative to the compilation root. By default the compilation root is the project directory. However, when using the -F directive to include another argument file the compilation root might change (for more details see Including Other Argument Files). You can use environment variables when specifying paths. You can use ant-like path patterns [http://ant.apache.org/manual/dirtasks.html#patterns] when specifying top file paths: • ? matches single character, e.g. top?.sv matches top1.sv and topA.sv but not top_1.sv • * matches a sequence of characters from a file/directory name, e.g. top*/*.sv will match all files with .sv extension from all the directories starting with top • ** matches a sequence of directories from a path (recursively) e.g. **/*.sv matches all files with .sv extension from the whole project directory tree 4.6 Strings You may use single quoted (') or double quoted (") strings to group a piece of text so that it will be considered a single directive argument. Example: +define+FOO='my macro' To use a quotation mark " in a string, you should escape it using backslash \ like this: +define+MOO="Hello \"Moo\"" You can also use \" as string delimiter, and any " inside the string defined like this are considered as part of the string, like this: +define+MOO=\"Hello "Moo"\" NOTE: When in vcs compatibility mode, the escaping only works in files included with -file (see Including Other Argument Files). © AMIQ 54 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com 4.7 Comments The following comment styles are allowed: # single line comment // single line comment -- single line comment /* multi line comment */ 4.8 Environment Variables To define an environment variable you can use the following syntax: +dvt_env+<NAME>[=VALUE] or, equivalently: +dvt_setenv+<NAME>[=VALUE] Examples: +dvt_env+UVM_HOME=/uvm/uvm-1.1 +dvt_env+SPECMAN_PATH=$SPECMAN_PATH:/path/to/my/vips To use the value of a system variable called ENV_VAR you can use any of the following notations: • $ENV_VAR • ${ENV_VAR} • %ENV_VAR% Environment variables, either from the parent shell or explicitly defined, can be used to specify: • top files • directives that take a path as an argument, for example +incdir+ • value for defines When an environment variable is not defined, but it is used, the behavior is as follows: • for the value of a define directive, the define value is left as-is © AMIQ 55 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com • for top files and directives that take a path as an argument, an error is signaled and such top files and directives are ignored • when used inside the value of an environment variable, it is expanded to the empty string Environment variables are visible to the DVT parsers, like for example when used in the e language import statements. Environment variables are propagated to the external tools launched from DVT, for example by using Run Configurations or External Builders. When an environment variable is used inside a build file, only the +dvt_env+ directives above the usage line are taken into account. Predefined environment variables Variable Value DVT_PROJECT_LOC Absolute path of the project directory. 4.9 Including Other Argument Files You can include other argument files with -f, -F or -file: -f /path/to/argument/file.f The -f and -file directives are equivalent, except for the vcs compatibility mode. In the vcs compatibility mode Strings [/wiki/Strings] are handled differently when using -f or -file. The behavior of -F is not consistent across simulators, so DVT treats it according to the compatibility mode: dvt, vcs questa ius when analyzing the contents of the included argument file, all relative paths are resolved as relative to the parent directory of the argument file; in other words, this is equivalent to changing the compilation root to be the parent directory of the argument file the directive is disregarded when analyzing the contents of the included argument file, relative paths are resolved as relative to the compilation root except for relative top file paths. Relative top file paths are resolved as follows: - first, as relative to the parent directory of the argument file - if not found, as relative to the compilation root 4.10 Build Persistence The internal DVT dictionary and information regarding the project state, like for example the errors and warnings, are persisted on disk in the dvt database. When closing and re-opening DVT, the project is restored from the persisted information to the saved state to avoid rebuilding. © AMIQ 56 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com By default, the database is saved in the workspace directory under the location below: <dvt_workspace>/.metadata/.plugins/org.eclipse.core.resources/.projects/<project_name>/dict When the current build is other than the default, the following location is used: <dvt_workspace>/.metadata/.plugins/org.eclipse.core.resources/.projects/<project_name>/dict/bc_<current_b You can specify a custom database location with the +dvt_db_location+ directive, like this: +dvt_db_location+<path> The database is saved in: <path>/dvt_db/<project_name> When the current build is other than the default, the following location is used: <path>/dvt_db/<project_name>/bc_<current_build_name> This directive is global: it has effect for all the compiled code, regardless of +dvt_init+ directives. If specified multiple times, only the first time is taken into account. This may change in the future. There are several use-cases for custom database location. Generally, the target is to eliminate rebuilding after import: • closing and re-opening DVT • importing an existing project in a new workspace • load a set of read-only files in "Browsing mode" (no edit) DB Access Considerations The pseudo-code algorithm below illustrates handling write access restrictions and concurrent access to the location specified by the +dvt_db_location+ directive. if <dvt_db_location> is in use by another DVT instance then USE workspace db location else if read access is required if <dvt_db_location> does not exist READ FROM workspace db location (*1) else if <dvt_db_location> is not writable and there is a saved snapshot in the workspace db location READ FROM workspace db location else READ FROM <dvt_db_location> else if write access is required if <dvt_db_location> is not writable (*1) WRITE TO workspace db location © AMIQ 57 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com else (*2) WRITE TO <dvt_db_location> and CLEAN UP workspace db location (*1) Read only db locations force writes to the workspace db location and as a consequence the read only wil (*2) The workspace db location is cleaned up in order to ensure that a fall back per (*1) is not outdated. 4.11 DVT Auto-Linked Some of the files that DVT compiles for a project may be located outside the project directory (see What is a Project). In order to benefit from DVTs advanced functionalities on such files, they are automatically linked as if inside the project, under the <project_root>/DVT AutoLinked virtual folder. A virtual folder is a logical container - it has no physical representation on the disk. For example, a file physically located in: /path/to/my/base/classes/file.ext will be Auto-Linked under the following virtual folder hierarchy: <project_root> `DVT Auto-Linked `path `to `my `base `classes `file.ext You can create new files or open existing ones anywhere in the DVT Auto-Linked hierarchy. For creating new files, you can use the New File Wizard. The files thus created will have a representation on the disk. For opening existing files, you can right click on any folder in the DVT Auto-Linked hierarchy and select Open from the context menu. A File Chooser will appear that will help you find the file that you want. In the case of very deep hierarchies, you can define "aliases" for paths using the +dvt_auto_link_root+<alias>=<root_path> directive. These aliases are called DVT AutoLinked Roots. For example by adding this line in the project's default.build: +dvt_auto_link_root+base_classes=/path/to/my/base/classes/ the following virtual folder hierarchy is created: <project_root> © AMIQ 58 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com `DVT Auto-Linked `base_classes `file.ext The specified <root_paths> and <aliases> must be unique, and therefore only the first occurrence is considered. Aliases may not be names of directories located directly under the filesystem root (like for example /etc or /bin). Environment variables may be used when specifying root paths, for example: +dvt_auto_link_root+src=$HOME/a/b/c Notes • An environment variable may only be used at the beginning of a root path (that is, the following will not work: +dvt_auto_link_root+src=/path/$VAR/a/b/c) • Only environment variables inherited from the console where DVT was started may be used. Variables defined using +dvt_env+ are not allowed. • The +dvt_auto_link_root+ directive may only be used in the first invocation More examples: +dvt_auto_link_root+hdl=/a/b/c All auto-linked files with a path that starts with /a/b/c will be presented in DVT Auto Linked/hdl +dvt_auto_link_root+hdl=/a/b/c +dvt_auto_link_root+hdl/d/e/f The second directive will be ignored because the same "hdl" alias was used. +dvt_auto_link_root+hdl=/a/b/c +dvt_auto_link_root+src=/a/b/c The second directive will be ignored because the same "/a/b/c" path was used. +dvt_auto_link_root+hdl=/a/b +dvt_auto_link_root+src=/a/b/c All files under /a/b/c will be presented under src and the rest from /a/b under hdl. 4.12 Run a Script Before Build In order to run a script before the build see the Build tab from the DVT Generic run configuration. For more details see Run Configurations. © AMIQ 59 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com 4.13 All Build Directives Directive Note Description -ams ius.irun Compatibility Mode-Specific All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor will be parsed with VHDL AMS 1999 instead. Has precedence over -v93 and -v200x. -asext <ext>[,<ext>] ius.irun Compatibility Mode-Specific Equivalent to -as_ext +<ext>[,<ext>] -ccext <ext> ius.irun Compatibility Mode-Specific Equivalent to -c_ext +<ext>[,<ext>] -cxxext <ext> ius.irun Compatibility Mode-Specific Equivalent to -cpp_ext +<ext>[,<ext>] -cuname <compilation_unit_name> Compile under <compilation_unit_name> package; the directive is enforced until: * another -cuname directive is encountered * +dvt_init directive is encountered * end of default.build is encountered -default_ext <syntax> ius.irun Compatibility Mode-Specific +define +<DEFINE>=<replacement> Set the Language Syntax for Unmapped Extensions. See ius.irun Compatibility Mode for more details regarding the <syntax> argument. Define a preprocessing define; the replacement is optional; you may quote the replacement with ' or "; if defined, environment variables are expanded. -define <DEFINE>=<replacement> +dvt_active_test e Language Only The definition of structs/units/types declared in several +<path> Test Files is considered to be the one in the Active Test File. +dvt_auto_link +<true/false> GLOBAL +dvt_auto_link_root GLOBAL +<alias>=<root_path> Enable automatic linking of resources located outside the project location. Default: true. When Auto-Linking <root_path>/subpath/to/file link it as © AMIQ 60 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com DVT Auto-Linked/<alias>/subpath/to/file This directive helps to reduce the depth of the virtual filesystem hierarchy under DVT Auto-Linked, because the <root_path> sequence of virtual folders is compacted to <alias> virtual folder. The <root_paths> and <aliases> specified like this must be unique, and therefore only the first occurrence is considered. This is a global directive. Aliases may not be names of directories located directly under the filesystem root (like for example etc or bin). +dvt_build_log_file_location GLOBAL +<path_to_existing_directory> Specify the location of the internal builder log file. Default: ./ (Project location). +dvt_build_log_to_console GLOBAL +<true/false> Enable/disable internal builder logging to console. Default: true. +dvt_build_log_to_file GLOBAL +<true/false> Enable/disable internal builder logging to file. Default: true. +dvt_compilation_root +</path/to/ compilation/ root> Specify the compilation root. Relative paths specified in default.build will be resolved as relative to this location, except for the special cases that rise when Including Other Argument Files. +dvt_db_location GLOBAL +<path> Save the project database files under <path>/ dvt_db/<project_name> directory. The <path>/dvt_db/ <project_name> directory will be created if needed and may be overwritten at each full/incremental project build. In certain situations (for example if write access for <path>/dvt_db/<project_name> is denied or the directory is in use by another DVT instance) DVT falls back to the default location: <dvt_workspace>/.metadata/.plugins/ org.eclipse.core.resources/.projects/<project_name>. +dvt_disable_parallel_lex_parse GLOBAL Disable lexing-parsing parallelization. SystemVerilog Only +dvt_disable_preproc_optimize GLOBAL +<true/false> SystemVerilog Only Disable DVT preprocessing optimizations. Default: false. +dvt_disable_checks GLOBAL Disable a set of semantic checks by ID. +<check_id1> +<...> SystemVerilog For example: +dvt_disable_checks and VHDL Only +UNDECLARED_IDENTIFIER © AMIQ 61 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com Possbile check IDs: UNDECLARED_IDENTIFIER, MISSING_OTHERS_CHOICE, REDUNDANT_OTHERS_CHOICE. By default no checks are disabled. +dvt_e_as_computed_translate_method e Language Only Explicitly specify the user-defined methods used in +<package>::<struct>.<method> as computed macros. The <package> is optional and defaults to main if not specified. +dvt_e_enable_non_standard_checks GLOBAL Enable/disable non-standard syntax and semantic +<true/false> checks. Default: false. e Language Only +dvt_e_sn_which_emulation GLOBAL Use the following set of search paths to locate VIPs\n instead of sn_which.sh: e Language Only / <IUS Install Location>/specman/linux/ <IUS Install Location>/specman/src/ <IUS Install Location>/specman/docs/ <IUS Install Location>/specman/tcl/specman/ <IUS Install Location>/specman/linux/ <IUS Install Location>/specman/src/ <IUS Install Location>/specman/docs/ <IUS Install Location>/specman/tcl/specman/ <IUS Install Location>/specman/erm_lib/ <IUS Install Location>/specman/sn_lib/ <IUS Install Location>/specman/packages/ <IUS Install Location>/specman/uvm/uvm_lib/ <IUS Install Location>/specman/ovm/ovm_lib/ <IUS Install Location>/specman/erm_lib/ <IUS Install Location>/specman/sn_lib/ <IUS Install Location>/specman/packages/ © AMIQ 62 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com <IUS Install Location>/specman/uvm/uvm_lib/ <IUS Install Location>/specman/ovm/ovm_lib/ +dvt_e_macro_strict_exp_checking GLOBAL If true, the <exp> match expression will match only +<true/false> valid expressions. If false, <exp> is equivalent with the e Language Only <any> match expression that matches any non-empty sequence of characters. Default: false. +dvt_e_macro_exp_back_tracking GLOBAL If true, the parser will reject a user defined expression +<true/false> match if the result of the macro reparse is not a valid e Language Only expression. Default: true. +dvt_e_sn_extract_defines GLOBAL Automatically extract and define the Specman version +<true/false> defines. Default: true. e Language Only +dvt_e_sn_which_add GLOBAL By default, the following VIPs are located using +<vip1>+<vip2> sn_which.sh, and their locations are added to the +... e Language Only $SPECMAN_PATH: evc_util, vr_ad, ovm_e, uvm_e. When an irun installation newer than 13.10 is detected, +dvt_e_sn_which_clear only evc_util, vr_ad, and uvm_e are added. Use +dvt_sn_which_add+<vip1>+<vip2>+... to add to this list and +dvt_sn_which_clear to clear it. +dvt_enable_unknown_directive_warnings GLOBAL Trigger warnings for unknown build directives. Default: +<true/false> false. +dvt_env +<NAME>[=VALUE] Define an environment variable. Its value is visible for subsequent directives and during parsing. +dvt_setenv +<NAME>[=VALUE] +dvt_ext_map +<syntax> +<ext> Files with <ext> extension are parsed using the specified <syntax>. See Default DVT Compatibility Mode for more details regarding <syntax>. +dvt_ext_unmap +<ext> Files with <ext> extension are parsed using the Language Syntax for Unmapped Extensions. +dvt_ext_unmap_all All files are parsed using the Language Syntax for Unmapped Extensions. +dvt_ext_unmapped_syntax +<syntax> Set the Language Syntax for Unmapped Extensions. See Default DVT Compatibility Mode for more details regarding <syntax>. +dvt_extended_checks DEPRECATED + During incremental compilation, basic semantic checking is performed for all the code. Extended checks are applied only on parts of the code, in order to prevent performance penalty. This directive controls the granularity of the extended semantic checks during incremental build: © AMIQ 63 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com +dvt_extended_checks+AUTO - extended semantic cheks in all of the code +dvt_extended_checks+MANUAL - basic semantic checks in all of the code NOTE: You can manually trigger extended semantic cheks in all of the code. +dvt_extract_comment_above GLOBAL +<true/false> Verilog Only Extract comments above elements. Default: true. +dvt_extract_comment_above_max_empty_lines GLOBAL Extract comment if located at no more than specified +<number_of_lines> number of empty lines above element declaration. Verilog Only Default: 1. +dvt_extract_comment_bcd GLOBAL +<true/false> Verilog Only Extract /** begin comment delimiter comments. Default: true. +dvt_extract_comment_inline GLOBAL +<true/false> Verilog Only Exctract comments inline with elements. Default: true. +dvt_extract_comment_ml GLOBAL +<true/false> Verilog Only Extract /* multi line comments. Default: true. +dvt_extract_comment_sl GLOBAL +<true/false> Verilog Only Extract // single line comments. Default: true. +dvt_file_compile_timeout GLOBAL +<timeout> During full compilation, skip parsing a file if it takes more than the specified threshold (in seconds). Set 0 for disable timeout. Default: 40 seconds. +dvt_file_substituteGLOBAL During compilation, the <file_path> file will be +<file_path>=<substitute_file_path> substituted with the <substitute_file_path> file. SystemVerilog Only +dvt_full_compile_checks GLOBAL In order to speed-up full compilation, you may chose to +<scope> fully check only a relevant subset your source code. This SystemVerilog directive controls the scope of the full build checks: and VHDL Only +dvt_full_compile_checks+FULL - all of the code is checked +dvt_full_compile_checks+LIBS - only the specfied libraries are checked, some basic checks are still performed for the rest of the code © AMIQ 64 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com +dvt_full_compile_checks+OFF - only some basic checks are performed Default: FULL +dvt_incremental_compile_checks GLOBAL +<scope> SystemVerilog and VHDL Only In order to speed-up incremental compilation, you may chose to fully check only a relevant subset your source code. This directive controls the scope of the incremental build checks: +dvt_incremental_compile_checks+FULL - all of the code is checked +dvt_incremental_compile_checks+LIB - only the corresponding libraries of the modified files are checked, some basic checks are still performed for the rest of the code +dvt_incremental_compile_checks+FILE - only the modified files are checked, some basic checks are still performed for the rest of the code +dvt_incremental_compile_checks+OFF - only some basic checks are performed all over the code Default: LIB +dvt_incremental_compile_max_lines GLOBAL Files with more than max lines will not be incrementally +<max_lines_number> compiled. Set 0 for infinite limit. Default: 7000. +dvt_incremental_compile_timeout GLOBAL During incremental compilation, skip the file if parsing +<timeout> or semantic checking takes more than the specified threshold (in seconds). Set 0 for disable timeout. Default: 4 seconds. +dvt_init +<mode> Equivalent of a new invocation, resets all directives. See Compatibility Modes for a detailed description. +dvt_max_nof_threads GLOBAL +<num_threads> Configure the maximum number of threads to use during different phases of intensive computation (e.g. semantic checking, etc.). Default: 8 +dvt_path_pattern_timeout +<timeout> Timeout in seconds when scanning path patterns (like for example /**/*.v). Default: 5. +dvt_preprocess_translate_pragmas Verilog Only Instructs DVT to skip analyzing the code between +<pragma1> pragmas such as +<pragma2>+... // <pragma> translate_off // <pragma> translate_on © AMIQ 65 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com You can specify any number of pragmas as arguments to this directive, separated by '+' like for example +dvt_preprocess_translate_pragmas+pragma+synopsys +synthesis +dvt_semantic_checks_timeout GLOBAL +<timeout> SystemVerilog and VHDL Only Popup semantic checking dialog asking to continue or stop when full compilation semantic checking takes more than the specified timeout (in seconds). Default value: 30. +dvt_skip_compile +<simple_pattern> Instructs DVT to skip analyzing the files whose absolute path matches the specified <simple_pattern>. In a simple pattern you can use wildcards such as '*' (any string) and '?' (any character). Such skipped files are decorated distinctively in the Navigator View: . +dvt_skip_compile +not +<simple_pattern> Instructs DVT to skip analyzing the files whose absolute path does not match the specified <simple_pattern>. In a simple pattern you can use wildcards such as '*' (any string) and '?' (any character). Such skipped files are decorated distinctively in the Navigator View: . +dvt_skip_compile +regex +<regex_pattern> Instructs DVT to skip analyzing the files whose absolute path matches the specified <regex_pattern>. Such skipped files are decorated distinctively in the Navigator View: . +dvt_skip_compile +regex+not +<regex_pattern> Instructs DVT to skip analyzing the files whose absolute path does not match the specified <regex_pattern>. Such skipped files are decorated distinctively in the Navigator View: . +dvt_skip_ext +<ext> Do not parse top files with <ext> extension. The dot (.) for specifying <ext> is optional. For example +dvt_skip_ext+.gv and +dvt_skip_ext+gv are equivalent. +dvt_test+<path> e Language Only Specify a top file and mark it as test. For example, the e Language test files have a special status, see e Language Test Files. © AMIQ 66 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations -extinclude The included files are parsed using the syntax as specified by directives, that is using by ext syntax (if explicit) or the syntax for unmapped extensions. It overrides the default behavior. vcs.vlogan Compatibility Mode-Specific +incdir+<path> www.dvteclipse.com Indicate search directories for files included with `include preprocessing directive. -incdir <path> +libext+<suffix> Specify accepted extensions for files in the library directories. Note: there are no default extensions, .v and .sv don't have a special status. -libmap <path> Specify the Verilog library map file. +librescan When DVT finds an unresolved module reference in a library file or directory, it will scan for the unresolved reference starting from the first specified library; by default (librescan not specified) it starts scanning from the library that introduced the unresolved reference and continues using the specified libraries order. -librescan -objext <ext> ius.irun Compatibility Mode-Specific -ovm Equivalent to -o_ext +<ext>[,<ext>] In all modes except the ius.irun Compatibility Mode it is equivalent with -uvm +incdir+/path/to/uvm/src /path/to/uvm/src/uvm_pkg.sv where /path/to/uvm is $UVM_HOME or $DVT_UVM_HOME if $UVM_HOME is not defined. In the ius.irun Compatibility Mode /path/to/uvm is using the IUS installation. -ovmhome ius.irun Compatibility Mode-Specific Load the OVM / UVM library from the specified <path>. Has precedence over -ovm / -uvm. -sndefine <arg> ius.irun Compatibility Mode-Specific Equivalent to +define+<arg> -snpath <path> ius.irun Compatibility Mode-Specific Equivalent to +dvt_env+SPECMAN_PATH= $SPECMAN_PATH:<path> -sv ius.irun Compatibility Mode-Specific All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a Verilog -uvmhome © AMIQ 67 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com syntax flavor will be parsed with SystemVerilog 2012 instead. Has precedence over -v1995. -sverilog vcs.vlogan Compatibility Mode-Specific Sets the syntax for unmapped extensions to SystemVerilog. This directive has precedence over +v2k. -<syntax>_ext ius.irun [+]<ext>[,<ext>] Compatibility Mode-Specific Files with <ext> extension will be parsed using the specified <syntax>. If the optional + is specified, the mapping will be added to the default File Extension to Language Syntax Mapping. Otherwise, the default mapping of the specified <syntax> is overridden. If you specify the override directive multiple times for the same <syntax>, the default File Extension to Language Syntax Mapping will be overridden only the first time. You can specify more extensions at once, commaseparated, for example - vlog_ext .svh,.svp. The dot (.) for specifying <ext> is mandatory. The following directives are supported: -a_ext, amsvhdl_ext, -amsvlog_ext, -as_ext, -c_ext, -cpp_ext, -dynlib_ext, -e_ext, -o_ext, -spice_ext, -sysv_ext, vhcfg_ext, -vhdl_ext. See ius.irun Compatibility Mode for more details regarding <syntax>. +systemverilogext vcs.vlogan +<ext> Compatibility Mode-Specific All files with <ext> extension are parsed using the SystemVerilog syntax. +UVM_TESTNAME GLOBAL The name of the UVM test which will be automatically created under uvm_root. -v <path> Specify a Verilog library file. -v1995 ius.irun Compatibility Mode-Specific All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with Verilog 2001 will be parsed instead with a reduced keywordset variant of Verilog 2001. The reduced keywordset does not contain the keywords automatic, localparam, generate, endgenerate, and genvar. -v200x ius.irun Compatibility Mode-Specific All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor (but not VHDL AMS) will be parsed with VHDL 2000 instead. Has precedence over -v93. -v93 ius.irun Compatibility Mode-Specific All files that would be parsed according to the File Extension to Language Syntax Mapping or Language Syntax for Unmapped Extensions with a VHDL syntax flavor (but not VHDL AMS) will be parsed with VHDL 93 instead. -v95 © AMIQ 68 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations +v2k vcs.vlogan Compatibility Mode-Specific Sets the syntax for unmapped extensions to Verilog 2001. +verilog1995ext vcs.vlogan +<ext> Compatibility Mode-Specific All files with <ext> extension are parsed using the Verilog 1995 syntax. +verilog2001ext vcs.vlogan +<ext> Compatibility Mode-Specific All files with <ext> extension are parsed using the Verilog 2001 syntax. -vhdl87 vcs.vhdlan Compatibility Mode-Specific Sets the syntax for unmapped extensions to VHDL 1076-1987. -vhdlext <ext> ius.irun Compatibility Mode-Specific Equivalent to -vhdl_ext +<ext>[,<ext>] -vlogext <ext> ius.irun Compatibility Mode-Specific Equivalent to -vlog_ext +<ext>[,<ext>] -w <lib> vcs.vhdlan Compatibility Mode-Specific Compile intro library <lib>. -work <lib> www.dvteclipse.com -work <lib> Compile into library <lib>. -y <path> Specify a Verilog library directory. 4.14 e Language Test Files Test Files are parsed independently on top of the Top Files. A Test File can be specified using the following directive: +dvt_test+/path/to/test_file.e All Test Files and the files imported by Test Files, but not part of Top Files and the files imported by Top Files, are decorated with a green bullet: 4.15 e Language SPECMAN_PATH The SPECMAN_PATH environment variable is used by the e Language parser to find imported files. It can be defined or altered by using the +dvt_env+ directive. © AMIQ 69 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com When relative paths are provided, they are automatically transformed into paths relative to the compilation root directory. By default the compilation root is the project directory. For more details see Paths. Examples: Define/overwrite shell-inherited value +dvt_env+SPECMAN_PATH=/my/specman/ path1:/my/specman/path1 Append to shell-inherited value +dvt_env+SPECMAN_PATH= $SPECMAN_PATH:/my/specman/path Prepend to shell-inherited value +dvt_env+SPECMAN_PATH=/my/specman/ path:$SPECMAN_PATH Append <project_root>/e directory to the +dvt_env+SPECMAN_PATH= SPECMAN_PATH $SPECMAN_PATH:e Backward-compatibility note: starting with DVT version 3.2, if a .build file is used to configure the project, the .edt_specman_path file is ignored. Adding VIPs to $SPECMAN_PATH using sn_which.sh You can specify a list of VIPs that should automatically be located by DVT using sn_which.sh and added to the $SPECMAN_PATH (if available in the console where DVT was started). The Specman version defines (e.g define SPECMAN_VERSION_###) are also detected using the same mechanism. By default, the following VIPs are located and added automatically: evc_util, vr_ad, ovm_e, uvm_e 4.16 SystemVerilog OVM or UVM Library Compilation Typically the OVM or UVM libraries are compiled using directives like: +incdir+/path/to/xvm/src /path/to/xvm/src/xvm_pkg.sv Using the -ovm or -uvm directives You can use the - ovm or - ''-uvm'' directives to compile the OVM or UVM libraries. They are shortcuts for the explicit directives above. For - ''-uvm'': 1. If the $UVM_HOME system variable is specified, use that library. 2. If the $DVT_UVM_HOME system variable is specified, use that library. If you launch DVT using one of the utility scripts that ship with DVT, $DVT_UVM_HOME is set by default to the most recent uvm library in $DVT_PREDEFINED_PROJECTS/libs. © AMIQ 70 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 4. Build Configurations www.dvteclipse.com The - ''-ovm'' directive works in a similar way. NOTE: At any time you can set a system variable using for example: +dvt_setenv+UVM_HOME=/path/to/xvm © AMIQ 71 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 5. Compile Checks The DVT internal builder performs various checks on the source code. • Syntax Checks indicate wrong syntax according to the IEEE standard, for example typos like 'clas' instead of 'class' when declaring a class. Syntactic checking is the first level checking performed on the code during parsing. • Semantic Checks indicate wrong semantic according to the IEEE standard, for example calling an undefined function 'foo()'. For performance reasons, not all semantic checks are performed at once. A subset is performed during full or incremental compilation. The complete set of checks is performed on demand, when explicitely triggered. • Non Standard Checks indicate syntax or semantic that is not standard, although some simulators support it. Non standard syntax is the result of legacy (for example from Vera) or additional language capabilities that may get into future standard releases. Check failures are signaled as compile problems, with the error or warning severity. The compile problems are presented in the Problems View. For performance reasons not all compile problems are visible at once in the Problems View. You can use Compile Waivers to change the severity (promote/demote) or disable the problems reported by DVT during build. 5.1 Compile Waivers You can use waivers to change the severity (promote/demote) or disable the problems reported by DVT during compilation. Promote Warning -> Error Demote Error -> Warning Disable Hide Waivers are defined per project, in the .dvt/waivers.xml file. To quickly create a waivers file click on the Edit waivers button in the Problems View. The .dvt/waivers.xml is created with a default content and opened. You can easily create your own waivers from the default generated ones. In the waivers editor you can use autocomplete for tags, attributes and attribute values. To quickly create a new waiver, in the Problems View right click on any problem reported by DVT and waive it. DVT proposes some default values for the waiver description, path and message. You can easily change them to fine-tune the waiver. You can include other waiver files using the <include/> tag. Compile Waivers Examples Use Case © AMIQ Solution 72 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com I want to hide all errors from a library that I do <waiver name="Disable all from library not control. folder." severity="DISABLED"><match path="/path/to/library/*"/></waiver> I want to hide all errors that I don't care about. <waiver name="Disable all that match a specific message pattern." severity="DISABLED"><match message="*some message pattern*"/></ waiver> I want to hide DVT false alarms until the issue Use a message based and/or path based waiver. is fixed. Compile Waivers File Syntax (XML) <!-XML file header; required. --> <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE waivers PUBLIC "-//DVT//waivers" "waivers.dtd" > <!-Root tag; required. Version attribute is required. The latest syntax version, illustrated by this example, is version 1. --> <waivers version="1"> <!-You can include waivers from other waiver files. The syntax of the included files is the same as this. You may use system variables in the path to included waiver files. --> <include path="$COMMON/path/to/included_waivers.xml"/> <!-The root tag must contain at least one waiver. The waiver tag must specify the NEW severity of the problems waived by this waiver; it can be one of ERROR, WARNING or DISABLED --> <waiver name="Optional short name of the waiver" severity="DISABLED"> <description>An optional verbose description of the waiver.</description> <!-Each waiver must contain at least one match tag. Each match tag must specify a message pattern, a path pattern or both. A match tag matches a problem if ALL specified patterns match. The waiver will waive a problem if ANY of the match tags matches. NOTE: path pattern is NOT matched against the project relative path patterns may contain * or ? wildcards --> <match © AMIQ 73 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com message="pattern to match against the problem's message" path="/pattern/to/match/against/the/problems/absolute/path"/> <match message="*message pattern*" path="/path/pattern*"/> <match message="*only by message*"/> <match path="/only/by/path*"/> </waiver> <!-- Further example waivers --> <waiver name="Disable by message" severity="DISABLED"> <description> This waiver disables all problems containing 'JUST_A_FOO_PROBLEM' inside their message. </description> <match message="*JUST_A_FOO_PROBLEM*"/> </waiver> <waiver name="Demote by path" severity="WARNING"> <description> This waiver turns into warnings all problems reported under '/path/to/foo' </description> <match path="/path/to/foo/*"/> </waiver> <waiver name="Promote by path OR message" severity="ERROR"> <description> This waiver turns into errors all problems that contain 'JUST_A_FOO_PROBLEM' inside their message OR were reported under '/path/to/foo'.</description> <match message="*JUST_A_FOO_PROBLEM*"/> <match path="/path/to/foo/*"/> </waiver> <waiver name="Disable by path AND message" severity="DISABLED"> <description> This waiver disables all problems that contain 'JUST_A_FOO_PROBLEM' inside their message AND were reported under '/path/to/foo'.</description> <match message="*JUST_A_FOO_PROBLEM*" path="/path/to/foo/*"/> </waiver> </waivers> 5.2 Semantic Checks ID Message Notes Preprocessing CYCLIC_INCLUDE Cyclic include detected Basic NON_EXISTING_INCLUDE_FILE No such file # Basic FAILED_TO_OPEN_INCLUDE_FILE Cannot open `include file # Basic MISMATCHED_ENDIF Expecting `endif label # found # Basic © AMIQ 74 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com CYCLIC_MACRO Cyclic define detected Basic UNDEFINED_MACRO Undefined macro name: # Basic REDEFINED_MACRO Redefinition of macro name # Basic WRONG_NUMBER_OF_MACRO_ARGUMENTS Number of macro instance parameters # not equal to macro define Basic parameters # Modules DUPLICATE_MODULE Duplicate module #, already declared at line # file # Extended Primitives DUPLICATE_PRIMITIVE Duplicate primitive #, already declared at line # file # Extended Interfaces DUPLICATE_INTERFACE Duplicate interface #, already declared at line # file # Extended Instances UNDECLARED_MODULE Instantiated module # is not declared Basic DUPLICATE_INSTANCE Duplicate instance #, already declared at line # file # Extended NOF_PORT_CONNECTIONS Expected # port connections, found # Extended NON_EXISTING_PORT Non existing port # of module # Extended MULTIPLE_PORT_CONNECTIONS Multiple connections to port # Extended IMPLICIT_PORT_CONNECTION Cannot infer implicit connection for port(s) # Basic NOT_IN_LIST_OF_PORTS # not in the list of # ports" Extended Packages DUPLICATE_PACKAGE Duplicate package #, already declared at line # file # Extended NON_EXISTING_PACKAGE Non existing package # Basic IMPORT_IN_CLASS Import statement not allowed within class scope Basic Typedefs DUPLICATE_TYPEDEF Duplicate typedef #, already declared at line # file # Extended Classes DUPLICATE_CLASS Duplicate class #, already declared at line # file # Extended EXTEND_NON_EXISTING_CLASS Non existing class # Basic CIRCULAR_INHERITANCE Class # extends itself Basic DUPLICATE_CONSTRUCTOR Duplicate constructor # already declared at line # file # Extended EXTERN_METHOD_UNDECLARED Outer class method # was not declared extern inside class # Basic Parameters DUPLICATE_PARAMETER Duplicate parameter #, already declared at line # file # Extended Nets, Variables, Fields, Properties © AMIQ 75 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com DUPLICATE_FIELD Duplicate field #, already declared at line # file # Extended UNDECLARED_PORT Port # direction declaration is missing Methods DUPLICATE_FUNCTION Duplicate function #, already declared at line # file # Extended DUPLICATE_TASK Duplicate task # already declared at line # file # Extended DUPLICATE_METHOD_IMPLEMENTATION Duplicate method implementation for #, already defined at line # Extended file # DUPLICATE_ARGUMENT Duplicate argument #, already declared at line # file # Extended DUPLICATE_VARIABLE Duplicate variable # already declared at line # file # Extended ILLEGAL_STATIC_VIRTUAL Illegal static virtual function/task declaration Extended Constraints DUPLICATE_CONSTRAINT Duplicate constraint #, already declared at line # file # Extended Events DUPLICATE_EVENT Duplicate event #, already declared at line # file # Extended Covergroups DUPLICATE_COVERGROUP Duplicate covergroup #, already declared at line # file # Extended DUPLICATE_COVERPOINT Duplicate coverpoint #, already declared at line # file # Extended DUPLICATE_COVER_CROSS Duplicate cover cross #, already declared at line # file # Extended Enumerations DUPLICATE_ENUM_LITERAL Duplicate enumeration literal #, already declared at line # file # Extended Programs DUPLICATE_PROGRAM Duplicate program #, already declared at line # file # Extended Checkers DUPLICATE_CHECKER Duplicate checker #, already declared at line # file # Extended Blocks DUPLICATE_NAMED_BLOCK Duplicate named block #, already declared at line # file # Extended DUPLICATE_CLOCKING Duplicate clocking block #, already declared at line # file # Extended Configurations UNDECLARED_CONFIGURATION Configuration # is not declared Basic UNDECLARED_LIBRARY Library # is not declared Basic UNDECLARED_DESIGN Top design # is not declared Basic UNDECLARED_CELL Cell # is not declared Basic Associated types (fields, variables, functions, etc.) © AMIQ 76 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com NON_EXISTING_TYPE Non existing type # Extended Hierarchical identifiers UNDECLARED_IDENTIFIER Identifier # is not declared Extended UNDECLARED_IDENTIFIER Identifier # is not a member of # Extended UNEXPECTED_IDENTIFIER Expecting function # but actual target is not a function Extended 5.3 Non Standard Checks ID Message Notes/ Examples ARGUMENTDynamic array 'new' used in wrong context ILLEGAL_NEW_DYNAMIC_ARRAY task too(input int a[] = new 1);...endtask ASSERTIONGlobal deferred immediate assertion item not allowed must be (0))) else ILLEGAL_GLOBAL_SCOPE_FOR_ASSERTION declared under the scope of a module or checker $error("some error"); ASSIGNMENT_PATTERNEmpty assignment pattern '{} not allowed MANDATORY_CONTENT x = '{}; ASSIGNMENT_PATTERNConcatenation used instead of assignment pattern for struct x = {a : '0, b : ILLEGAL_CONCATENATION initialization '1}; ATTRIBUTEAttribute instance 'const' specifier not allowed ILLEGAL_CONST_SPECIFIER (* const int full_case=1, parallel_case *) ATTRIBUTEAttribute instance 'const' specifier not allowed ILLEGAL_DATA_TYPE_SPECIFIER (* const int full_case=1, parallel_case *) ATTRIBUTEAttribute instance followed by ';' not allowed ILLEGAL_SEMI (* full_case, parallel_case; *) CASEEmpty case statement not allowed MANDATORY_BRANCHES case (x) endcase CASTMissing tick on type casting expression MANDATORY_TICK int(some_var) CONFIGURATIONMissing ';' after configuration rule statement MANDATORY_SEMI CONSTANT_EXPRESSIONInside expression should not be placed in constant expression ILLEGAL_INSIDE_OPERATOR © AMIQ 77 int y inside {b, c} ? 10 : 2 [a]; Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com CONSTRAINT'default' qualifier not allowed ILLEGAL_DEFAULT_QUALIFIER default constraint a {...} CONSTRAINT'hard' qualifier not allowed ILLEGAL_HARD_SOLVE_BEFORE solve before hard; CONSTRAINTDist expression enclosed in parentheses ILLEGAL_PAREN (x dist {100 := 1, 200 := 2, 300 := 5}) x y CONSTRAINTMisplaced 'soft' keyword should be placed before the expression constraint ILLEGAL_SOFT_KEYWORD deflt { length inside {32, 1024} soft; } CONSTRAINTSpace between : and = in a dist_weight ILLEGAL_SPACE_1 x dist { 100 : = 1, 200 : = 2, 300 : = 5} CONSTRAINTSpace between : and / in a dist_weight ILLEGAL_SPACE_2 x dist {100 : / 1, 200 : = 2, 300 : = 5} CONSTRUCTORUsing 'automatic' lifetime for class constructor ILLEGAL_LIFETIME function automatic new(...); COVER_BINS_IFFBins 'iff' expression without parentheses MANDATORY_PAREN bins a = { 0:63,65 } iff ana; COVER_BINS_SELECTION'wildcard' specification not allowed ILLEGAL_WILDCARD bit 3:0 a, b; covergroup cov @(posedge clk); aXb : cross a, b { wildcard bins i_zero = binsof(a) intersect { 0 }; } endgroup COVER_BINS_SELECTION_IFFBins selection 'iff' expression without parentheses MANDATORY_PAREN COVER_BINSOF_COVERPOINTHierarchical identifier not allowed for cover point specification ILLEGAL_HIERARCHICAL © AMIQ 78 binsof(x.cover_point_id.bin_ // correct is binsof(cover_point_id.bin_id Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks COVER_BINSOF_BINSelect used in bin identifier ILLEGAL_SELECT www.dvteclipse.com binsof(cover_point_id.bin_id 3) COVERCROSS_IFFCovercross 'iff' expression without parentheses MANDATORY_PAREN COVERPOINT_IFFCoverpoint 'iff' expression without parentheses MANDATORY_PAREN coverpoint a iff test; DATA_TYPEPacked dimension for integer atom type (byte, shortint, int, longint, int 1:0 a; ILLEGAL_PACKED_DIMENSION_FOR_NON_BIT integer, time). DATA_TYPE'$typeof' system task is not allowed ILLEGAL_TYPEOF $typeof(a) b; DATA_TYPEPacked dimension should use constant range instead of constant enum bit 1 ILLEGAL_CONSTANT_EXPRESSION_FOR_PACKED_DIMENSION expression. { A, B } foo; DATA_TYPEPackage scope in enum base type not allowed ILLEGAL_PACKAGE_SCOPE_IN_ENUM_BASE_TYPE package package_name;...typedef int id;...endpackage...typedef enum package_name::id {R,G,B} x; DATA_TYPEInteger vector type or identifier before packed dimension is typedef MANDATORY_TYPE_IDENTIFIER_IN_ENUM_BASE_TYPE required enum 1:0 {R,G,B} x; DELAY_EXPRIdentifier followed by bit-select or part-select requires parentheses always ... MANDATORY_PAREN #del 0 ok = 1; DISABLE_STATEMENT'class_name::' not allowed in disable statement construct" ILLEGAL_CLASS_SCOPE disable a_class::a; DPI_STRINGDPI_C/DPI_SC should be replaced by DPI-C/DPI-SC ILLEGAL_UNDERSCORE import "DPI_C" init_1 = function void moo() END_LABELClass scope 'class_scope::' before end label not allowed ILLEGAL_CLASS_SCOPE ... endfunction : class_scope::func_name EVENT_CONTROLSelect used in event control ILLEGAL_SELECT @u_m3_1.a 1; EVENT_TRIGGER'class_name::' not allowed in event trigger construct" ILLEGAL_CLASS_SCOPE -> a_class::a; FATAL_ELABORATION_SYSTEM_TASKExpecting 0, 1 or 2 as $fatal first argument ILLEGAL_FINISH_NUMBER $fatal(4, "Sorry"); FATAL_ELABORATION_SYSTEM_TASKFinish number missing in $fatal call MANDATORY_FINISH_NUMBER $fatal("Sorry"); © AMIQ 79 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com FIELD'static const' outside class scope ILLEGAL_STATIC_CONST_OUTSIDE_CLASS module m;...static const c;...endmodule FOR_LOOP-'for' loop initialization is not optional MANDATORY_INITIALIZATION for (;i<10; i+ +) begin end FOR_LOOP-Only variable assignments allowed as 'for' initialization statement for (+ ILLEGAL_INITIALIZATION +count;count<10; ++count) begin end FOR_LOOP-'for' loop conditional expression is not optional" MANDATORY_EXIT_CONDITION for (i=1;; i+ +) begin end FOR_LOOP-'for' loop step is not optional MANDATORY_STEP for (i=1;i<10;) begin end FOREACH_LOOPMultidimensional array select in foreach loop ILLEGAL_MULTIPLE_BRACKETS int A 2 3 4;...foreach(A i-1 pkg::j k) begin ... end FUNCTION-Missing 'function' keyword in prototype declaration" MANDATORY_FUNCTION_KEYWORD extern int f(); FUNCTION-Empty arguments list '()' not allowed when arguments declared task print(); ILLEGAL_EMPTY_ARGUMENTS_LIST inside function/task body" input string message; // task print; input string message is correct FUNCTION-'pure' qualifier not allowed before # class qualifier ILLEGAL_PURE_VIRTUAL_KEYWORD_ORDER pure local virtual function void foo(); // pure virtual local function foo() is correct. FUNCTION-Signing before data type ILLEGAL_SIGNING_BEFORE_RETURN_DATA_TYPE function unsigned int foo(); endfunction FUNCTION-'static' qualifier not allowed ILLEGAL_STATIC_QUALIFIER static function foo();...endfunction © AMIQ 80 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com FUNCTION-Extern function is not implemented MANDATORY_IMPLEMENTATION_OF_EXTERN FUNCTION-Extern function out-of-body declaration must be in the same scope function ILLEGAL_PACKAGE_SCOPE_FOR_EXTERN_IMPL as the class void a_package::a_class::a_functi FUNCTION-Extern global function not allowed ILLEGAL_EXTERN_DECLARATION_IN_GLOBAL_SCOPE extern foo(); int FUNCTION-Function prototype return data type or void missing MISSING_FUNCTION_RETURN_DATA_TYPE_OR_VOID function doCheck(); FUNCTION-Range selection of randomize argument 'arg_name' not allowed ILLEGAL_SELECT_ON_RANDOMIZE_ARGUMENT std::randomize(rand_var 7:0) with {...}; FUNCTION-Hierarchical interface identifier 'id1.id2' not allowed ILLEGAL_HIERARCHICAL_INTERFACE_IDENTIFIER task id1.id2.id3(); GENERATE_BEGIN'begin/end' generate block in module or interface ILLEGAL_IN_MODULE_OR_INTF GENERATE_BEGIN'begin/end' generate block in program ILLEGAL_IN_PROGRAM IDENTIFIERReserved keyword # used as an identifier ILLEGAL_IT_IS_A_RESERVED_KEYWORD instance, restrict, checker, table, cell, config, design IFDEF`ifdef, `ifndef, `elsif must be followed by an identifier instead of MANDATORY_IDENTIFIER '`<defined_name>' INSIDE_OPERATORThe value range after inside should be placed between curly braces if ( a inside MANDATORY_CURLY_BRACES {} x) LVALUE- Hierarchical name using subroutine call not allowed ILLEGAL_METHOD_CALL_IN_HIERARCIHCAL_IDENTIFIER $root.m4.foo().y = 10; MODPORT- Hierarchical identifier not allowed in modport port declaration ILLEGAL_HIERARCHICAL_IDENTIFIER interface i2; wire clk; wire gnt; clocking sb @(posedge clk); output gnt; endclocking modport master (output sb.gnt);endinterface MODPORT- .* used in modport import/export declaration ILLEGAL_DOT_STAR_IMPORT_EXPORT interface i2; wire clk; © AMIQ 81 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com task masterRead(input logic 7:0 raddr); endtask clocking sb @(posedge clk); endclocking modport master (import sb.*);endinterface MODPORT- Missing modport port s declaration MISSING_PORTS_DECLARATION modport mp_name(); MODULE- Missing instance name in instantiation of '<module_name>' MANDATORY_INSTANCE_NAME module top(input i, output o); m1(.i(i), .o(o)); endmodule module m1(input i, output o); endmodule PACKAGE- Misplaced initial block construct ILLEGAL_INITIAL_BLOCK package p1;initial begin end;endpackage PARAMETER_ASSIGNMENTUnsized dimension is not allowed in parameter assignment ILLEGAL_UNSIZED_DIMENSION parameter logic flag1[] = '{2}; localparam logic flag2[] = '{2}; PARAMETER_ASSIGNMENTParameter value not enclosed in parentheses MANDATORY_PAREN module m #(P1=1) ();endmodule module top();m # 3 u_m();endmodule PARAMETER_ASSIGNMENTEmpty ordered parameter assignment MANDATORY_WHEN_ORDERED xmm_atomic_gen #(transaction, ,"Atomic Gen") msg_rx_gen; PORT_CONNECTIONImplicit port connection '.*' cannot appear more than once in the m SINGLE_IMPLICIT_CONNECTION port list u_m(.*, .*) © AMIQ 82 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 5. Compile Checks www.dvteclipse.com PRIMITIVE_OUTPUT_TERMINALPrimitive output terminal enclosed in parentheses ILLEGAL_PAREN nor (highz1,strong0) n1((out1),in1,in2); PRIMITIVE_INOUT_TERMINALPrimitive inout terminal enclosed in parentheses ILLEGAL_PAREN tranif0 ti0 (x, (y), z); PROPERTY-Missing ';' after property statement MANDATORY_SEMI -> b endproperty REPLICATION_OPERATORRange multiple concatenation not allowed ILLEGAL_RANGE {2:3{1}} SPECIFY- Missing timing check limits not allowed MANDATORY_SETUPHOLD_TIMING_CHECK_LIMITS $setuphold( posedge clk, data); SPECIFY- Null $width arg MANDATORY_WIDTH_ARGUMENTS $width( negedge clr, lim, , notif ); SPECIFY- Parallel path description list of inputs not allowed ILLEGAL_LIST_OF_SOURCE_IN_PARALLEL_PATH (in1,in2 => q 1) = 1; STRING- Use '\\' in order to continue to the next line MANDATORY_BACKSLASH_FOR_NEXT_LINE string my_s = "string is splitted on multiple lines"; STREAM_CONCATENATIONPacked dimension on stream concatenation simple type SIMPLE_TYPE_PACKED_DIMENSION result = { >> bit 7:0 { variable_name } }; TASKExtern task is not implemented MANDATORY_IMPLEMENTATION_OF_EXTERN TASKExtern task out-of-body declaration must be in the same scope as ILLEGAL_PACKAGE_SCOPE_FOR_EXTERN_IMPL the class TEMPORAL_GOTO_OR_NON_CONSECUTIVE_REPEAT_OPERATORGoto repeat '[->' and non-consecutive repeat '[=' operators take ILLEGAL_SYNTAX boolean expressions only TIME_UNITS_AND_PRECISIONThe unsigned number or fixed point number in time literal shall timeunit 10 ILLEGAL_SPACE not be followed by whitespace ps; TYPEDEF- Typedef covergroup ILLEGAL_COVERGROUP typedef covergroup my_coverg; WILD_EQUALITY_OPERATORWild equality operator '=?=' not standard, use '==?' instead. ILLEGAL_SYNTAX WILD_EQUALITY_NOT_OPERATORWild equality not operator '!?=' not standard, use '!=?' instead. ILLEGAL_SYNTAX USELIB_DIRECTIVEVerilog-XL directive `uselib non standard, use -y, -v, and +libext ILLEGAL_SYNTAX command line flags instead. © AMIQ 83 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 6. Content Assist (Autocomplete) Content assist (autocomplete) can be triggered explicitly if you press Ctrl+Space in any code context. Some of the contexts when content assist is triggered automatically as you type are: • when you type a dot (.) for accessing a struct member (field, method etc) as in bfm.do_write() • when you type a compare (==) in an expression as in if (mode == Proposals are presented in a list for you to choose from. Moving through proposals you can quickly see the related documentation. Press Enter or click to select a proposal or Esc to cancel the assist. © AMIQ 84 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 6. Content Assist (Autocomplete) www.dvteclipse.com Sometimes autocomplete has many proposals that are split in several categories: 1. the first one is for things you can access in a scope (wires, regs, functions, tasks etc. depending on the enclosing scope) 2. the second one is for code templates 3. the third one is for other things, like module instances If you press Ctrl+Space the first time, you'll see a small indication in the proposals pop-up window at the bottom, something like "Press Ctrl+Space again to see template proposals". Pressing Ctrl+Space cycles through the categories above. 6.1 Content assist for CamelCase and Underscore You can quickly filter the proposals list by using capital letters or underscores as anchors like the the examples below: Variable Name Substrings that do find variable Substrings that don't find the variable uvmTestDoneObjectionBase uTesDonObj, DoneObj, TDOB estDone, tionBase uvm_test_done_objection_base uv_te_d_o_b, t_d_o, TDO ne_objection uvm_TESTDone_objectionBASE uv_T_D_o_b, TESDOB test_done_objection_base, ESTDone_, one_objection Natural behavior with ignore case turned on or off. 6.2 Code Templates Code templates are presented in content assist. Press the first letters from the template name then click Ctrl+Space twice to get a list of available templates. © AMIQ 85 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 6. Content Assist (Autocomplete) www.dvteclipse.com 6.3 Module Automatic Instantiation You need to type the first letters of the module name, then press Ctrl+Space three (3) times. You can recognize module instances by their icon, it looks like a chip with ports ready to be glued in. © AMIQ 86 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 6. Content Assist (Autocomplete) www.dvteclipse.com 6.4 Override Functions Using Autocomplete Write function or task and then press Ctrl + Space and a list with all available methods will pop-up. You can type the first letters of the method's name to filter out the list. © AMIQ 87 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 7. Content Filters Apply Content Filters to remove irrelevant information displayed in views. See Content Filters Examples for a list of use cases and examples. Toggle the content filtering functionality (on/off) with this toolbar button: . All views have a special indication that is: • enabled if some content has been filtered • disabled if no content has been filtered or content filters off For example in Types View: By default, elements from the UVM, OVM and VMM libraries are filtered. See Predefined Content Filters for details. You can define custom Content Filters in the .dvt/content_filters.xml file. To quickly create .dvt/content_filters.xml with some example filters, right click on the project and go to New > DVT Content Filters XML. See Content Filters XML syntax. 7.1 Content Filters XML syntax The .dvt/content_filters.xml file contains filter definitions using the syntax documented below. When editing .dvt/content_filters.xml you can use Autocomplete by pressing Ctrl + Space. Any errors encountered while loading the .dvt/content_filters.xml are reported in the DVT Internal Build Console. <!-XML file header; required. --> <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE content-filters PUBLIC "-//DVT//content_filters" "content_filters.dtd" > <!-Root tag; required. Version attribute is required. The latest syntax version, illustrated by this example, is version 1. --> © AMIQ 88 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <content-filters version="1"> <!-The root tag must contain at least one filter. An element is filtered if it matches all the filters. The filter tag must specify the kind="HIDE" attribute. The filter tag may specify a name attribute. --> <filter kind="HIDE" name="Filter name"> <description>An optional verbose description of the filter.</description> <!-Each filter must specify at least one of the following tags: path-set, element-text-set or element-type-set --> <!-The path-set tag must specify a match attribute. If match="TRUE" the set comprises of the enumerated paths (see below). If match="FALSE" the set comprises any path except the enumerated ones (see below). An element (problem, task, type, function, macro etc) matches the path-set if it is defined/introduced in a file within the path-set. The path-set tag may specify an apply-to-macro-call-stack attribute. By default apply-to-macro-call-stack="FALSE". If apply-to-macro-call-stack="TRUE" an element introduced by a macro call will match the path set if the macro matches the path-set. --> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <!-A path-set must contain at least a path attribute. The path tag must specify a pattern attribute. The pattern may contain wildcards ? (any character) and * (any sequence of characters). The pattern may contain environment variables. You may not use variables defined in build configuration files using +dvt_env+ directive. The path tag may specify an include-children attribute. By default include-children="FALSE". If include-children="TRUE" any file `included (SystemVerilog) or imported (e Language) directly or indirectly by a file matching the pattern, is also part of the path-set. --> <path pattern="*/uvm_pkg.sv" include-children="TRUE" /> <path pattern="*/vr_ad_top.e" include-children="TRUE" /> </path-set> <!-The element-text-set tag must specify a match attribute. If match="TRUE", an element matches the set if it matches any element-text tag. © AMIQ 89 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com If match="FALSE", an element matches the set if it does not match any element-text tag. An element (problem, task, type, function, macro etc) matches the text-set if its displayed label matches the text-set. --> <element-text-set match="TRUE"> <!-An element-text-set must contain at least one element-text tag. The element-text tag must specify a pattern attribute. The pattern may contain wildcards ? (any character) and * (any sequence of characters). --> <element-text pattern="_internal_*"/> </element-text-set> <!-The element-type-set tag must specify a match attribute. If match="TRUE", an element matches if it matches any element-type tag. If match="FALSE", an element matches if it does not match any element-type tag. --> <element-type-set match="TRUE"> <!-An element-type-set must contain at least one element-type tag. The element-type tag must specify the name attribute. Valid values for the element-type name are: COVER, EVENT, ONEVENT, EXPECT, MACRO, METHOD, METHOD_TYPE, SCALAR_TYPE, STRUCT, ACTION_BLOCK, ASSERT_EXPECT, CHECKER, CLASS, CLOCKING_BLOCK, CONSTRAINT, COVERGROUP, COVERPOINT, COVERCROSS, FIELD, FUNCTION, GENERATE_BLOCK, INTERFACE, MODPORT, MODULE, PACKAGE, PRIMITIVE, PROGRAM, PROPERTY_SEQUENCE, TYPE_ALIAS, PARAMETER, TYPE_PARAMETER, ARCHITECTURE, BLOCK, COMPONENT, ENTITY, PACKAGE_BODY, CONFIGURATION, INSTANCE, SIGNAL, PORT, PROCESS, VARIABLE, TYPE The element-type tag may specify a language attribute which helps to fully identify an element which is valid in multiple languages (for example STRUCT is a valid element type both in SystemVerilog and e Language) The valid values for the language attribute are: E, SV and VHDL. --> <element-type name="STRUCT" language="SV" /> </element-type-set> <!-Each filter may specify a view-set tag. If view-set is not specified, the filter applies to all views. The view-set tag must specify a match attribute. If match="TRUE" the set comprises of the enumerated views (see below). If match="FALSE" the set comprises all views except the enumerated ones (see below). --> <view-set match="TRUE"> <!-© AMIQ 90 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com A view-set must contain at least one view tag. The view tag must specify the name attribute. Possible values for the name attribute are: DESIGN_HIERARCHY, DIAGRAM, TYPE_HIERARCHY_MEMBERS, MACRO, OUTLINE, PROBLEMS, SEARCH, T TYPES_MEMBERS, UVM_BROWSER_CLASSES, UVM_BROWSER_MEMBERS --> <view name="TASKS" /> </view-set> </filter> </content-filters> 7.2 Content Filters Examples • Hide the Types, Tasks and Problems from a library <filter kind="HIDE" name="Base classes"> <description>Hide the Types, Tasks and Problems from /path/to/my_base_classes</description> <view-set match="TRUE"> <view name="TYPES" /> <view name="TASKS" /> <view name="PROBLEMS" /> </view-set> <path-set match="TRUE"> <path pattern="/path/to/my_base_classes/*" /> </path-set> </filter> • Hide the Tasks and Problems from a library <filter kind="HIDE" name="My library"> <description>Hide the Tasks and Problems from files included by my_library_top.svh</description> <view-set match="TRUE"> <view name="TASKS" /> <view name="PROBLEMS" /> </view-set> <path-set match="TRUE"> <path include-children="TRUE" pattern="*/my_library_top.svh" /> </path-set> </filter> • Hide from Outline View the functions and fields introduced by specific macros <filter kind="HIDE" name="Noisy macros"> <description>Hide from Outline View the functions and fields introduced by macros defined in files under <view-set match="TRUE"> <view name="OUTLINE" /> </view-set> <path-set apply-to-macro-call-stack="TRUE" match="TRUE"> <path pattern="$MY_MACROS_LIBRARY/*" /> © AMIQ 91 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com </path-set> <element-type-set match="TRUE"> <element-type name="FUNCTION"/> <element-type name="FIELD"/> </element-type-set> </filter> • See only tasks that contain REVIEW_FIRST from a library <filter kind="HIDE" name="REVIEW_FIRST tasks"> <description>Hide the tasks that don't contain REVIEW_FIRST from /path/to/my_in_progress_folder</de <view-set match="TRUE"> <view name="TASKS" /> </view-set> <path-set match="TRUE"> <path pattern="/path/to/my_in_progress_folder/*" /> </path-set> <element-text-set match="FALSE"> <element-text pattern="*REVIEW_FIRST*"/> </element-text-set> </filter> 7.3 Predefined Content Filters By default, elements defined in the UVM, OVM and VMM libraries are filtered out by Predefined Content Filters from the following views: • Design Hierarchy • Diagram • Macros (and Quick Macros) • Outline (and Quick Outline) • Problems • Search • Tasks • Type Hierarchy (Members Panel) • Types (and Quick Types) • UVM Browser (Classes and Members Panels) You can easily enable/disable Predefined Content Filters form the preference page: menu Window > Preferences then DVT > Content Filters. © AMIQ 92 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com The Predefined Content Filters definitions are: <filter kind="HIDE"> <view-set match="TRUE"> <view name="DESIGN_HIERARCHY"/> <view name="OUTLINE"/> <view name="PROBLEMS"/> <view name="SEARCH"/> <view name="TASKS"/> <view name="TYPES"/> <view name="TYPE_HIERARCHY_MEMBERS"/> <view name="UVM_BROWSER_CLASSES"/> <view name="UVM_BROWSER_MEMBERS"/> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/ovm.svh" /> <path include-children="TRUE" pattern="*/ovm_pkg.sv" /> <path include-children="TRUE" pattern="*/ovm_e_top.e" /> </path-set> </filter> <filter kind="HIDE"> <view-set match="TRUE"> <view name="DESIGN_HIERARCHY"/> <view name="OUTLINE"/> <view name="PROBLEMS"/> <view name="SEARCH"/> <view name="TASKS"/> <view name="TYPES"/> <view name="TYPE_HIERARCHY_MEMBERS"/> <view name="UVM_BROWSER_CLASSES"/> <view name="UVM_BROWSER_MEMBERS"/> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/uvm.svh" /> <path include-children="TRUE" pattern="*/uvm_pkg.sv" /> <path include-children="TRUE" pattern="*/uvm_e_top.e" /> </path-set> </filter> <filter kind="HIDE"> <view-set match="TRUE"> <view name="DESIGN_HIERARCHY"/> <view name="OUTLINE"/> <view name="PROBLEMS"/> <view name="SEARCH"/> <view name="TASKS"/> <view name="TYPES"/> <view name="TYPE_HIERARCHY_MEMBERS"/> © AMIQ 93 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <view name="UVM_BROWSER_CLASSES"/> <view name="UVM_BROWSER_MEMBERS"/> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/vmm.sv" /> </path-set> </filter> <filter name="OVM Predefined Diagram Filter" kind="HIDE"> <view-set match="TRUE"> <view name="DIAGRAM" /> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/ovm.svh" /> <path include-children="TRUE" pattern="*/ovm_pkg.sv" /> <path include-children="TRUE" pattern="*/ovm_e_top.e" /> </path-set> <element-type-set match="FALSE"> <element-type name="CLASS" language="E"/> <element-type name="CLASS" language="SV"/> </element-type-set> </filter> <filter name="UVM Predefined Diagram Filter" kind="HIDE"> <view-set match="TRUE"> <view name="DIAGRAM" /> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/uvm.svh" /> <path include-children="TRUE" pattern="*/uvm_pkg.sv" /> <path include-children="TRUE" pattern="*/uvm_e_top.e" /> </path-set> <element-type-set match="FALSE"> <element-type name="CLASS" language="E"/> <element-type name="CLASS" language="SV"/> </element-type-set> </filter> <filter name="VMM Predefined Diagram Filter" kind="HIDE"> <view-set match="TRUE"> <view name="DIAGRAM" /> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/vmm.sv" /> </path-set> <element-type-set match="FALSE"> <element-type name="CLASS" language="E"/> <element-type name="CLASS" language="SV"/> </element-type-set> © AMIQ 94 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com </filter> <filter name="UVM Predefined Macros View Filter" kind="HIDE"> <view-set match="TRUE"> <view name="MACRO" /> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/uvm.svh" /> <path include-children="TRUE" pattern="*/uvm_pkg.sv" /> </path-set> <element-text-set match="FALSE"> <element-text pattern="uvm_info" /> <element-text pattern="uvm_warning" /> <element-text pattern="uvm_error" /> <element-text pattern="uvm_fatal" /> <element-text pattern="uvm_info_context" /> <element-text pattern="uvm_warning_context" /> <element-text pattern="uvm_error_context" /> <element-text pattern="uvm_fatal_context" /> <element-text pattern="uvm_field_utils_begin" /> <element-text pattern="uvm_field_utils_end" /> <element-text pattern="uvm_object_utils" /> <element-text pattern="uvm_object_param_utils" /> <element-text pattern="uvm_object_utils_begin" /> <element-text pattern="uvm_object_param_utils_begin" /> <element-text pattern="uvm_object_utils_end" /> <element-text pattern="uvm_component_utils" /> <element-text pattern="uvm_component_param_utils" /> <element-text pattern="uvm_component_utils_begin" /> <element-text pattern="uvm_component_param_utils_begin" /> <element-text pattern="uvm_component_end" /> <element-text pattern="uvm_object_registry" /> <element-text pattern="uvm_component_registry" /> <element-text pattern="uvm_field_int" /> <element-text pattern="uvm_field_object" /> <element-text pattern="uvm_field_string" /> <element-text pattern="uvm_field_enum" /> <element-text pattern="uvm_field_real" /> <element-text pattern="uvm_field_event" /> <element-text pattern="uvm_field_sarray_int" /> <element-text pattern="uvm_field_sarray_object" /> <element-text pattern="uvm_field_sarray_string" /> <element-text pattern="uvm_field_sarray_enum" /> <element-text pattern="uvm_field_array_int" /> <element-text pattern="uvm_field_array_object" /> <element-text pattern="uvm_field_array_string" /> <element-text pattern="uvm_field_array_enum" /> <element-text pattern="uvm_field_queue_int" /> © AMIQ 95 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <element-text pattern="uvm_field_queue_object" /> <element-text pattern="uvm_field_queue_string" /> <element-text pattern="uvm_field_queue_enum" /> <element-text pattern="uvm_field_aa_int_string" /> <element-text pattern="uvm_field_aa_object_string" /> <element-text pattern="uvm_field_aa_string_string" /> <element-text pattern="uvm_field_aa_object_int" /> <element-text pattern="uvm_field_aa_int_int" /> <element-text pattern="uvm_field_aa_int_int_unsigned" /> <element-text pattern="uvm_field_aa_int_integer" /> <element-text pattern="uvm_field_aa_int_integer_unsigned" /> <element-text pattern="uvm_field_aa_int_byte" /> <element-text pattern="uvm_field_aa_int_byte_unsigned" /> <element-text pattern="uvm_field_aa_int_shortint" /> <element-text pattern="uvm_field_aa_int_shortint_unsigned" /> <element-text pattern="uvm_field_aa_int_longint" /> <element-text pattern="uvm_field_aa_int_longint_unsigned" /> <element-text pattern="uvm_field_aa_int_key" /> <element-text pattern="uvm_field_aa_int_enumkey" /> <element-text pattern="uvm_record_attribute" /> <element-text pattern="uvm_record_field" /> <element-text pattern="uvm_pack_intN" /> <element-text pattern="uvm_pack_enumN" /> <element-text pattern="uvm_pack_sarrayN" /> <element-text pattern="uvm_pack_arrayN" /> <element-text pattern="uvm_pack_queueN" /> <element-text pattern="uvm_pack_int" /> <element-text pattern="uvm_pack_enum" /> <element-text pattern="uvm_pack_string" /> <element-text pattern="uvm_pack_real" /> <element-text pattern="uvm_pack_sarray" /> <element-text pattern="uvm_pack_array" /> <element-text pattern="uvm_pack_queue" /> <element-text pattern="uvm_unpack_intN" /> <element-text pattern="uvm_unpack_enumN" /> <element-text pattern="uvm_unpack_sarrayN" /> <element-text pattern="uvm_unpack_arrayN" /> <element-text pattern="uvm_unpack_queueN" /> <element-text pattern="uvm_unpack_int" /> <element-text pattern="uvm_unpack_enum" /> <element-text pattern="uvm_unpack_string" /> <element-text pattern="uvm_unpack_real" /> <element-text pattern="uvm_unpack_sarray" /> <element-text pattern="uvm_unpack_array" /> <element-text pattern="uvm_unpack_queue" /> <element-text pattern="uvm_create" /> <element-text pattern="uvm_do" /> <element-text pattern="uvm_do_pri" /> © AMIQ 96 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <element-text pattern="uvm_do_with" /> <element-text pattern="uvm_do_pri_with" /> <element-text pattern="uvm_create_on" /> <element-text pattern="uvm_do_on" /> <element-text pattern="uvm_do_on_pri" /> <element-text pattern="uvm_do_on_with" /> <element-text pattern="uvm_do_on_pri_with" /> <element-text pattern="uvm_send" /> <element-text pattern="uvm_send_pri" /> <element-text pattern="uvm_rand_send" /> <element-text pattern="uvm_rand_send_pri" /> <element-text pattern="uvm_rand_send_with" /> <element-text pattern="uvm_rand_send_pri_with" /> <element-text pattern="uvm_declare_p_sequencer" /> <element-text pattern="uvm_register_cb" /> <element-text pattern="uvm_set_super_type" /> <element-text pattern="uvm_do_callbacks" /> <element-text pattern="uvm_do_obj_callbacks" /> <element-text pattern="uvm_do_callbacks_exit_on" /> <element-text pattern="uvm_do_obj_callbacks_exit_on" /> <element-text pattern="uvm_blocking_put_imp_decl" /> <element-text pattern="uvm_nonblocking_put_imp_decl" /> <element-text pattern="uvm_put_imp_decl" /> <element-text pattern="uvm_blocking_get_imp_decl" /> <element-text pattern="uvm_nonblocking_get_imp_decl" /> <element-text pattern="uvm_get_imp_decl" /> <element-text pattern="uvm_blocking_peek_imp_decl" /> <element-text pattern="uvm_nonblocking_peek_imp_decl" /> <element-text pattern="uvm_peek_imp_decl" /> <element-text pattern="uvm_blocking_get_peek_imp_decl" /> <element-text pattern="uvm_nonblocking_get_peek_imp_decl" /> <element-text pattern="uvm_get_peek_imp_decl" /> <element-text pattern="uvm_blocking_master_imp_decl" /> <element-text pattern="uvm_nonblocking_master_imp_decl" /> <element-text pattern="uvm_master_imp_decl" /> <element-text pattern="uvm_blocking_slave_imp_decl" /> <element-text pattern="uvm_nonblocking_slave_imp_decl" /> <element-text pattern="uvm_slave_imp_decl" /> <element-text pattern="uvm_blocking_transport_imp_decl" /> <element-text pattern="uvm_nonblocking_transport_imp_decl" /> <element-text pattern="uvm_transport_imp_decl" /> <element-text pattern="uvm_analysis_imp_decl" /> <element-text pattern="UVM_REG_ADDR_WIDTH" /> <element-text pattern="UVM_REG_DATA_WIDTH" /> <element-text pattern="UVM_REG_BYTENABLE_WIDTH" /> <element-text pattern="UVM_REG_CVR_WIDTH" /> <element-text pattern="UVM_DEFAULT_TIMEOUT" /> <element-text pattern="UVM_MAX_STREAMBITS" /> © AMIQ 97 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <element-text pattern="UVM_PACKER_MAX_BYTES" /> <element-text pattern="UVM_TLM_B_MASK" /> <element-text pattern="UVM_TLM_B_TRANSPORT_IMP" /> <element-text pattern="UVM_TLM_FUNCTION_ERROR" /> <element-text pattern="UVM_TLM_NB_BW_MASK" /> <element-text pattern="UVM_TLM_NB_FW_MASK" /> <element-text pattern="UVM_TLM_NB_TRANSPORT_BW_IMP" /> <element-text pattern="UVM_TLM_NB_TRANSPORT_FW_IMP" /> <element-text pattern="UVM_TLM_TASK_ERROR" /> </element-text-set> </filter> <filter name="OVM Predefined Macros View Filter" kind="HIDE"> <view-set match="TRUE"> <view name="MACRO" /> </view-set> <path-set match="TRUE" apply-to-macro-call-stack="TRUE"> <path include-children="TRUE" pattern="*/ovm.svh" /> <path include-children="TRUE" pattern="*/ovm_pkg.sv" /> </path-set> <element-text-set match="FALSE"> <element-text pattern="ovm_phase_func_decl" /> <element-text pattern="ovm_phase_task_decl" /> <element-text pattern="ovm_phase_func_topdown_decl" /> <element-text pattern="ovm_phase_func_bottomup_decl" /> <element-text pattern="ovm_phase_task_topdown_decl" /> <element-text pattern="ovm_phase_task_bottomup_decl" /> <element-text pattern="ovm_info" /> <element-text pattern="ovm_warning" /> <element-text pattern="ovm_error" /> <element-text pattern="ovm_fatal" /> <element-text pattern="ovm_field_utils_begin" /> <element-text pattern="ovm_field_utils_end" /> <element-text pattern="ovm_object_utils" /> <element-text pattern="ovm_object_param_utils" /> <element-text pattern="ovm_object_utils_begin" /> <element-text pattern="ovm_object_param_utils_begin" /> <element-text pattern="ovm_object_utils_end" /> <element-text pattern="ovm_component_utils" /> <element-text pattern="ovm_component_param_utils" /> <element-text pattern="ovm_component_utils_begin" /> <element-text pattern="ovm_component_param_utils_begin" /> <element-text pattern="ovm_component_end" /> <element-text pattern="ovm_field_int" /> <element-text pattern="ovm_field_object" /> <element-text pattern="ovm_field_string" /> <element-text pattern="ovm_field_enum" /> <element-text pattern="ovm_field_real" /> © AMIQ 98 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <element-text pattern="ovm_field_event" /> <element-text pattern="ovm_field_sarray_int" /> <element-text pattern="ovm_field_sarray_object" /> <element-text pattern="ovm_field_sarray_string" /> <element-text pattern="ovm_field_sarray_enum" /> <element-text pattern="ovm_field_array_int" /> <element-text pattern="ovm_field_array_object" /> <element-text pattern="ovm_field_array_string" /> <element-text pattern="ovm_field_array_enum" /> <element-text pattern="ovm_field_queue_int" /> <element-text pattern="ovm_field_queue_object" /> <element-text pattern="ovm_field_queue_string" /> <element-text pattern="ovm_field_queue_enum" /> <element-text pattern="ovm_field_aa_int_string" /> <element-text pattern="ovm_field_aa_object_string" /> <element-text pattern="ovm_field_aa_string_string" /> <element-text pattern="ovm_field_aa_object_int" /> <element-text pattern="ovm_field_aa_int_int" /> <element-text pattern="ovm_field_aa_int_int_unsigned" /> <element-text pattern="ovm_field_aa_int_integer" /> <element-text pattern="ovm_field_aa_int_integer_unsigned" /> <element-text pattern="ovm_field_aa_int_byte" /> <element-text pattern="ovm_field_aa_int_byte_unsigned" /> <element-text pattern="ovm_field_aa_int_shortint" /> <element-text pattern="ovm_field_aa_int_shortint_unsigned" /> <element-text pattern="ovm_field_aa_int_longint" /> <element-text pattern="ovm_field_aa_int_longint_unsigned" /> <element-text pattern="ovm_field_aa_int_key" /> <element-text pattern="ovm_field_aa_int_enumkey" /> <element-text pattern="ovm_declare_p_sequencer" /> <element-text pattern="ovm_sequence_utils_begin" /> <element-text pattern="ovm_sequence_utils_end" /> <element-text pattern="ovm_sequence_utils" /> <element-text pattern="ovm_update_sequence_lib" /> <element-text pattern="ovm_update_sequence_lib_and_item" /> <element-text pattern="ovm_sequencer_utils" /> <element-text pattern="ovm_sequencer_utils_begin" /> <element-text pattern="ovm_sequencer_param_utils" /> <element-text pattern="ovm_sequencer_param_utils_begin" /> <element-text pattern="ovm_sequencer_utils_end" /> <element-text pattern="ovm_create" /> <element-text pattern="ovm_do" /> <element-text pattern="ovm_do_pri" /> <element-text pattern="ovm_do_with" /> <element-text pattern="ovm_do_pri_with" /> <element-text pattern="ovm_send" /> <element-text pattern="ovm_send_pri" /> <element-text pattern="ovm_rand_send" /> © AMIQ 99 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 7. Content Filters www.dvteclipse.com <element-text pattern="ovm_rand_send_pri" /> <element-text pattern="ovm_rand_send_with" /> <element-text pattern="ovm_rand_send_pri_with" /> <element-text pattern="ovm_create_on" /> <element-text pattern="ovm_do_on" /> <element-text pattern="ovm_do_on_pri" /> <element-text pattern="ovm_do_on_with" /> <element-text pattern="ovm_do_on_pri_with" /> <element-text pattern="ovm_blocking_put_imp_decl" /> <element-text pattern="ovm_nonblocking_put_imp_decl" /> <element-text pattern="ovm_put_imp_decl" /> <element-text pattern="ovm_blocking_get_imp_decl" /> <element-text pattern="ovm_nonblocking_get_imp_decl" /> <element-text pattern="ovm_get_imp_decl" /> <element-text pattern="ovm_blocking_peek_imp_decl" /> <element-text pattern="ovm_nonblocking_peek_imp_decl" /> <element-text pattern="ovm_peek_imp_decl" /> <element-text pattern="ovm_blocking_get_peek_imp_decl" /> <element-text pattern="ovm_nonblocking_get_peek_imp_decl" /> <element-text pattern="ovm_get_peek_imp_decl" /> <element-text pattern="ovm_blocking_master_imp_decl" /> <element-text pattern="ovm_nonblocking_master_imp_decl" /> <element-text pattern="ovm_master_imp_decl" /> <element-text pattern="ovm_blocking_slave_imp_decl" /> <element-text pattern="ovm_nonblocking_slave_imp_decl" /> <element-text pattern="ovm_slave_imp_decl" /> <element-text pattern="ovm_blocking_transport_imp_decl" /> <element-text pattern="ovm_nonblocking_transport_imp_decl" /> <element-text pattern="ovm_transport_imp_decl" /> <element-text pattern="ovm_analysis_imp_decl" /> <element-text pattern="ovm_do_callbacks" /> <element-text pattern="ovm_do_obj_callbacks" /> <element-text pattern="ovm_do_callbacks_exit_on" /> <element-text pattern="ovm_do_obj_callbacks_exit_on" /> <element-text pattern="ovm_do_task_callbacks" /> <element-text pattern="ovm_do_ext_task_callbacks" /> </element-text-set> </filter> © AMIQ 100 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 8. Code Templates 8.1 Code Templates in Autocomplete Type the first letters from the code template name, then press Ctrl+Space twice to see code template proposals. Proposals are suggested using Global Code Templates and Project Level Code Templates. SystemVerilog: e Language: VHDL: © AMIQ 101 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 8. Code Templates www.dvteclipse.com 8.2 Global Code Templates To see the list of global code templates go to menu Window > Preferences then select the DVT > Code Templates preference page. Click the New button to define a new template. NOTE: The template name is important for autocomplete proposal filtering based on already typed text! See more details here. 8.3 Project Level Code Templates Project level code templates are available in autocomplete only for the respective project. You cannot use them in other projects - as opposed to Global Code Templates. © AMIQ 102 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 8. Code Templates www.dvteclipse.com To see the list of project level code templates Right-click on a project in Navigator > Properties > DVT > Code Templates. Click the New button to define a new template. NOTE: The template name is important for autocomplete proposal filtering based on already typed text! See more details here. After selecting a template, press Enter and it is automatically inserted at the current position in the active editor. 8.4 Code Templates View The Code Templates is located near the Navigator and Hierarchy views or you can open it from Window > Show View > Other... > DVT > Code Templates. To insert a template in a code editor, you can either: © AMIQ 103 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 8. Code Templates www.dvteclipse.com • drag and drop it in the editor at a specific location • double click on it • click on Insert into editor button • right-click on it > Insert Note: if you choose one of the last three actions mentioned above, the template will be inserted in the current editor at the current cursor's positon. Please make sure you have an opened editor and the cursor is at the right position before adding the template!' 1. Insert the selected template into the current editor 2. Create a new template 3. Edit the selected template 4. Remove the selected template ( NOTE: you cannot undo this operation!) 5. Refresh the view (if it doesn't automatically update when you modify templates/projects etc.) 6. Collapse/expand all 7. Filter templates (you can filter them by: nature, context, name, project, description) 8. Templates' natures © AMIQ 104 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 8. Code Templates www.dvteclipse.com 9. A global template 10.A project template 11.Templates' contexts 12.Preview the template's pattern (it automatically updates when clicking on a template) To create a new template, click on Create a New Template button on the toolbar: 1. Template's name 2. Check Automatically insert if you want the template to expand automatically on ctrl-space when there is no other matching template available. It is usually good idea to leave the checkbox checked, otherwise you would get a template proposal "popup" 3. Each template must be created under a project available in the current workspace (select ['' ''global ] for a global template) 4. Assign a nature - only natures relevant to the selected project will be displayed 5. Template's context - only contexts relevant to the selected nature will be displayed 6. Templates's description 7. Code Pattern - embed variables in ${} e.g. ${ variable_name} to enable the template proposal wizard when inserting the template into an editor 8. Insert variables - here you can find some useful misc. predefined variables © AMIQ 105 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 9. File Templates Whenever you create a new file using the New File Wizard, you can pick a file template. A file template is a code template with the context set to File Content. For more details see Code Templates. © AMIQ 106 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 10. Project Templates 10.1 What is a project template? A project template is a parameterized directory tree. Both in the file contents (.v, .sv, .sh, .e, .vhd, .txt - practically any file) and in the file or directory names you can use parameters. Combined with TODO markers, you can use a project template as a customized wizard. Parameters are IDs surrounded by double underscores (for example __pkg_prefix__) or by x_ and _x (for example x_pkg_prefix_x). This convention allows you to edit the template like any other project using DVT in its full power - autocomplete, hyperlinks etc. Parameters are highlighted distinctively: NOTE: It is not mandatory (but elegant) to use DVT for template creation. It is very elegant to apply the template using DVT. . When you generate code using the project template, parameters are replaced in all files (including their names) with the values you specify: © AMIQ 107 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 10. Project Templates www.dvteclipse.com . How to generate code from a project template template.config 10.2 How to generate code from a project template To generate code from a project template use DVT Project From Template Wizard from menu File > New > DVT Project From Template then follow the steps: 1. Specify Template Directory and Target Directory 2. Specify Parameters 10.2.1 Step 1. Specify Directories Specify the template directory ( You can also choose from Predefined Projects) and the destination directory where the code will be generated. © AMIQ 108 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 10. Project Templates www.dvteclipse.com 10.2.2 Step 2. Specify Parameters DVT automatically recognizes the parameters by scanning the template directory recursively. If default values are specified in the template.config file they are automatically filled in. You can edit values as needed. You may restore to defaults as well. If the template directory was developed using DVT and configured as a project (it includes .project and .dvt files) you may chose to inherit its settings (default.build etc.). © AMIQ 109 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 10. Project Templates www.dvteclipse.com . 10.3 template.config You may use the template.config file in the template directory to specify default values and description for the parameters: • name,value,description pkg_prefix,ti_i2c,The verification component prefix PKG_PREFIX,TI_I2C,For defines Some parameters are predefined: • __user__ for the user name (from the operating system) • __date__ for the date (from the operating system) 10.4 Add from Template With this feature you can generate code from a single template file (or a folder containing templates) and add it to an existing project. To access the Add from Template Wizard go to Navigator > right click on a Target folder inside a project > New > Add from Template © AMIQ 110 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 10. Project Templates www.dvteclipse.com The next step is to browse for the templates source folder (by default, is the last path used), then click Next. From the Templates panel > select the files/folders you want to add to Target. In the Attributes panel, you can modify the replacement variables by typing a new value or by selecting one from the history. The Target panel is used for preview - it shows where the selected files will be placed in the project and signals if the there is a duplicate file error (if the file you want to add already exists in the target folder). © AMIQ 111 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 10. Project Templates 112 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 11. Code Formatting In order to format a selected region of code or an entire file, use the Format Source action. Press Ctrl+Shift+F or use editor's right click menu Source > Format Source. All code formatting preferences are available at menu Window > Preferences > DVT > SystemVerilog > Editor > Formatting. 11.1 Whitespace • Trim end of line whitespace - When enabled, end of line whitespace is deleted. • Compact whitespace groups - When enabled, consecutive whitespace characters are trimmed to a single space character. It does not affect indentation, that is the whitespace at the beginning of a line is not affected by this option. • Tabs and Spaces - Lines are indented using tabs or spaces depending on the preferences configured in Window > Preferences > General > Editors > Text Editors: • If the Insert spaces for tabs option is enabled, indentation will use space characters, otherwise tabs will be used. • The Displayed tab width option controls the size of a tab in spaces. • Add whitespace before - Space separated list of tokens to add whitespace before. • Add whitespace after - Space separated list of tokens to add whitespace after. 11.2 Indentation • Optional "begin" - Some language constructs, for example the conditional statement if or the loop statement for, require a begin - end block to control the execution of several statements. Such blocks are called optional "begin" in order to distinguish them from other cases like fork begin ... end endfork' or plain begin ... end blocks used just for grouping several statements together for readability. This option affects the optional "begin" blocks: • On a new line - begin is moved on a new line • On the same line - begin is moved on the same line with it's construct • Leave as is • Parameters - This option affects module ports and parameters, function and task arguments, class parameters: • One per line - each is placed on it's own line • More per line - more are placed on the same line, as fit when line wrapping is enabled © AMIQ 113 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 11. Code Formatting www.dvteclipse.com • Leave as is • Preprocessing - This option affects `ifdef blocks: • Indent and increase indentation level - indent like any other scope language construct that increases indentation of it's enclosed statements • Indent - indent, but don't increase the enclosed statements indentation • Move at first column - move at line start, but don't increase the enclosed statements indentation • Leave as is • Don't indent single line comments at first column - This option affects single line comments that start at column zero. It is useful to disable the indentation for whole regions of code that are block commented, for example by using Ctrl + /. When enabled, single line comments that start at column zero are not indented. • Indent multi-line comments - This option affects multi-line comments ( /* ... */). When enabled, multi-line comments are indented. • Don't increase the indent Level On - By default all scope language constructs increase indentation. This option allows you to control which language constructs should increase indentation. • Implicit semi macros - The code formatting engine depends on detecting some delimiters for properly identifying the proper indentation scope, for example indentation should not increase after if(a) foo1();, but it should after if(a) begin foo();. Semicolon or end is such a delimiter and sometimes it may be encapsulated inside a macro. This option allows you to explicitly list such macros for proper code formatting. 11.3 Vertical Alignment When enabled, this option performs vertical alignment. • Vertical Alignment Tokens The lines of code inside the same scope are aligned by the specified comma separated list of vertical alignment tokens. if(a) begin if(a) begin x = 1; x = 1; // aligned by '=' inside the if scope xx = 1; xx = 1; end else begin end else begin xxx = 1; xxx = 1; // aligned by '=' inside the else scope, orthogonal to the if scope above xxxx = 1; xxxx = 1; end end © AMIQ 114 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 11. Code Formatting www.dvteclipse.com Vertical alignment is performed left to right, by the same token. For example assuming '=' and ':' as vertical align tokens: var x : int = 1; // "first level :", "second level =" var xx : int = 1; a = 1; // not aligned to "second level =" above, as this is a "first level =" aa = 1; In order to use the comma character ',' as a vertical alignment token, the character must be preceded by the escaping character '\'. • Vertical align single line comments - When enabled, single line comments are aligned. • Vertical align to open parenthesis - When enabled, vertical align to open parenthesis. • Vertical align to open curly - When enabled, vertical align to open curly. • Vertical Align Patterns - Module Port Declarations - When enabled, this pattern aligns module ports: input [7:0] a, // comment input signed [7:0] bb, // comment output signed [7:0] ccc, // comment input clk, // clock input rst, // reset input data_in // data • Vertical Align Patterns - Module Signal Declarations - When enabled, this pattern aligns module signals: reg signed [7:0] data_out; // c1 wire [1:0] byte_enable; // c2 reg nop; // c3 • Vertical Align Patterns - Function Declarations - When enabled, this pattern aligns function and task declarations: task write_byte (input bit [7:0] data, output bit error); 11.4 Line Wrapping When enabled, this option splits the lines of code that exceed the specified number of characters. • Line Width - A line is wrapped when it exceeds this value • Wrap single line comments and move above when needed - When enabled, if a single line comment exceeds the line width, it will be moved above and further wrapped, if needed. It is moved above in order not to break the association between an entity and it's description. © AMIQ 115 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 11. Code Formatting www.dvteclipse.com DVT automatically considers any comment above or in-line with an entity as it's description that appears in tooltips, auto-complete or generated documentation. • Wrap multi line comments - When enabled, multi line comments are wrapped to fit the line width. 11.5 External When enabled, all other code formatting options are disabled and code formatting is performed using the given command. © AMIQ 116 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 12. Override Functions 12.1 Override Annotation An Override Annotation indicates that a function/task overrides a parent class implementation. Override annotations are triangles on the vertical ruler to the left of the editor, next to the function definition: A green triangle indicates an overridden function A yellow triangle indicates a shadowed function that overrides a non-virtual function from a parent. A white triangle indicates a predefined function Hover an override annotation to see the overridden parent. Click on an override annotation to jump to the parent function that is overridden. 12.2 Inspect Overrides in the Quick Type Hierarchy View Press Ctrl+T with the cursor positioned on the function name. The Quick Type Hierarchy View allows you to inspect and jump to a specific parent or child that implements the function in the hierarchy. © AMIQ 117 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 12. Override Functions www.dvteclipse.com See also Quick_Type_Hierarchy_View. 12.3 Inspect Overrides in the Layers View Position the cursor on the function name and press Shift+F3 or right click and choose Show > Layers from the menu. The Layers View is populated with all the function declarations and implementations across the object oriented hierarchy. You can choose to see supertype, subtype or full layers. See also Layers_View. © AMIQ 118 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 12. Override Functions www.dvteclipse.com 12.4 Override Using the Dialog To override an inherited function or task, in the Editor, right click inside a class body > Source > Override Methods to open the override methods dialog. Alternatively you can hit Ctrl + Space in the Editor and select Open Override Methods Select the functions/tasks you want to override and press OK. The empty body of the overridden functions or tasks will be placed inside the class body at the cursor position: © AMIQ 119 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 12. Override Functions www.dvteclipse.com 12.5 Override Using Autocomplete Write function or task and then press Ctrl + Space and a list with all available methods will pop-up. You can type the first letters of the method's name to filter out the list. See also Content_Assist_Autocomplete. 12.6 Override Using the Type Hierarchy View You can override a function by pressing F4 to open the Type Hierarchy View > enable Show All Inherited Members option (highlighted in the image below) > select a function > rightclick > Override The function's body will be placed at the and of the class. © AMIQ 120 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 12. Override Functions 121 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 13. Generate Getters and Setters To open the Generate Getters and Setters dialog start typing inside a body class, press Ctrl +Space and select Generate Getters and Setters or right-click inside a body class and select Source > Generate Getters and Setters. There will appear a list with all the getters and setters that can be created for the current class. You can type the first letters of the field's name to filter out the list. Select the functions that you want to implement and press OK. © AMIQ 122 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 13. Generate Getters and Setters 123 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 14. Module Automatic Instantiation 14.1 Autoinstance Using Autocomplete You need to type the first letters of the module name, then press Ctrl+Space three (3) times. You can recognize module instances by their icon, it looks like a chip with ports ready to be glued in. 14.2 Autoinstance Using Drag and Drop Design elements can be auto instantiated by dragging them from the Types View into the editor. © AMIQ 124 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 15. Semantic Search You can search for a specific type, method etc. in the current project or whole workspace. Press Ctrl+H to pop-up the search dialog. To search for the declaration of a specific type, method, field etc. : • Press Ctrl+H to open the Search Dialog • Click on the vlog Search tab. • Type the name in the Search String (if you select in the editor before pressing Ctrl+H, the Search String is automatically set to the selection). • Select type or field etc. and Declarations • Click Search. To search for a whole word in all verilog files, in comments or not: • Press Ctrl+H to open the Search Dialog © AMIQ 125 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 15. Semantic Search www.dvteclipse.com • Click on the vlog Search tab. • Type the name in the Search String (if you select in the editor before pressing Ctrl+H, the Search String is automatically set to the selection). • Select Whole Word and Do not search in comments or All occurrences • Click Search. The search results are presented in the Search View. The Search View is automatically raised at any invocation. You can also go to menu Window > Show View > Other... > General > Search to open the Search View. • Use up and down arrows to move from one match to another. • Use search history to switch between various search results. • Use search again to refresh search results. © AMIQ 126 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 16. Search for References (Usages) To search where a function, variable, class, module or any other entity is used, right click on it's name > References > Project. The results are presented in the Search View. You can also search for references from the Search Dialog (Ctrl+H) . © AMIQ 127 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 17. Quick Search in Views Most DVT views have a Quick Search bar: The Quick Search bar allows you to easily locate a specific element by typing a few letters from its name. Besides simple Regex ('?' for any character and '*' for any character sequence), more advanced patterns are supported, for example CamelCase or hierarchical patterns like top//fifo/c.pi_data. 17.1 CamelCase No filter. Filter: fsc All elements that contain the character sequence fsc. Filter: f_s_c All elements that contain consecutive words starting with f, s, c. Words are character sequences delimited by underscores or by capital letters. © AMIQ 128 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com Filter: FSC All elements that contain words starting with or containing characters in this order f, s, c. 17.2 Simple Regex No filter. Regex Filter: rs* All elements that contain the text rs. Regex Filter: f?c All elements that f<any_character>c. contain the text 17.3 Hierarchical Search You can use single slash ('/') characters to search for strict (direct) hierarchies and double slash ('//') to search for non-strict (indirect) hierarchies. You can choose to see all or just the direct descendants of the matched elements. For each hierarchical segment you can use either CamelCase or Simple Regex. © AMIQ 129 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com No filter. Filter: first/second ''Search for strict hierarchy.'' All elements that contain the search pattern and are in a direct hierarchical relationship (father/son) are shown. Filter: second/s_f/fi* ''Search for strict hierarchy'' + CamelCase and simple Regex Filter: second//fsc ''Search for non-strict hierarchy.'' All elements that contain the search pattern and are in a direct or indirect hierarchical relationship (ancestor/../../descendant) are shown. Filter: s_p/ ''Search for strict hierarchy and show direct descendants.'' Same results as for search strict hierarchy, but including the sons of the matched elements. Filter: s_p// ''Search for strict hierarchy and show all descendants.'' Same results as for search strict hierarchy, but including all descendants of the matched elements. © AMIQ 130 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com 17.4 Search for Members In addition to Hierarchical Search, you can use a member pattern after the dot '.' character to search for types or instances that contain specific members (for example methods, ports, events, etc). The members that match the member pattern are promoted to the top of the members pane. Search for port example No filter. Filter: .sleep Search by port name. All instances with ports that contain the search pattern are shown. Filter: sec/.sleep Search by hierarchy and port name. Hierarchical searching and port searching can be combined. Search for method example © AMIQ 131 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com No filter. Filter: .collect Search by member name. All types with members that contain the search pattern are shown. © AMIQ 132 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com Filter: gpio/.collect Search by hierarchy and member name. Hierarchical searching and member searching can be combined. 17.5 Search Port in Design Hierarchy You can search for a specific port in the design hierarchy by using the Design Hierarchy View. Press the Select Top button and pick one of the available design tops. Make the ports panel visible by pressing the Show/Hide Ports button. In the instances filter text box, type the name of the port you are looking for, preceded by the dot '.' character. The instances that contain the port are bolded. The ports are also bolded and promoted to the top of the ports pane. © AMIQ 133 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com 17.6 Search Port in Verification Hierarchy You can search for a specific port in the verification hierarchy by using the Verification Hierarchy View. Press the Select Top button and pick one of the available top units/components. Make the ports panel visible by pressing the Show/Hide Ports button. In the instances filter text box, type the name of the port you are looking for, preceded by the dot '.' character. The instances that contain the port are bolded. The ports are also bolded and promoted to the top of the ports pane. © AMIQ 134 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com 17.7 Search all UVM Phase Overrides Use the Types View to see where a specific function is declared. For example, type .*phase in the Types View Quick Search to locate all UVM phase overrides. The classes that contain the declarations are bolded. The matching type members are also bolded and promoted to the top of the members pane. © AMIQ 135 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 17. Quick Search in Views www.dvteclipse.com 17.8 Search Global API Use the Types View to locate functions, tasks, fields, parameters, etc. declared at library or package level. For example, type .dpi_get in the Types View Quick Search to locate dpi functions located inside the uvm_pkg package. The libraries or packages that contain the declarations are bolded. The matching members are also bolded and promoted to the top of the members pane. © AMIQ 136 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 17. Quick Search in Views 137 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 18. Trace Port Connections 18.1 Trace Connections from Design Hierarchy Start by inspecting the module hierarchy in the Design Hierarchy View. All traces are going to be computed on this design hierarchy. You can trace across the whole design (when you pick a top module as the hierarchy root) or focus on a specific module in the design (when you pick that module as the hierarchy root). The Design Hierarchy View documentation provides more details on how to populate this view. Select an instance and click on the Show/Hide Ports button in the toolbar. Then right click on a port and select one of the trace kinds, for example Trace Drive and Load. The Trace Connections View opens. 18.2 Trace Connections from Editor You can trace connections directly from the DVT editor. All four trace kinds ( Trace Drive, Trace Load, Trace Drive and Load, Trace in Subinstances) are available. Start by placing the editor cursor over a port or signal and selecting Trace > trace kind from the right-click context menu. © AMIQ 138 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com IMPLEMENTATION NOTE: Tracing Connections from Editor works within the current design hierarchy, found in the Design Hierarchy View. The Design Hierarchy View documentation provides more details on how to populate this view. If the traced port or signal belongs to multiple module instances, you must select the desired one. The Trace Connections View opens. © AMIQ 139 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com 18.3 Trace Connections View The Trace Connections View presents a hierarchy similar with the Design Hierarchy View: • The connected instances are displayed, the rest are filtered out. • You can use Trace All in Full Hierarchy or the Show Root options to show the entire design. The connected instances are colored, the rest are grayed-out. • Port icons indicate the direction of the signal. • Sources and destinations are marked with red/green decorations. • You can search for a specific connected instance or port/signal with Quick Search. © AMIQ 140 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com The toolbar buttons allow you to change the trace kind (drive, load, drive and load or subinstances): • Trace Drive shows the connected instances across the drive paths (who drives this port?). • Trace Load shows the connected instances across the load paths (who does this port drive?). • Trace Drive and Load shows the connected instances across the drive and load paths (how is this signal connected in the design)? • Trace in Subinstances shows the connected instances under the traced module instance (how is this signal connected below?). • Trace All in Full Hierarchy is similar with Trace Drive and Load, but the full hierarchy is presented, not only connected instances (how is this signal connected in the whole design context?). Other buttons: • Show/Hide Ports Shows or hides the connections (ports or signals) of the currently selected instance. • Show Root shows the path to the hierarchy root, even if the signal doesn't reach it. It provides the enclosing context for deep traces, for example when tracing a signal many levels below the top module. This option is enabled by default. © AMIQ 141 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com At any time you can see the traced port (the port you are currently tracing). It is indicated in the info label. The two connected instances that are bold colored in the tree represent : • The instance with the traced port. • The instance with the port or signal shown in the trace path. More details here. Double-click on an element to go to code. • For a connected instance, go to its declaration. • For a port, go to where it is connected in the trace path. • For a signal, go to where it is declared. When the connections panel is hidden, right-click on an instance in the tree to show the context menu. © AMIQ 142 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com When visible, right-clicking on a port or signal to show the context menu. The options in the context menu are : • Trace > trace kind Trace ports found on the drive or load paths of the current traced port. • Go to... Go to the port instantiations or signal declarations of the selected instance. The same as double-clicking on a particular port or signal in the connections panel. • Why Show the trace path from the traced port to the selected port or signal. More details here. 18.4 Trace Path Why signal foo drives/loads signal moo? The Why option in the context menu allows you to see the trace path from any port/signal of a connected instance to the original traced port. © AMIQ 143 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com A list is displayed containing the step by step path starting with the connected port/signal and ending with the traced port. The list contains port instantiations, signal definitions and the assign statements through which the traced signal propagates. At any time you can see what kind of path the port or signal is on (drive path or load path). Also you can change the order the list is displayed, so that it suits your take on the trace kind (from source to destination or reverse) using the button. Double-click on an element to go to code : • For a port, go to where it is instantiated in the trace path. • For a signal, go to where it is declared. • For an assign statement, go to where it is used. © AMIQ 144 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 18. Trace Port Connections www.dvteclipse.com Selecting an element in the list will color red both the corresponding connected instance in the Trace Connections View hierarchy and the current port or signal in the connection panel. The connected instances on the trace path are marked in the tree with an asterisk before their names. © AMIQ 145 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 19. Code Factory The Code factory allows you to easily generate instances, signals and testbenches starting with modules or entities. Factory Input It is required that you first set an input. Right-click on the element definition and select from the context menu the option Set Factory Input under Code Factory. The current input persists until a new one is set or until a full build is invoked. Creating code Having set an input, you can do one of the following: • Create Instance for instantiating the design element; • Create Signals for listing the ports of the design element as signals; • Create Testbench for defining a testbench that instantiates the design element with all the required port connections already made; The code will be inserted at the cursor's current position. Any information or errors during Code Factory operations are shown in the status bar. Notes • At the moment you can set only SystemVerilog modules and VHDL entities as factory input. • Cross language operations are not supported. You can't set a SystemVerilog module as input and use it in VHDL for creating output and vice-versa. © AMIQ 146 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 20. Refactoring 20.1 Rename Refactoring To rename an entity (type, method, macro etc.) in the source code along with all its references, place the cursor on the desired element, then right click and select Refactor > Rename (or use the shortcut combination <Shift + Alt + R>). You will be prompted for the new name of the entity: Click OK to perform the refactoring, or Preview to see the changes that are about to be performed in the source code. In the Preview page you can select the changes that should be performed. After you click Finish the changes are performed, and the project is rebuilt. © AMIQ 147 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 1. Select a file/change to see the source differences produced by the refacotring. 2. Uncheck a file/change to prevent those changes from being applied. 20.2 Refactoring Scripts In some situations - like porting code from a library to another, or when dealing with crossproject API refactoring - one has to perform several refactoring operations for many projects. DVT can help you automate such operations by providing scripted refactoring functionality. Refactoring scripts are XML files that describe a set of changes to be performed for a project (into source code, scripts or file/directory names). For instance, such a script can describe all the changes to be applied to a source base for migration between OVM and UVM libraries. 20.2.1 Writing a Refactoring Script Below there is a thoroughly commented example script to illustrate the XML syntax used by the scripting engine. XML header on the first line. © AMIQ 148 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com <?xml version="1.0" encoding="UTF-8"?> Start of refactoring script content. The script name is displayed in visual controls. <refactor-script version="1" name="My refactoring script"> You can specify exceptions, i.e. paths that will not be affected by the refactoring. Paths are relative to the project root. You can specify both files and folders. For a folder, all files in it and in all its subfolders will be skipped. <exception kind="path" path="skipme"/> It is advised to exclude sensitive project configuration files, like for instance: <exception kind="path" path=".project"/> Actual refactoring directives are called items. There are several kinds of items, differentiated by the action they perform. When writing a script, one must be careful not to have item collisions: situations when the same piece of text is modified by more than one item. Here are examples that illustrate all the actions currently available in DVT. replace-in-text performs plain textual search & replace for all the text files in the project like source files, scripts etc. Note that the search string is case sensitive. <item action="replace-in-text" search="ovm" replacement="uvm" /> replace-in-file-name and replacein-dir-name perform plain textual search & replace in the names of all files/folders within the project. <item action="replace-in-file-name" search="ovm" replacement="uvm" /> <item action="replace-in-dir-name" search="ovm" replacement="uvm" /> rename renames all occurrences of the specified element. An element " is a SystemVerilog language element, and should be specified as follows: • for macros, the name of the macro preceded by a backtick, just like a macro call <item action="rename" element="`my_macro" newname="`my_macro_new_name"/> • for types, modules, methods, etc., the name of the element preceded by the enclosing elements, including the package (if it's the case) © AMIQ 149 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com <item action="rename" element="my_pkg::my_class" newname="my_class_new_name"/> Note that the new name is just the name of the element. Here are some more examples: <item action="rename" element="my_pkg::my_module.my_function" newname="my_function_new_name"/> <item action="rename" element="outer_class.inner_class.my_function" newname="my_function_new_name" comment="XXX: API change. Function renamed from my_function to my_function_new_name."/> In the last example, outer_class is not inside any package (i.e. it's in the global scope). Also, you can optionally specify a comment that will be inserted on the line above the occurence. If the comment contains a Task Tag (like TODO, FIXME, XXX or a custom defined one), after refactoring is completed you can use the Tasks View to inspect action items or notes automatically added by the refactoring. add-comment adds the specified comment to each occurrence of the specified element. The comment will be inserted on the line above the occurrence. <item action="add-comment" element="my_type.foo" comment="FIXME: function removed from my_type API"/> Finally, the script closing tag. </refactor-script> To see a larger example, you can simply start the OVM to UVM Migration wizard and inspect the script behind it (there is an Inspect button on the right side of the first wizard page). 20.2.2 Applying a Refactoring Script To apply a script: right click on project, select Refactor > Apply a refactoring script, then browse to the script you want to apply. © AMIQ 150 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com You can either apply the changes straightforward or inspect them in a Preview wizard page, where you can select which of the proposed changes should be performed. Also, on the topright of the preview wizard you have a Filter button that allows you to filter changes by the type of refactoring action. To apply the refactoring, click Finish © AMIQ 151 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 1. Select a file/change to see the source differences procuced by the refacotring. 2. Uncheck a file/change to prevent those changes from being applied. 3. Filter the displayed changes by type of refactoring item 20.3 Connect Instances Across the Design Hierarchy You can use the Connect Instances Toolbar in order to connect two module instances across the design hierarchy. 20.3.1 Connect Instances Using New Ports In order to connect two module instances using new ports, you must specify the output instance (the signal source) and the input instance (the signal destination). New ports will be created across the design hierarchy as needed, in order to propagate the signal. 1. Press the Select Top button and pick one of the available design tops. More details here on how to populate the Design Hierarchy View. 2. Press the Show Connect Toolbar button to bring up the Connect Instances Toolbar . 3. Right click on an instance and select Connect Output from the context menu. © AMIQ 152 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com The output instance is presented in the connect toolbar Output textbox: 4. Select another instance, right click and Connect Input. The input instance is presented in the connect toolbar Input textbox along the previous set output instance: © AMIQ 153 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 5. You can Preview Structural Changes in the Design Hierarchy . 6. Press the Connect button. The Refactor Connect dialog pops-up. Here you can tune the port and signal names, as well as other refactoring parameters. 7. Press the Preview button to preview the source code changes: © AMIQ 154 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 8. Press the OK button in order to perform the changes. Note 1: At any time you can change the connection output or input. Pick the direction using the radio buttons, select another instance, then right click Connect Input/Output. Note 2: You can undo the whole refactoring operation using Undo ( Ctrl+Z). 20.3.2 Connect Instances Using Existing Ports In order to connect two module instances using existing ports, you must specify the output port (the signal source) and the input port (the signal destination). New ports will be created across the design hierarchy as needed, in order to propagate the signal. © AMIQ 155 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 1. Press the Select Top button and pick one of the available design tops. More details here on how to populate the Design Hierarchy View. 2. Press the Show Connect Toolbar button to bring up the Connect Instances Toolbar . 3. Press the Show/Hide Ports button to see the ports of the selected instance, if needed. 4. Select an instance using left click and a port using right click Connect. The output instance and port are presented in the connect toolbar Output textbox: 5. Select another instance using left click and a port using right click Connect. © AMIQ 156 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com The input instance and port are presented in the connect toolbar Input textbox along the previous set instance and port: 6. The rest of the steps are the same as connecting instances using new ports. More details here. Note : The swap between output instance and input instance doesn't work for directional ports (input or output). 20.3.3 Preview Structural Changes in the Design Hierarchy Any change to a module or entity definition, like new ports or new signals being added, affects all its instances. Before proceeding to source code changes, you can preview the design structural changes. Terminology: • output instance is the module instance where the connection starts. It outputs the signal that will be connected. output module is the module being instantiated as an output instance. • input instance is the module instance where the connection ends. It inputs the signal that will be connected. input module is the module being instantiated as an input instance. • closest parent instance is the parent instance through which a signal is routed to connect the ports leading from the output instance to the input instance across the design hierarchy. No ports will be added to the closest parent instance. The closest parent module is the module corresponding to the closest parent instance. • relevant modules are the modules that will change by adding new ports and/or new signals. relevant instances are instances of relevant modules. © AMIQ 157 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com Ports are added only to modules that are instantiated on the paths leading from the output module instance and the input module instance to the closest parent instance. Ports are added to the output module or the input module only if the connection is not using an existing port. All the instances that will not change are grayed out. All relevant instances are highlighted. If you hide the irrelevant instances, only the grayed out instances enclosing relevant instances are kept in the tree. The following filters in the Connect Instances Toolbar help you understand the structural changes: • Show Design Hierarchy to see the unfiltered design hierarchy. • Minimal Path highlights just the affected path from the output instance to the input instance. It includes the closest parent instance through which the signal is routed. It presents the connection between the instances you've selected without considering the side effects caused by other instances. • Direct Changes highlights all the "similar" instances that are connected. It practically presents all the instances of the closest parent module. • Indirect Changes highlights all the changes in the design that are not Direct Changes. For example an output module could be instantiated outside the closest parent module design hierarchy, in "isolation" from the input module. As such these may be unexpected changes that lead to dangling ports. • All Changes highlights all the changes in the design. Here you see all the relevant instances. It is the union of Direct Changes and Indirect Changes. Note 1: Changes are computed on all tops. Example We connect blue1: Blue ( output instance) to d1 : D ( input instance). b1 : B is the closest parent instance and B is the closest parent module. The relevant instances are highlighted. The structural changes of the filters above are: Show Design Minimal Path Hierarchy © AMIQ Direct Changes Indirect Changes 158 All Changes Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 20. Refactoring 159 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 20.3.4 Connect Instances Toolbar 1. You press the Show Connect Toolbar button to bring up the connect toolbar. 2. In the design hierarchy you can select the instances that you want to connect. 3. You can Swap the ports direction. 4. The output instance path. The port segment is presented only if you use an existing port. 5. The input instance path. The port segment is presented only if you use an existing port. 6. Filter that controls the structural changes preview mode (see Preview Structural Changes in the Design Hierarchy). 7. Filter to hide unaffected instances. © AMIQ 160 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 20. Refactoring www.dvteclipse.com 8. Press Connect to start the refactoring operation. 9. Press Close to hide the Connect Toolbar. 20.4 Add Port to Module from Selected Field You can use the Add Port to Module to add a selected field as a port easy and fast. 1. Right click field wire1 in module A. 2. Select Refactor > Add Port. 3. You can optionally change the new generated port name. 4. Select a direction for the port and press Preview or OK. 20.5 Add New Port to Module You can use the Add Port to Module to add a new port easy and fast. 1. Right click on an empty line in module A. 2. Select Refactor > Add Port. 3. Specify the port name, direction, type and optional width. 4. Select a direction for the port and press Preview or OK. © AMIQ 161 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 20. Refactoring 162 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 21. Diagrams Diagrams help you inspect or document the architecture of a verification environment (e language, SystemVerilog) or the structure of a design element (Verilog, VHDL). They are rendered inside the diagram editor, using the dot engine. You must have dot installed for diagrams to work (see http://www.graphviz.org). For convenience every DVT distribution includes dot. The dot executable can be specified using menu Window > Preferences > DVT > Diagrams. 21.1 Class Diagrams You can create class diagrams to inspect or document the architecture of a verification environment from the toolbar button or from the menu File > New > SystemVerilog UML Class Diagram. Class diagrams are saved with the extension .vcdiagram. You must have dot installed (diagrams are rendered using the dot engine - see http:// www.graphviz.org and Common dot related issues). You can specify the dot executable from menu Window > Preferences > DVT > Diagrams. In the diagram editor you can click on classes to jump to the source code. You can select the relevant classes for which to draw the diagram from button (see Class Diagrams - Select Classes). For the selected classes diagram can present inheritance, associations (pointers) and class members (see Class Diagrams - Preferences). You can customize the font sizes for nodes and edges from menu Window > Preferences > DVT > Diagrams. See Class Diagrams - Legend for the description of diagram drawing conventions. © AMIQ 163 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com 21.1.1 Class Diagrams - Select Classes A diagram is created around a set of relevant classes you specify. For example when you decide to show parents, children or associations by using Class Diagrams - Preferences, it applies only to selected classes. In a diagram the selected classes are colored with yellow fill (see also the Class Diagrams - Legend). The right list shows the selected classes. Use left/right arrows or double click to select the relevant classes. © AMIQ 164 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com You can also add/remove an element to/from the current selection by right clicking on it in the diagram and choosing "Select type"/"Deselect type": Class Diagrams Class Diagrams - Preferences Class Diagrams - Legend © AMIQ 165 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com 21.1.2 Class Diagrams - Preferences For the selected classes you can choose to show parents, children, associations (pointers), customize the graph layout etc. You may choose to: • Show first, all or no parents for the selected classes • Show first, all or no children for the selected classes • Show all, public or no members - fields, methods (functions, tasks), events - for the selected classes • Show associations (pointers): • Selected - only pointers between selected classes are shown • First - only pointers from selected classes are shown • Full - the full collaboration diagram (pointers from selected classes and their parents and so on recursively) • Customize the graph layout © AMIQ 166 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com • Show package information Class Diagrams Class Diagrams - Select Classes Class Diagrams - Legend 21.1.3 Class Diagrams - Legend A class. A selected class. A selected class with members. '- (minus)' for fields + (plus) for functions or tasks * (star) for events A predefined class. Inheritance: ChildClass inherits from ParentClass. Association: AClass points to BClass (has a field f_bcl of type BClass). © AMIQ 167 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com Inheritance with parameters: SetParams inherits from AClassWithParams#(int) (sets T to int). Association with parameters: MyClass has a field p_cls of type AClassWithParams#(int) (sets T to int). Outgoing connections (inheritance or associations) from a selected class are colored with orange. Incoming connections (inheritance or associations) to a selected class are colored with blue. Class Diagrams Class Diagrams - Select Classes Class Diagrams - Preferences 21.2 Architecture UML Diagrams An Architecture UML Diagram presents the associations between all the entities that inherit from a commonly used set of base classes. Typically these are components like monitors, drivers, agents etc. To create an Architecture UML Diagram use the New Diagram toolbar button and select Architecture UML Diagram from the menu. © AMIQ 168 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com You can tune the default set of base classes and filters from menu Window > Preferences > DVT > Diagrams > UML Architecture Diagrams. 21.3 Sequences UML Diagrams A Sequences UML Diagram presents the associations between all the entities that inherit from a commonly used set of base classes. Typically these are sequence or scenario data types. To create a Sequences UML Diagram use the New Diagram toolbar button and select Sequences UML Diagram from the menu. You can tune the default set of base classes and filters from menu Window > Preferences > DVT > Diagrams > UML Sequences Diagrams. 21.4 Module Diagrams Module Diagrams help you inspect and document the structure of a design element. A module diagram presents the design's direct subinstances, the connections between them, as well as the connections to design's ports. You must have dot installed (diagrams are rendered using the dot engine - see http:// www.graphviz.org and Common dot related issues). A DVT distribution includes dot. You can specify the dot executable from menu Window > Preferences > DVT > Diagrams. © AMIQ 169 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 170 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com Create a new module diagram in any of the following ways: • right-click on a project or open the File menu and choose New > HDL Module Diagram • use the New Diagram toolbar button and select New HDL Module Diagram from the menu • Right click in the Types View or the Design Hierarchy View and select Show Diagram • Place the cursor over a Type or Instance name in the editor, right click and select Show > Diagram The size of instance blocks is proportional to their number of ports. Click on a diagram node to go to the element's definition in the source code. Instances containing subinstances have a thick border. To view their diagram right click and select Show Module Diagram or press Ctrl and click. © AMIQ 171 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 172 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com 21.4.1 Module Diagrams - Select Modules In case you want to change the design, click the Select Module button to pick a design. Select Module opens automatically when you create a new diagram, unless you started from a selection. You can chose only from designs with subinstances. You can filter the list using the text field. © AMIQ 173 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 174 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com 21.4.2 Module Diagrams - Preferences Use the Preferences button to customize the diagram contents and layout. © AMIQ 175 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 176 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com By default Show connected Ports is selected. If some ports clutter the diagram, you can exclude them by selecting Hide ports if name contains. Tip: if you generate a diagram and see less ports than expected, check its description at the bottom for the list of port names you have excluded. Uncheck Display port names to hide Port names from the diagram and show them as a tooltip. Choose Hide all ports to show only subinstances in the diagram. © AMIQ 177 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 178 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com Show multiple nodes per port is an alternative way of viewing ports of the enclosing design: if a port is connected to several instances, a node is created for it next to each instance. This may help reduce clutter. The following images illustrate how this option changes the diagram: Table 21.1. Without Multiple Nodes Per Port With Multiple Nodes Per Port Collapse bidirectional edges uses a single edge with arrows at both ends to represent signals flowing in both directions between two nodes. Note: the diagram might not be displayed correctly with this option if your version of the dot program is older than 2.29. The following images illustrate this option: Table 21.2. Without Collapse Bidirectional Edges © AMIQ With Collapse Bidirectional Edges 179 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com The Graph direction can also be customized, as illustrated by the screenshots in this section. © AMIQ 180 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com The preference page DVT → Diagrams → Module Diagrams allows you to choose: • highlighting of modules with subinstances • colors for all elements of the diagram The preview section automatically reflects your changes. © AMIQ 181 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 21. Diagrams 182 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com 21.4.3 Module Diagrams - Breadcrumb Navigation If you navigate to sub-instances using right click > Show Module Diagram or by pressing Ctrl+Click, the breadcrumb buttons above the diagram allow you to quickly navigate through the design hierarchy. The small buttons with an arrow show possible subinstances of a design. You can select a subinstance to display its diagram. 21.5 Diagram Toolbar Select input elements - the selection dialog opens automatically when you create a new diagram, unless you started from a selection. Change preferences Save - depending on the dot version, you may save a diagram in various formats, for example JPEG, PNG or SVG. Refresh Refresh automatically - when on, the diagram is automatically refreshed, for example when you change the input elements or preferences. Zoom in Zoom out Zoo fit Zoom reset Show legend Show help 21.6 Diagram Preferences The preference page DVT > Diagrams has settings for Graphviz DOT that affect both Class and Module Diagrams. © AMIQ 183 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 21. Diagrams www.dvteclipse.com Diagrams are generated using the Graphviz DOT program. The DVT Distribution includes DOT so you can use diagrams without additional setup. If you prefer (or if you didn't install DVT from Distribution) you can also specify the location of the DOT program on your system. The Font you choose here is used by all diagrams in DVT. This preference can contain: • A font name, like sans, mono or verdana • The absolute path to a True Type Font file (.ttf), e.g. /usr/share/fonts/truetype/ubuntufont-family/Ubuntu-R.ttf The DVT Distribution includes several font files, for convenience. You can preview & choose one of them by clicking the button. © AMIQ 184 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 22. Export HTML Documentation To generate the HTML Documentation click on Export HTML Documentation Wizard button on the main toolbar . The HTML documentation is similar with JavaDoc and it is generated using the comments above type declarations, method declarations etc. NOTE: It is recommended to perform a full build before exporting the HTML documentation. 22.1 Export HTML Documentation Wizard 1. General Page 1. Specify the project for which HTML Doc will be generated 2. Documentation title 3. Overview description file - its content will be placed on the first page of the documentation 4. User defined HTML Page - a customized html page that can be embedded in the navigation menu (for example you can add links to external documentation or resources: <a © AMIQ 185 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com target="elementFrame" href=" http://www.dvteclipse.com">dvt</a> -> will open the web page in the main frame) 5. The output directory - target directory where the documentation will be placed 6. Option to hide the "Generate by < user >" watermark 2. API Selection Preferences Select/deselect what kind of API and what packages to include in documentation. 3. Filter Preferences © AMIQ 186 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com 1. A set of general filters 2. SystemVerilog specific filters 3. Names Filter - exclude types' names that match these filters 4. Paths filter - exclude files from documentation © AMIQ 187 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com 4.Styling Preferences Comments beautify and formatting 5.Link To Existing Documentation © AMIQ 188 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com Create links to the elements for which documentation is already generated in the directories specified in the list above, instead of re-generating their HTML pages. You can also select if you want to see references to external documentation's index.html files in the left navigation menu. 6.Diagrams Preferences © AMIQ 189 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com Add/remove diagrams (based on project's natures). Depending on how big is your project, generating diagrams could be a time consuming task. 22.2 Comments Formatting There are two formatting styles supported: JavaDoc & NaturalDocs. You can use HTML syntax in JavaDoc comments . © AMIQ 190 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com 22.2.1 JavaDoc JavaDoc Support The table below lists the JavaDoc tags that DVT recognizes. For more details see http:// en.wikipedia.org/wiki/Javadoc. @param Valid for: functions, tasks Adds a parameter with the specified argument-name followed by the specified description to the "Arguments" section @return © AMIQ Valid for: functions 191 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com Adds a "Returns" section with the description text. This text should describe the return type and permissible range of values @see Adds a "See Also" heading with a link or text entry that points to reference. A doc comment may contain any number of @see tags, all grouped under the same heading @author Adds an "Author" entry @deprecated Adds a comment indicating that this API should no longer be used (even though it may continue to work) @version Adds a "Version" subheading with the specified version-text @since Adds a "Since" heading with the specified since-text {@link LINK_ADDRESS Inserts an in-line link with visible text label that points LINK_TEXT} to the documentation for the specified package, class or member name of a referenced class. This tag is valid in all doc comments. For more details see below. {@literal text} Displays text without interpreting the text as HTML markup or nested javadoc tags. This enables you to use regular angle brackets (< and >) instead of the HTML entities (<and >) in doc comments, such as in parameter types (<Object>), inequalities (3 < 4), or arrows (<-) JavaDoc Links An in-line link in a comment can be created using this tag {@link LINK_ADDRESS LINK_TEXT}.There are two types of links: • Internal Links -> point to data inside Documentation. In this case LINK_ADDRESS must respect the following notation: Package_Name::Class_Name.Method_Name for an absolute path or TYPE_NAME.INNER_TYPE_NAME or just TYPE_NAME for relative paths. In case of a relative path a link will be created to the best match for that type with regard to its scope inside the project. NOTE: Using relative paths could generate broken links if there are different data types with the same name inside the project! • External Links -> point to external web pages or files. For webpages LinkAddress must start with http:// and for files with file:// followed by the resource's address. For example: {@link http://www.dvteclipse.com} or {@link file://external-res.pdf} For both types of links LINK_TEXT is optional and it can be used to show a user defined text instead of link's path. JavaDoc Autocomplete and Comment Templates To add JavaDoc like comments to code, in Code Editor type above the code declaration /** and then press Enter. Depending on the code type (a class declaration, a function, a task etc.) a comment will be added with the respective JavaDoc tags. © AMIQ 192 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com These comments are added based on some predefined comment templates that can be customized. Go to Window > Preferences > DVT > SystemVerilog > Editor > Code Templates.You can select a javadoc template and modify it by adding/removing supported tags (using this naming convention: ${TagNameWithout@} ) or custom text. You can also create new templates. A template will be applied only to a specified data type, for example: javadoc_class will be applied to classes. If you want to add a template for modules its name must respect the following rule: YourTemplateName_DataType (ex: MyModuleTemplate_module) and must be placed in JavaDoc Comment Context. See the result in the image below: © AMIQ 193 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 22. Export HTML Documentation 194 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com 22.2.2 NaturalDocs NaturalDocs Support The table below lists the NaturalDocs syntax that DVT recognizes. For more details see http:// www.naturaldocs.org. <LinkAddress> Inserts an in-line link with visible text label that points to the documentation for the specified package, class or member name of a referenced class. This tag is valid in all doc comments. For more details see below. ~Italic Text~ Use tilda (~) for Italic Text. *Bold Text* Use star (*) for Bold Text. Headings You can add headings to your output just by ending a line with a colon and having a blank line above it. Bullet Lists You can add bullet lists by starting a line with a dash, an asterisk, an o, or a plus. Bullets can have blank lines between © AMIQ 195 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com them if you want, and subsequent lines don’t have to be indented. You end a list by skipping a line and doing something else. Definition Lists You can add a definition list by using the format below, specifically “text space dash space text”. Like bullet lists, you can have blank lines between them if you want, subsequent lines don’t have to be indented, and you end the list by skipping a line and doing something else. Images You can include images in your documentation by writing (see filename). If you put it alone on a line it will be embedded in place. Code and Text Diagrams , or :'''. If you have a vertical line or text box with the comment, you must separate these symbols from it with a space. NaturalDocs Links An in-line link in a comment can be created using <LINK_ADDRESS LINK_TEXT>.There are two types of links: • Internal Links -> point to data inside Documentation. In this case LINK_ADDRESS must respect the following notation: Package_Name::Class_Name.Method_Name for an absolute path or TYPE_NAME.INNER_TYPE_NAME or just TYPE_NAME for relative paths. In case of a relative path a link will be created to the best match for that type with regard to its scope inside the project. NOTE: Using relative paths could generate broken links if there are different data types with the same name inside the project! • External Links -> point to external web pages or files. For webpages LinkAddress must start with http:// and for files with file:// followed by the resource's address. For example: < http://www.dvteclipse.com> or <file://external-res.pdf> For both types of links LINK_TEXT is optional and it can be used to show a user defined text instead of link's path. 22.3 Customizing Documentation Generated documentation using new HTML style can be customized using the files <html_doc>/css/custom.css and <html_doc>/js/custom.js. The new HTML style is based on Bootstrap [http://http://getbootstrap.com/] and jQuery [http:// jquery.com/] frameworks and customizations can be done using jQuery API and by changing Bootstrap's default styles. Custom CSS The custom Cascading Style Sheet is included last and can overwrite any style defined above. Example: changing the color of collapsible panels holding the element names. © AMIQ 196 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 22. Export HTML Documentation www.dvteclipse.com .panel-default > .panel-heading { background-color: Chocolate; color: Cornsilk; } Custom JavaScript The custom.js JavaScript file is included at the end of the HTML and it can completely change the content of the page. Example: adding a custom "CONFIDENTIAL" warning to TOC and every page header can be done using jQuery. $('body').prepend('<div class="alert alert-warning text-center" role="alert">CONFIDENTIAL</div>'); Customizing the TOC page and the content pages separately can be achieved by testing the window name: if (window.name === "content") $('body').prepend('<div class="alert alert-warning text-center" role="alert">This is the content frame</div> if (window.name === "toc") $('body').prepend('<div class="alert alert-warning text-center" role="alert">This is the toc frame</div>'); A similar approach can be used to customize individual pages based on the file name: if (window.location.pathname.split('/').pop() === "summary-overview.html") $('body').prepend('<div class="alert alert-warning text-center" role="alert">This is the the summary page< © AMIQ 197 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 23. External Tools Integration 23.1 Run Configurations You can invoke (run) any executable from Eclipse and see its output in the Console View. You just need to create a Run Configuration from menu Run > Run.... VlogDT provides one type of configuration: • DVT Generic DVT Generic Run Configuration 1. Menu Run > Run Configurations.... 2. Select DVT Generic configuration and click the New button. 3. Specify name, working directory, run as command or script and the content of the command or script. 4. Click Run. © AMIQ 198 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Before writing the command you can specify how to run the content. Run as a: • command (the content must be a single line command with arguments) • script (the content must be a multiline script, preceded by a hash exclam, that will be written to file system before execution) If run as a command is selected the content should look like this: sh -c "echo Test ${string_prompt:Parameter 1} ${string_prompt:Parameter 2}" or if run as a script is selected a script with hash exclam must be specified: #!/bin/sh echo Test ${string_prompt:Parameter 1} ${string_prompt:Parameter 2} for i in `seq 5 -1 0` ; do echo Starting in $i seconds sleep 1 done echo Test started Parameters can be specified using Eclipse variables or DVT Custom_Dialogs can be used for more complex dialogs. © AMIQ 199 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com As a result you will be asked to provide the "Parameter 1" e.g. "run" and "Parameter 2" e.g. "script". The result of running the command will be: "Test run script" Note: The parameters ${VAR} are considered Eclipse variables that and will be resolved before running the command. To use shell variables in the command you must use the $VAR syntax. When running as a command, unresolved Eclipse variables will trigger an error and the run will be aborted. not be reported. When running as a script the unresolved Eclipse variables will remain untouched. Quick Run You can launch again at any time from menu Run > Run History... or directly from the toolbar (simple click launches last): You can also use the Run > Quick Run menu (or Ctrl+U shortcut key) to quickly launch any existing Run Configuration: The DVT Quick Run dialog will pop-up and present a list of all available Run Configurations. You can use the quick filter to search for a specific Run Configuration, up and down arrows to navigate in the list and Enter to launch: © AMIQ 200 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Output The invocation output is dumped to the Console View. Click on hyperlinks in the Console View to jump directly to the to source location. 23.1.1 Run Configuration Session Type Note: This feature is available only for Linux and MacOS The options available under the command/script text box can be used to control the process session that will be used to run the command or script. The following session types are available: © AMIQ 201 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Same process session as DVT • The process will be a direct child of DVT • The process must manage its subprocesses if termination signals are received, otherwise orphaned processes may appear • Job control is not available • stdin, stdout, sdterr will be available in "Console View", tty will not be available A new process session • The process will be launched using a wrapper script that will create a new process session • The process may manage its subprocesses if termination signals are received, but "Terminate all spawned processes..." option can be used to kill all subprocesses when the parent process ends or is terminated • Job control is available • stdin, stdout, sdterr will be available in "Console View", tty will not be available An xterm process session (xterm must be available in the system) • The process will be launched using xterm that will create a new process session • The process may manage its subprocesses if termination signals are received, but "Terminate all spawned processes..." option can be used to kill all subprocesses when the parent process ends or is terminated • Job control is available • tty, stdin, stdout and sdterr will be available in xterm, the stdout, stderr can be redirected to "Console View" using "Redirect xterm output..." option • xterm window can remain on screen when the process ends or is terminated if "Hold xterm window open..." option is selected © AMIQ 202 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.1.2 Custom Shortcut and Button for a Run Configuration On the main toolbar click on Run > Run Configurations... > select a run configuration file from DVT Generic and click on Shortcuts Tab. You can choose to add a shortcut on the main toolbar and/or an accelerator (for example, ALT+SHIFT+1). WARNING: It is not recommended to remove accelerators from Window > Preferences > General > Keys © AMIQ 203 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com If you want to remove a shortcut/accelerator you can uncheck the respective preference in the Shortcuts Tab. Toolbar shortcuts must have an icon. You can specify an external file or create one by selecting the Create Icon option. Each icon can have a one letter label and a background color. You can specify the position of a button on the toolbar by modifying the Toolbar Order Number - buttons are placed on the toolbar from left to right, ordered from 0 to N (max 999). If there are more buttons with the same number, they will be ordered alphabetically. NOTE: You cannot create shortcuts/accelerators for read-only run configuration files. 23.1.3 Using environment variables in DVT Generic Run Configurations Environment variables can be set in the following ways: • in the shell where DVT was launched © AMIQ 204 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com • using +dvt_env+ directive in the project's build configuration file (.dvt/default.build) - see Environment Variables • from the Environment tab of the Run Configurations dialog (menu Run > Run Configurations) • directly within the command getting executed, for example: sh -c "env PROJECT_DIR= ${project_loc} iev -f ${project_loc}/iev/iev.f -c". 23.1.4 Using an alias in a DVT Generic Run Configuration Aliases only work in interactive shells. The command specified in the Run Configuration should be: <your_shell> -ic "<your_alias>" for example bash -ic "ll" When you create a new DVT Generic Run Configuration, DVT tries to guess the shell that you use from the $SHELL system variable and fills it in for you. 23.1.5 DVT Generic Run Configuration Variables The following variables are available when you configure a run configuration. These variables are automatically expanded each time the run configuration is launched. DVT variables Name Description ${selected_resources_loc} Absolute file system path of the selected resources separated by system file separator character. You can pass as argument a string to be used as separator. ${selected_resources_path} Workspace relative path of the selected resources separated by system file separator character. You can pass as argument a string to be used as separator. ${selected_resources_name} The name of the selected resources separated by system file separator character. You can pass as argument a string to be used as separator. ${dvt_current_build_file} Absolute path to the current DVT build file ${dvt_cli} © AMIQ Expands to the full DVT CLI path, using as the workspace option the current workspace: $DVT_HOME/bin/dvt_cli.sh -workspace ${workspace_loc} 205 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Eclipse variables Name Description ${workspace_loc} The absolute path on the system's hard drive to Eclipse's workspace directory ${workspace_loc:<resource The absolute path on the system's hard drive to the specified resource. The path>} <resource path> is the full path of the resource relative to the workspace root. For example ${workspace_loc:/MyProject/MyFile.txt}. Note that the expanded result of this variable is not the same as ${workspace_loc}/ MyProject/MyFile.txt if the project's contents directory for MyProject is outside the workspace directory. ${project_loc}The absolute path on the system's hard drive to the currently selected resource's project or to the project being built if the external tool is run as part of a build. ${project_loc:<resource The absolute path on the system's hard drive to the specified resource's path>} project. The <resource path> is the full path of the resource relative to the workspace root. For example ${workspace_loc:/MyProject/MyFile.txt}. Note that the expanded result of this variable is not the same as ${workspace_loc}/ MyProject if the project's contents directory for MyProject is outside the workspace directory. ${container_loc} The absolute path on the system's hard drive to the currently selected resource's parent (either a folder or project). ${container_loc:<resource The absolute path on the system's hard drive to the specified resource's parent path>} (either a folder or project). The <resource path> is the full path of the resource relative to the workspace root. For example:${workspace_loc:/MyProject/ MyFolder/MyFile.txt}. Note that the expanded result of this variable is not the same as ${workspace_loc}/MyProject/MyFolder if the project's contents directory for MyProject is outside the workspace directory. ${resource_loc} The absolute path on the system's hard drive to the currently selected resource. ${resource_loc:<resource The absolute path on the system's hard drive to the specified resource. The path>} <resource path> is the full path of the resource relative to the workspace root. For example ${workspace_loc:/MyProject/MyFile.txt}. Note that the expanded result of this variable is not the same as ${workspace_loc}/ MyProject/MyFile.txt if the project's contents directory for MyProject is outside the workspace directory. ${project_path}The full path, relative to the workspace root, of the currently selected resource's project or of the project being built if the external tool is run as part of a build. ${container_path} The full path, relative to the workspace root, of the currently selected resource's parent (either a folder or project). ${resource_path} The full path, relative to the workspace root, of the currently selected resource. ${project_name} The name of the currently selected resource's project or of the project being built if the external tool is run as part of a build. ${container_name} The name of the currently selected resource's parent (either a folder or project). ${resource_name} The name of the currently selected resource. © AMIQ 206 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.2 Smart Log For any invocation you can either use predefined filter sets for specific tools, or define your own filters and style maps in order to view the simulation output like the one below. For more details: Smart Log - Filters Smart Log - Hyperlinks Smart Log - Styles Run Configurations 23.2.1 Smart Log - Filters To define a new filter for a DVT Generic run configuration go to the Filters Tab, click New... and specify filter parameters. © AMIQ 207 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com The main filter parameters are: • Name - The name of the filter • Severity - The severity of the filter. • Pattern - The filter pattern. Use ${file} to indicate a file hyper-link, and ${line} to indicate the line to jump to. Use (?<TAG_NAME>) to tag a group that will be used to randomly or explicitly assign a style (green bold for example - see Smart Log - Styles). © AMIQ 208 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com In the Filters Tab you can also set other parameters such as: • The maximum number of characters per line ( 1 ) • The maximum number of consecutive lines ( 2 ) • Whether links should jump to resources from the current working set ( 5 ) You can browse through predefined filters to see more examples ( 3 ). You can also add a filter pattern for your console title ( 4 ). This should contain capturing groups whose contents will be appended to the console title. For example the pattern in the image © AMIQ 209 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com above: "DVT_CONSOLE_TITLE\s+(\w+)" will append "[my_title]" to the console title when it will match a text like "DVT_CONSOLE_TITLE my_title" in the console output. Smart Log - Hyperlinks Smart Log - Styles Run Configurations 23.2.2 Smart Log - Hyperlinks Using the predefined filters enables you access to hyperlinks for files and also for some error codes of certain simulators. By clicking on a hyperlinked error code a dialog pops-up with the explanation of that error provided by the simulator help tool. DVT supports verror for Questa and nchelp for IUS. You can customize the name of these tools by setting the following environment variables: DVT_VERROR_TOOL_NAME and DVT_NCHELP_TOOL_NAME You can further customize this feature by creating your own regular expression for a custom hyperlink that launches a defined launch configuration. Use ${cmd:launch_configuration_name:regular_expression} to define these custom hyperlinks in your filter pattern, where launch_configuration_name is the name of the launch configuration that is going to be launched when clicking on the hyperlink and regular_expression is the regular expression whose matched result will be hyperlinked. For example when running a launch configuration that outputs the location of a log file like this one: in order to hyperlink the location of the file a pattern needs to be defined: © AMIQ 210 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com To summarize the content of the log file and display just the number of errors, warnings and infos in a new console: the "Summarize_log" launch configuration is defined with $DVT_CUSTOM_HYPERLINK_CAPTURING_GROUP_0 environment variable © AMIQ 211 the Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Smart Log - Filters Smart Log - Styles Run Configurations © AMIQ 212 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.2.3 Smart Log - Styles Assuming the filter MyTrace has a pattern Trace (?<AGENT_KIND> a-zA-Z_0-9+) (?<INSTANCE> a-zA-Z_0-9+) .* that contains 2 groups tagged <AGENT_KIND> and <INSTANCE>, DVT will randomly assign a color for each unique combination (AGENT_KIND_match, INSTANCE_match). You'll get different colors for: • Master M1 (<AGENT_KIND> group matched "Master" and <INSTANCE> matched "M1") • Master M2 (<AGENT_KIND> group matched "Master" and <INSTANCE> matched "M2") • Slave S1 (<AGENT_KIND> group matched "Slave" and <INSTANCE> matched "S1") • Slave S2 (<AGENT_KIND> group matched "Slave" and <INSTANCE> matched "S2") Trace Master M1 sending packet... Trace Master M2 waiting for grant... Trace Slave S1 receiving packet... Trace Master M1 abort... Trace Slave S1 signal nack... Trace Slave S2 go to idle... You can manually assign colors by editing the .dvt/log_styles.xml file: <?xml version="1.0" encoding="UTF-8"?> <section name="attributes"> <item key="version" value="1"/> <list key="log_styles"> <item value="PATTERN_NAME=MyTrace, AGENT_KIND=Master, INSTANCE=M1, COLOR=#FF8000, FONT_STYLE=BOLD, BORDER_STYLE=NONE"/> <item value="PATTERN_NAME=MyTrace, AGENT_KIND=Master, INSTANCE=M2, COLOR=#008000, FONT_STYLE=BOLD, BORDER_STYLE=NONE"/> <item value="PATTERN_NAME=MyTrace, AGENT_KIND=Slave, INSTANCE=S1, COLOR=#800080, FONT_STYLE=BOLD, BORDER_STYLE=NONE"/> <item value="PATTERN_NAME=MyTrace, AGENT_KIND=Slave, INSTANCE=S2, COLOR=#8080FF, FONT_STYLE=BOLD, BORDER_STYLE=NONE"/> </list> © AMIQ 213 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com </section> For example the first line means "If pattern MyTrace matched and AGENT_KIND is 'Master' and INSTANCE is 'M1' set color to ...". You can use regular expressions, for example AGENT_KIND=M*. You can specify the COLOR, the FONT_STYLE (BOLD or ITALIC), and the BORDER_STYLE (DOT or SOLID or NONE). Smart Log - Filters Smart Log - Hyperlinks Run Configurations 23.3 External Builders An external builder allows you to invoke any script/tool and back-annotate its output (errors, warnings etc.) to the source code. It is a mean that allows you to connect any 3d party tool (compiler, linter etc.) to DVT error signaling engines. You can configure one or more external builders on a project: • The commands you define will be invoked on project clean, full build and incremental build. • The patterns you define will be applied on the command output to recognize errors, warnings etc. • The pattern matches will be back-annotated to the source code and presented in a similar way DVT signals errors (file, line, in the Errors View etc.) DVT ships with some predefined example configurations to get you started. For more details: How to define a new external builder How to invoke external builders External Builder Output Source Code Markers - errors warnings etc 23.3.1 How to define a new external builder Select the project in the Navigator View, right-click and choose Properties. Choose the DVT > External Builders properties. Click the New button to define a new external builder. From the list of external builders choose the generic External Builder or one of the pre-configured ones. © AMIQ 214 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com Main tab In the Main tab you can: © AMIQ 215 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 1. Specify the name of the builder. It will appear in the extracted messages, for example in the Errors View. 2. Specify the Full Build command - invoked on project full build and re-build. It is any regular shell command. You can use various variables (see pre-configured builders for examples). 3. Specify the Auto Build command - invoked on incremental builds, for example on save. It is any regular shell command. You can use various variables (see pre-configured builders for examples). 4. Specify the Clean command - invoked on project clean and before re-build. It is any regular shell command. You can use various variables (see pre-configured builders for examples). 5. Specify the working directory where the commands are invoked from. You can use various variables, browse the file system etc. (see pre-configured builders for examples). 6. Use various variables to pass as arguments to commands, for example ${incdir} or ${project_loc}. NOTE: If you wish to specify multiple commands or use wildcards or system variables, use sh -c "". E.g: sh -c "echo $USER; rm -f *.log" Filters tab © AMIQ 216 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com In the Filters tab you can: 1. Choose from one of the predefined filter categories. 2. Preview a filter. 3. Define a new filter, edit, remove or duplicate an existing one. Filters in predefined categories cannot be edited or removed (allow future enhancements or fixes). 23.3.2 How to invoke external builders External builders are automatically invoked after the DVT builder. For example when requesting to build or rebuild the project, when saving etc. Obviously if the command is empty for a specific phase (full, clean or auto), the builder is not invoked. You can also explicitly invoke only the external builders from the dedicated button . The focus must be on some editor in the project or a resource from the project should be selected. If you have multiple external builders defined for a project, you can select which one will be invoked by clicking on the respective entry in the menu: NOTE: When invoking only one builder, a Clean Project operation that removes all errors from all external builders is also triggered. 23.3.3 External Builder Output An external builder dumps its output in the console upon invocation. Using the defined filters, matches are identified and hyper-linked to source code. © AMIQ 217 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.3.4 Source Code Markers - errors warnings The matches found in the builder output using the filters are marked on the source code. They are visible in the editors, Problems View etc. You can right-click on a marker to jump to the Console output of the external builder to investigate the error/warning. © AMIQ 218 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.4 External Documentation You can browse and search through 3rd party documentation using the Eclipse help system. © AMIQ 219 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com For more details: Configure External Documentation Search External Documentation 23.4.1 Configure External Documentation NOTE: Integration with external documentation is not available by default in DVT distributions. You have to install the feature by following this procedure: http://dvteclipse.com/ install_update_site.html. At step #4 make sure you have checked the Help Plugins. NOTE: DVT doesn't ship with 3rd party documentation, if it is not in the public domain (for example doxygen docs are public).. Assuming you have the documentation installed, configure the path to it from menu Window > Preferences > Help: 23.4.2 Browse External Documentation Once configured it will appear in the help system (menu Help > Help Contents): © AMIQ 220 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 23. External Tools Integration www.dvteclipse.com 23.4.3 Search External Documentation You can search through the documentation directly from within Eclipse IDE. For example select and click Ctrl+Shift+H. The Help View is brought up with the matches. You can also bring up the Help View from menu Window > Show View > Other... > Help. © AMIQ 221 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 24. Custom Dialogs You can easily create your own dialogs or wizards and integrate them with scripts and flows using DVT Custom Dialogs. Create a Dialog A Custom Dialog is defined in a file with the .swtxml extension (see #1 below) using SWT/ XML Syntax. To simplify dialog creation, DVT includes: • a SWT/XML Editor (highlight, structure, autocomplete by Ctrl+Space ...) (see #2 below) • a SWT/XML Preview View for previewing the edited dialog (see #3 below) Open a Dialog A Custom Dialog can be opened from any Run Configuration by using the ${dvt_dialog_prompt:path_to_dialog.swtxml} variable. This variable takes as an argument © AMIQ 222 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com the dialog descriptor file. The path to the *.swtxml file can be specified, in order of precedence, either as an absolute path, as a path relative to the location of the run configuration file or as a path relative to the project. When the run configuration is executed, the ${dvt_dialog_prompt:path_to_dialog.swtxml} variable is replaced with the string produced by the dialog (i.e. the dialog output). For example you can use the following command in a DVT Generic run configuration: sh -c "echo ${dvt_dialog_prompt:path_to_dialog.swtxml}" You can also open a dialog using the Command_Line_Interface. A dialog looks like this: Use the Dialog Output The dialog output is a string composed by concatenating the output of each widget that has an id attribute specified. The output of a widget is its id concatenated with its value. The value differs across widgets, see Widgets. For example a Directory Chooser defined like this: <dvt:DirectoryChooser id="+incdir+" value="/path/to/some/dir"/> will produce: +incdir+/path/to/some/dir © AMIQ 223 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com See Customizing_the_Dialog_Output for more customization options. You can find some comprehensive examples in the DVT Predefined Projects shipped with DVT. You can start with an example dialog containing all the available widgets from menu New > Example > DVT > DVT Custom Dialog. 24.1 Quick Steps 1. Follow the wizard from menu New > Example > DVT > DVT Custom Dialog and place the customdialog.swtxml file in your DVT project. 2. The SWT/XML Editor and the SWT/XML Preview View will open. In the editor (bottom side) switch to the Source tab instead of the Design tab. 3. Change the title of the dialog by editing the id attribute of the topmost (first) Composite element 4. Craft the dialog to the desired look by using the provided examples, autocomplete (Ctrl +Space) and the SWT/XML Preview View 5. Create a Run Configuration and specify as command echo ${dvt_dialog_prompt:customdialog.swtxml} and run it to see and verify the output produced by the newly created dialog 6. When you are content with the output, replace the command with your_script.sh ${dvt_dialog_prompt:customdialog.swtxml} 24.2 Customizing the Dialog Output Because the id of a widget can be any string, you can construct a wide variety of output formats simply by changing the form of the id. Some common use-cases are: • Bash style dash arguments, e.g.: id=" -name " => -name value • Simulator style plus arguments, e.g.: id=" +incdir+" => +incdir+value • Make style equals arguments, e.g.: id=" name=" => name=value The dvt:Container widget This widget acts just like a Composite (i.e. you can surround sets of widgets or composites with it), but also takes some configuration parameters that are applied for all the widgets it contains. • To specify values for checkboxes use checkboxOffValue and checkboxOnValue parameters: © AMIQ 224 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com XML <dvt:Container layout="layout:grid;" parameters="checkboxOnValue: -cov 1;checkboxOffValue: -cov 0"> <Button id=" " style="CHECK" text="Collect coverage" selection="true" /> </dvt:Container> <dvt:Container layout="layout:grid;" parameters="checkboxOnValue: -wave 1;checkboxOffValue: -wave 0 <Button id=" " style="CHECK" text="Dump wave" /> </dvt:Container> Output: -cov 1 -wave 0 • The default separator for list elements is ;. To change it, use listSeparator parameter: XML <dvt:Container parameters="listSeparator: -f "> <dvt:DirectoryFilesListing id=" -f " rootDirectory="/tmp/files"/> </dvt:Container> Output: -f file_1 -f file_3 -f file_5 -f file_7 • To prevent the widget id from being output when the value is empty use noIdForEmptyValues parameter: XML <dvt:Container parameters="noIdForEmptyValues:true"> <Text id=" -text "></Text> </dvt:Container> • To quote values use quoteWith parameter: © AMIQ 225 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com XML <dvt:Container layout="layout:grid;numColumns:2;" parameters="quoteWith:'"> <Label text="Text:"></Label> <Text id=" -text " style="BORDER" text="text with whitespace that needs to be quoted" /> </dvt:Container> Output: -text 'text with whitespace that needs to be quoted' Note: If you wish to quote a string with double quotes you should escape the double quote character from XML syntax as follows: <dvt:Container parameters="quoteWith:""> • To show information about the value of a certain widget in the console title use showInTitle parameter: XML <dvt:Container parameters="showInTitle:true"> <Label text="Seed:"></Label> <Text id=" -seed " style="BORDER" text="42223" /> </dvt:Container> Output Further customization can easily be achieved by using a simple script for processing arguments. E.g. with the following bash snippet you can convert any argument to any desired form: #!/bin/bash # # bash_arg_converter.sh # while [ $# -gt 0 ]; do case $1 in -custom_*) argname="$1" © AMIQ 226 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com shift argval="$1" ## Customize here to desired format ## echo -n " $argname $argval " ;; *) echo -n " $1 " ;; esac shift done In the configuration command box use the following instead of ${dvt_dialog_prompt}: `./bash_arg_converter.sh ${dvt_dialog_prompt:customdialog.swtxml}` How to avoid quoting problems: in the .swtxml file it is recommended to use \" for nested quotes and for the Launch Command (Run Configurations > Launch Command) the variable ${dvt_dialog_prompt:customdialog.swtxml} should be surrounded by quotes, like in the image below: 24.3 SWT/XML Reference A custom dialog is described in an XML file with .swtxml extension. The first line must declare the file as XML: <?xml version="1.0" encoding="utf-8"?> The topmost element must be a Composite widget that defines the title of the dialog (specified by its id attribute) and the widgets that can be used (standard SWT widgets and custom DVT widgets): © AMIQ 227 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com <Composite xmlns="http://www.swtxml.com/swt" xmlns:sv="http://www.dvteclipse.com/xmlns/customdialog/sv" xmlns:dvt="http://www.dvteclipse.com/xmlns/customdialog" id="Dialog Title"> </Composite> A widget is a graphical component (e.g. Textbox, Checkbox) or a container of other widgets (e.g. Composite, Group). Each widget has a corresponding XML tag. You can use any widget to create your dialog. If you specify an id attribute for the widget tag, it will also produce an output in the dialog result. 24.3.1 Layouts There is a large set of layout options available. A complete reference can be found here [http://www.eclipse.org/articles/article.php?file=Article-Understanding-Layouts/ index.html]. The best approach to finding the desired layout is by using the extensive autocomplete provided by the SWT/XML Editor. Below there is a list common use-cases with examples. Horizonal Fill <Composite id=" -verbosity " layout="layout:fill;"> <Label text="Verbosity:"/> <Button id=" HIGH " style="RADIO" text="High"/> <Button id=" MEDIUM " style="RADIO" text="Medium"/> <Button id=" LOW " style="RADIO" text="Low"/> </Composite> Vertical Fill <Composite id=" -verbosity " layout="layout:fill;type:VERTICAL;"> <Label text="Verbosity:"/> <Button id=" HIGH " style="RADIO" text="High"/> <Button id=" MEDIUM " style="RADIO" text="Medium"/> <Button id=" LOW " style="RADIO" text="Low"/> </Composite> Grid © AMIQ 228 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com <Composite id=" -verbosity " layout="layout:grid;numColumns:3;"> <Label text="Verbosity:" layoutData="horizontalSpan:3;"/> <Button id=" HIGH " style="RADIO" text="High"/> <Button id=" MEDIUM " style="RADIO" text="Medium"/> <Button id=" LOW " style="RADIO" text="Low"/> </Composite> 24.3.2 Widgets Composite Composites are used for grouping other elements, and they have no visual representation. You can control how their children elements are arranged by specifying the layout attribute. See the Layouts section for information on how to control the look of the dialog. Group Groups are similar to composites, except that they are graphically delimited by a border and can have a title specified by the text attribute. Refer to Radio Button for an example. Label Labels are simple text fragments used to present information. Refer to Textbox for an example. Textbox XML <Label text="Seed number:"/> <Text id=" -seed " style="BORDER" text="123456" /> Output -seed 123456 Checkbox XML <Button id=" -cov " style="CHECK" text="Collect coverage" selection="true" /> <Button id=" -wave " style="CHECK" text="Dump wave" /> Output -cov © AMIQ 229 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com Radio Button XML <Group id=" -sim " text="Simulator" layout="layout:fill;type:VERTICAL;"> <Button id=" IUS " style="RADIO" text="IUS" selection="true"/> <Button id=" VCS " style="RADIO" text="VCS" /> <Button id=" Questa " style="RADIO" text="Questa" /> </Group> Output: -sim IUS Directory Chooser XML <dvt:DirectoryChooser id=" -sim_dir " question="Sim dir" layoutData="horizontalAlignment:FILL;" value="../sim"/> Output: -sim_dir ../sim File Chooser XML <dvt:FileChooser id=" -mem_file " question="Memory init data" layoutData="horizontalAlignment:FILL;" extensions="*.bin" © AMIQ 230 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com value="/common/mem/init.bin"/> Output: -mem_file /common/mem/init.bin Combo Box XML <Combo id=" -test " text="test_reset" items="test_random;test_reset;test_back2back;test_1;test_2;test_3"/> Output: -test test_reset Combo Box (read only) XML <Combo id=" -test " style="READ_ONLY" text="test_reset" items="test_random;test_reset;test_back2back;test_1;test_2;test_3"/> Output: -test test_reset List XML <List id=" -verbosity " © AMIQ 231 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com text="HIGH" style="BORDER|V_SCROLL" items="HIGH;MEDIUM;LOW;NONE"/> Output: -verbosity HIGH Directory Files Listing Lists all files/dirs that match a certain criteria in a specified folder. XML <dvt:DirectoryFilesListing id=" -file " question="Files Listing" includePaths="**\*.sv;**\*.e;**\*.vhdl" excludePaths="" rootDirectory="/home/path/.." fileType="FILE;DIR" outputOption="basename" showHiddenFiles="true" timeoutSeconds="10"/> Output: -file file_name Parameters • includePaths (excludePaths) - include (exclude) files based on their filename • Examples • "**\*.e;**\*.vhd" matches all .e and .vhd files/dirs in a directory tree. • "test\a??.sv" matches all files/dirs that start with an 'a', then two more characters and then ".sv", in a directory called test. • "**" matches everything in a directory tree. © AMIQ 232 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com • "**\test\**\XYZ*" matches all files/dirs that start with "XYZ" and where there is a parent directory called test (e.g. "abc\test\def\ghi\XYZ123"). • Default value for 'includePaths' is '**' • rootDirectory - can be specified as an absolute path or relative to a project in the current workspace. The path can also contain system variables. • fileType - select whether files, directories or both are shown • FILE - displays only files • DIR - displays only directories • FILE;DIR - displays both files and directories • Default value for 'fileType' is FILE • outputOption - option to format the selected file's name • 'basename' - returns the file's name without extension • 'fullname' - returns the file's name with extension • 'fullpath' - returns an absolute path of the selected file • 'relativepath' - a path relative to 'rootDirectory' • showHiddenFiles - by default is false • timeoutSeconds - if the root directory has a large number of children, listing them is stopped after * seconds Note: The includePaths and excludePaths attributes use ant-like path patterns [http:// ant.apache.org/manual/dirtasks.html#patterns]. Class Selector XML <sv:ClassSelector © AMIQ 233 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 24. Custom Dialogs www.dvteclipse.com id=" -test " question="Test to run" layoutData="horizontalAlignment:FILL; verticalAlignment:FILL; grabExcessHorizontalSpace:true; grabExcessVerticalSpace:true;" baseClassName="uvm_test"/> Output: -test test_2m_4s Note: This widget is only available for SystemVerilog. © AMIQ 234 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 25. Command Line Interface DVT has a Command Line Interface that allows you to perform various operations in DVT directly from the shell. For example you can create a new project, import an existing project, open a file etc. You send the CLI commands using the dvt_cli.sh script. 25.1 dvt_cli.sh With this script you can send commands to a running DVT from the terminal. If no running DVT instance is detected in the specified workspace, a new one is opened using dvt.sh. 25.2 Syntax ./bin/dvt_cli.sh -h[elp] ./bin/dvt_cli.sh [-s[ilent]] [-noexit] [-timeout <timeout>] [-workspace <dir>] [-import_workspace_settings <dir>] [-force_import_workspace_settings <dir>] <command> [-eclipse_args "<arguments to be passed to eclipse executable>"] -h[elp] -s[ilent] -noexit Display usage. [Optional] Do not print any WARNING / INFO messages. [Optional] If the script starts a new DVT, it will not exit until DVT is closed (i.e. dvt.sh finishes). -timeout <timeout> [Optional] If the script starts a new DVT, it will wait at most <timeout> seconds for DVT to start. Default: 100. -workspace <dir> [Optional] Location of the DVT workspace (overrides $DVT_WORKSPACE_PATH) -eclipsespace [Optional] Path to a custom eclipse storage directory (instead of ~/.eclipse). -import_workspace_settings <dir> [optional, dvt.sh argument] Path to the workspace from where settings will be imported. -force_import_workspace_settings <dir> [optional, dvt.sh argument] Same as -import_workspace_settings, but it will overwrite target workspace settings. -eclipse_ini <path_to_ini_file> [optional, dvt.sh argument] use this file instead of the default eclipse.ini when starting DVT (using this flag you can set JVM memory limits and other eclipse parameters as described in http://wiki.eclipse.org/Eclipse.ini) <command> All other arguments are considered the command to be passed to DVT. For more info on the available commands consult the COMMANDS section below. © AMIQ 235 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com -eclipse_args <arguments to be passed to eclipse executable> Everything that follows this argument is passed to the eclipse executable as-is. THIS MUST BE THE LAST ARGUMENT OF THE COMMAND LINE 25.3 Notes This script can also be configured by the following system variables: $DVT_WORKSPACE_PATH [required if -workspace flag not specfied] location of the DVT workspace $DVT_NETCAT_EXECUTABLE [required if 'netcat' is not found in $PATH] location of the netcat exacutable This script requires netcat executable. To pass system variables to the script as arguments you should escape the $ (dollar) preceding the varible name with \ (backslash), e.g. \$USER 25.4 Examples Create a Verilog/SystemVerilog/VHDL project: $> dvt_cli.sh createProject $PROJ/my_project -lang vlog -lang vhdl -f $PROJ/my_project/filelist.f Create a project and place it in its own workingset in a new DVT window; overwrite project if it already exists; logically link some common library files under the project directory: $> dvt_cli.sh createProject $PROJ/my_project -lang vlog -lang vhdl -workingset -newwindow -force -f $PROJ/my_project/filelist.f -map common $COMMON_LIB Create an e Language project and place it in its own workingset in a new DVT window; logically link some common library files under the project directory: $> dvt_cli.sh createProject $PROJ/my_project -workingset -newwindow -force -top $PROJ/my_project/e/top.e -test $PROJ/my_project/tests/test1.e -map common $COMMON_LIB Create a Verilog/SystemVerilog/VHDL project and associate it with Perforce $> dvt_cli.sh createProject $PROJ/my_project -lang vlog -lang vhdl -f $PROJ/my_project/filelist.f -p4 P4PORT=company_server:1666,P4CLIENT=perforce-work,P4USER=user1 Create a project from an existing template: $> dvt_cli.sh createProjectFromTemplate /target/location -template $PROJ/template/ Import an existing project into the workspace and place it in its own workingset in a new DVT window: $> dvt_cli.sh importProject $PROJ/my_project -workingset -newwindow © AMIQ 236 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com Open a file in the context of my_project and reveal line #50: $> dvt_cli.sh openFile $PROJ/my_project/e/bfm.e -line 50 -project my_project Open a custom dialog and print its output to the console: $> dvt_cli.sh openCustomDialog -file dialog.swtxml -project my_project Print a list of the files compiled in my_project: $> dvt_cli.sh listCompiledFiles -project my_project -unique 25.5 Makefile Example If you plan to integrate DVT in a flow which uses Make, you can find an example Makefile inside the uvm-1.1d_ubus predefined project: cd $DVT_HOME/predefined_projects/uvm-1.1d_ubus/examples/ # default target prints the usage make -f Makefile.dvt # Target dvt_gen creates the project directory # and generates the project configuration files make -f Makefile.dvt dvt_gen # Target dvt calls dvt_gen, starts DVT and creates the project make -f Makefile.dvt dvt # target dvt con 25.6 Commands 25.6.1 Create a Project (Mixed-Language Capable) createProject <project_path> [-workingset [-newwindow]] [-force] [-f|-F <file_path>] [-top <top_file_path>] [-test <test_file_path>] [-map <link_name> <target_path>] [-name <project_name>] [-lang <lang>] [-perspective <perspective>] [-p4 <connection_parameters>] [-exclude [name|path|projectRelativePath[_regex]=]<pattern>] <project_path> absolute path to project (must exist) -workingset [Optional] add project to a working set -newwindow [Optional] open a new window with the working set selected -force [Optional] required to overwrite existing project -f|-F [Optional] specify a command file for the project;-f and -F are mutually exclusive © AMIQ 237 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com -top [Optional] specify a top file for the project; you can specify this option multiple times -test [Optional] specify a test file for the project; you can specify this option multiple times -map [Optional] create a linked resource called <link_name> pointing to <link_target> -name [Optional] use as project name instead of project's directory name -lang enable support for <lang> language; valid are: E, VLOG, VHDL (case-insensitive); at least one must be specified -perspective [Optional] switch to <perspective> after creating the project. By default, DVT switches to the DVT Perspective if multiple -lang directives are provided. If a single language is enabled, the corresponding perspective is activated. Valid argument values: E, VLOG, VHDL, DVT or a perspective id -p4 [Optional] share project with Perforce Eclipse plugin. The <connection_parameters> argument must be specified as a list of <parameter>=<value> separated by commas. Mandatory parameters: P4PORT=<host:port> (P4PORT=company_server:1666) P4CLIENT=<perforce_workspace_name> (P4CLIENT=perforce-work) P4USER=<username> (P4USER user1) Optional parameters: P4CHARSET=<charset_type> (P4CHARSET=none) P4PASSWD=<password> (P4PASSWD=password123) SAVEPASS=<save_in_secure_storage_or_not> (SAVEPASS=false) OFFLINE=<working_offline_or_not> (OFFLINE=false) -exclude [Optional] exclude from the project resources (files, directories) and their children recursively by name, location (absolute path) or projectRelativePath. For <name|location|projectRelativePath>=<pattern>, the pattern is case insensitive and allows simple wildcards (* and ?) For <name_regex|location_regex|projectRelativePath_regex>=<pattern>, the pattern is case sensitive and allows regular expressions If only <pattern> is specified, matching is done against the resouce <name> using simple wildcards (* and ?). [NOTE] DVT provides a user interface for managing Resource Filters as a simpler and more intuitive alternative to the Eclipse built-in Resource Filters management UI. However, DVT's UI only works for <projectRelativePath> filters that do not contain wildcards or regular expressions -build <name> [Optional] Set <name> as active build configuration. -<name>.build <build configuration directives ...> [Optional] Create the build configuration file <project>/.dvt/<name>.build with <build configuration directives> as content. All flags up to the end of the command line, or up to the next -<name>.build flag are considered build configuration directives. © AMIQ 238 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com This flag cannot be used in conjunction with -f, -F, -test, or -top. NOTE: For backward compatibility, the commands createEProject and createSVProject are still recognized by the DVT CLI, and are equivalent with a createProject command plus the corresponding -lang flag 25.6.2 Create a Project From an Existing Template createProjectFromTemplate <target_path> -template <template_path> Creates a project into the workspace from an existing project template <target_path> absolute path to target directory <template_path> absoulute path of the project template 25.6.3 Import an Existing Project importProject <project_path> [-workingset [-newwindow]] [-p4 <connection_parameters>] Import an existing project into the workspace <project_path> absolute path to project -workingset [Optional] add project to a working set -newwindow [Optional] open a new window with the working set selected -p4 [Optional] share project with Perforce Eclipse plugin. The <connection_parameters> argument must be specified as a list of <parameter>=<value> separated by commas. Mandatory parameters: P4PORT=<host:port> (P4PORT=company_server:1666) P4CLIENT=<perforce_workspace_name> (P4CLIENT=perforce-work) P4USER=<username> (P4USER user1) Optional parameters: P4CHARSET=<charset_type> (P4CHARSET=none) P4PASSWD=<password> (P4PASSWD=password123) SAVEPASS=<save_in_secure_storage_or_not> (SAVEPASS=false) OFFLINE=<working_offline_or_not> (OFFLINE=false) 25.6.4 List Compiled Files listCompiledFiles -project <project_name>[ -unique][ -dirs][ -separator <separator>] List all the files compiled in the specified project, in compilation order. -project The project for which you want the list of compiled files. -unique [Optional] Remove duplicates form the list. -dirs [Optional] Get a list of parent directories of the compiled files instead of the files themselves. © AMIQ 239 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com -separator [Optional] Specify a custom separator for the list elements; default is newline. 25.6.5 Launch a Run Configuration launchRunConfig [-blocking] -name <run_config_name> Launch a Run Configuration -blocking [Optional] return after the Run Configuration has completed -name Name of the Run Configuration to launch 25.6.6 Open a File openFile <path_to_file>[ -line <line_number>][ -project <project_name>] Open the file denoted by <path_to_file> in the DVT editor. -line [Optional] select and reveal the specified line in the editor; lines are counted from 1 -project [Optional] try to open the file from the specified project If the file does not exist in the given project, it is opened from any other project in the workspace. If the file does not exist in any project, it is opened out of any context (limited DVT capabilities). 25.6.7 Open a Custom Dialog openCustomDialog -file <path_to_swtxml> [-project <project_name>] Open a custom dialog and return the values that were filled in. -file .swtxml file describing the custom dialog. Either an absolute path or a path relative to project root -project [Optional] specify a project for the Custom Dialog 25.6.8 Refresh a project refreshProject <project_name> [-subpath <subpath>] [-depth <depth>] Refresh a project or a <subpath> in a project. -subpath [Optional] Only refresh <project_path>/<subpath>. May be a folder or a file. -depth [Optional] Only refresh to the provided depth. By default the refresh depth is 2, that is full (recursive) refresh. Possible values for <depth> are: 2 the resource and its direct and indirect members at any depth © AMIQ 240 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 25. Command Line Interface www.dvteclipse.com 1 the resource and its direct members 0 the resource, but not any of its members 25.6.9 Quit quit Quit DVT 25.6.10 Query the running status status Query the running status of DVT. 25.6.11 Print version version Print the DVT version number. © AMIQ 241 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 26. Macros Support 26.1 Inactive Code Highlight 26.1.1 Overview DVT editor marks the inactive code (i.e. code that is not compiled due to ifdef/ifndef) with a colored background. 26.1.2 Settings You can enable/disable the highlight and choose the highlight color: navigate to Window > Preferences then expand DVT > SystemVerilog > Editor. In the panel on the right side you can find the Inactive code highlight settings group. © AMIQ 242 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 26. Macros Support www.dvteclipse.com 26.2 Macro Expansion 26.2.1 Overview You can inspect the code generated by the expansion of a macro in two ways: • inline: DVT replaces the macro call with the generated code in place; the expanded code is guarded by pragmas that allow DVT to collapse the code back to the original • in a separate editor: DVT opens a new editor window that shows the generated code 26.2.2 Triggering To expand Place the cursor on a macro call in the editor, right click, select from the pop-up menu Macros and then the desired expand type. Expansion also works for an entire region of code, and all macros in the selection will be expanded. DVT also marks inline macro expansions in the code and collects them in the tasks view to allow easy tracking. You can choose to expand only the first level (i.e. further macro calls inside the top level macro are not expanded) or all levels. You can quickly collapse a macro expansion by right-clicking on its marker. © AMIQ 243 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 26. Macros Support www.dvteclipse.com To collapse Place the cursor on the expansion start pragma, and select Collapse Inline Expansion. Do not modify the pragmas generated by DVT because this might break the collapse functionality! DVT will notify you if the macro expansion in the editor does not match the current macro definitions. This may happen either because the expansion or the macro definitions have been modified since the macro was expanded. A compare window will display the differences between the editor expansion and the expansion with current macro definitions. 26.2.3 Tips • Shortcuts • There are some handy keyboard shortcuts you can use for triggering: Expand one level inline Ctrl Shift = Collapse inline expansion Ctrl Shift - • Selection • Expansion also works for an entire region of code, and all macros in the selection will be expanded. © AMIQ 244 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 26. Macros Support www.dvteclipse.com • Markers • DVT also marks inline macro expansions in the code and collects them in the tasks view to allow easy tracking. • Quick collapse • You can quickly collapse a macro expansion by right-clicking on its marker. 26.2.4 IMPORTANT NOTE Do not modify the pragmas generated by DVT because this might break the collapse functionality! The pragmas are: • @DVT_EXPAND_MACRO_INLINE_START • @DVT_EXPAND_MACRO_INLINE_ORIGINAL • @DVT_EXPAND_MACRO_INLINE_END 26.3 Macros and Quick Macros Views The Macros View and Quick Macros View present all the macros in the project and allow you to quickly locate a macro definition in code. © AMIQ 245 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 27. Reminders (TODO Markers) See the Tasks View. © AMIQ 246 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 28. OVM Support 28.1 OVM Compliance Review To perform the OVM Compliance review of your project click the SV Lint button in the toolbar of the Verilog Perspective, and select Lint As > OVM Compliance The OVM Compliance Review opens and contains the following tabs: • The Main Tab is the entry point (see image below). From here you can Export to HTML the report. • The Architecture Tab presents entities grouped by categories like agents, monitors, drivers etc. • The Checks Tab presents the status of all checks with links to relevant source lines. • The Statistics Tab presents various statistics. • The Waivers Tab can be used to edit and inspect the defined waivers. © AMIQ 247 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com 28.1.1 Architecture Tab The architecture tab can be used to inspect the automatically detected environment architecture. 28.1.2 Checks Tab The checks tab can be used to inspect the compliance review results. Different filter combinations can be used to reduce the amount of information and have a better overview of the problems. The bottom of the view can be used to write different comments for every check as a reminder or for a later review. © AMIQ 248 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com 28.1.3 Statistics Tab The statistics tab can be used to inspect the collected statistics. © AMIQ 249 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com 28.1.4 Waivers Tab The waivers tab can be used to add, remove, edit and inspect the waivers. Waivers are used to change the status of the hits that are matched by the waiver properties. Hits can also be removed using the same method. The status option can be set to: • DISABLED: hits are removed • ERROR: hits are reported as errors • WARNING: hits are reported as warnings • INFO: hits are reported as info There are two types of waivers: • Manually defined waivers • Code waivers (collected from code) Manually defined waivers can be created using New... button from the Waivers tab. The Waivers Editor dialog offers an easy way to configure a waiver. The parameters that can be configured are: • Waiver Name: an unique name for the waiver • Waiver File: the file where the waiver will be saved (from the waivers include tree) © AMIQ 250 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com • Apply on: the scope of the waiver (it applies on matched or non matched hits) • Status: the status that will be applied to the matched hits • Check Names: the name of the checks this waiver applies to • Line Ranges: the line, or line ranges (StartLine:EndLine) this waiver must match • Message Patterns: the regular expression this waiver must match (Perl-like or simple regular expression) The waiver will match a hit if all defined parameters match the hit properties (the check that generated the hit, line, file, or message). If a parameter is empty (not defined) it will match any value. Code waivers can be inserted in code as comments with the following syntax: // @DVT_LINTER_WAIVER_START ["NAME"] STATUS [CHECK_1, CHECK_2] © AMIQ 251 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com code line ... code line // @DVT_LINTER_WAIVER_END Where: • NAME: is the waiver name (optional) and must be enclosed within quotation marks • STATUS: is the status applied to the hits (mandatory) and must be one of the valid status values (DISABLE, ERROR, WARNING, INFO) • CHECK_1, CHECK_2: is a list of check names (optional) this waiver applies to, if it's not defined the waiver applies to all checks 28.1.5 HTML Report The report is divided in 3 panels. 1. Summary Page or Hits Page (right) 2. Categories and Checks Tree (middle) 3. Filters (left) Summary Page Summary page contains statistics charts and top failures from current state of the report. To toggle between summary page and hits page you can use the following button Donut charts represent the ratio of errors/warnings/infos/passed checks or hits. © AMIQ 252 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com Under the charts, checks and files with the highest number of failures are displayed. Hovering over the checks or files will pop-up a filtering button that can be used to add that check or file to the filters. Hits Page The page appears when a check or category is selected in the tree or when the following button is pressed The hits table contains all the hits of the selected check or category and allows filtering and sorting. © AMIQ 253 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com To sort the table after severity, check, file or line, click on the column header of that specific property. Multiple sorting can be achieved by holding <Shift> pressed when clicking on the column header. Hovering over the checks or files column will pop-up a filtering button that can be used to add that check or file in the filters. Above the hits table a quick filter bar is displayed. It can be used to filter furthermore the hits displayed in the table. The quick filter applies to any information (check, file, line, message) available in the table and only the matching rows will show in the table. The small chart above the quick filter represents the ratio and absolute values of hit severities displayed in the table. Below the hits table a details area shows the information of the selected category, check and hit. Categories and Checks Tree Selecting a check or category in the tree will display the hits table for it. The details area will be updated with the information about that category or check. The status of a category or a check is computed based on the contained hits. © AMIQ 254 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com Filters Filters work on the information displayed in all components (summary page, checks tree, hits table). Status filters are filtering out the hits and checks that don't match and are applied on selection. Checks and files filters are filtering out the hits and checks that don't contain match. They are applied only when Reapply Filters button is pressed. The filters can also contain regular expressions. To save the state of the report (filters, selected checks, etc.) the save button can be used. Clicking it will show the URL needed to open the report in the same state © AMIQ 255 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com 28.1.6 Problems View Integration The Problems View can be used to inspect the compliance errors with ease. As soon as the compliance is performed, all the problems automatically appear in the Problems View and as markers on the left part of the Editor. It is also possible to jump to source code or reapply the linting without leaving this view. 28.2 OVM Field Editor The OVM Field Editor enables you to inspect and edit OVM field registrations. It allows you to quickly add, remove and edit the registration macros and presents field statistics (total no. of fields, no. of registered fields, no. of warnings/errors). 28.2.1 Triggering Triggering the OVM Field Editor for a certain class: place the cursor anywhere inside the class definition, right click and select Source > UVM Field Editor from the pop-up menu. If you place the cursor on a field, the OVM Field Editor will show up with the respective field selected. If there are no previously registered macros, the ovm_*_utils_begin and ovm_*_utils_end macros shall be determined based on the class found at the cursor position. For a class that inherits from ovm_sequence, a pop-up dialog will ask you to select the desired sequencer from the available ones. 28.2.2 Interface On the left side of the Field Editor Dialog there is a list containing all the fields in the class. You can register/unregister the class by clicking on the checkbox in the Class group. When the class is registered you can register or unregister fields by checking the corresponding checkboxes. © AMIQ 256 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com When selecting a field you can also find information about the macro used for registration in the OVM Registration Macro group. If it's not the desired macro you can fix it using the Fix button. On the right side you can see the flag status of the registered fields. Its main features are highlighted and explained below: 1. Summary information regarding registrations: no. of registered fields, total no. of fields in class, no. of errors, no. of warnings. 2. Content Filters matched indication 3. Class checkbox that allows you to toggle the registration state. 4. Field type 5. Field name 6. Field icon. The field icons have the following meanings: Icon Meaning The class is not registered The class is registered The field is a virtual interface © AMIQ 257 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com The field is instantiated and is a UVM Component The field is instantiated and is a UVM Object The field is a port The field is an array The field is not registered. The field is registered. The field is registered and affected by a warning. The field is registered and affected by an error. 7. Field registration checkbox that allows you to toggle the registration state. 8. Select/Deselect all buttons. Used to register/unregister all the fields in a class. 9. Fix button. Used to fix a macro registration if the right one isn't used 10. The UVM Registration Macro that is currently used for the selected field. 11. Message area: displays error/warning messages. 12. Field operation checkbox. If checked, the flag will be added to the registration. 13. Field operation controls: allow you to select / clear all of the checkboxes. 14. Print radix radio button. If checked, the radix will be set in the registration. At most one radix can be specified. 15. Tooltip: hover with the mouse pointer any field operation checkbox or print radix radio button to obtain information about the flag. 16. Clear print radix: allows you to unset the print radix (set all radio buttons off). 28.2.3 Problems OVM Field Editor reports the following problems: Message Severity This field is registered with <current_macro_name> instead of Error <macro_determined_by_dvt> Radix flag is specified more than once. Error The flags for the field registration are incorrectly specified. They should be Error OR-ed together using # (pipe character). © AMIQ 258 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com DVT could not determine a registration macro for this field. Warning ovm_field_object will be used. 28.2.4 Tips • Shortcut • You can quickly trigger by using <Shift+Alt+G>. • Fixing problems • To fix a problem, press the fix button if it's a wrong registration macro or unregister and register the field. Note: registering and unregistering the field will reset the flags/registration macro. • Multiple selection • You can't use multiple selection to perform registration/unregistration of more fields. Note: if you want you can register/unregister all the fields using the Select/Deselect all buttons. 28.3 OVM Smart Log DVT ships with predefined filters for OVM that allow you to view colored and hyper-linked logs like the one below. To turn on OVM Smart Log: • Select the predefined OVM filters as indicated below: © AMIQ 259 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com 28.4 Quick OVM Documentation Access • The Doxygen documentation is available at menu Help > Help Contents > OVM release number Doxygen . You may choose documentation version from menu Window > Preferences > Help > OVM Doxygen. • The CDN OVM/UVM User Guide is available at menu Help > Help Contents > CDN OVM/UVM User Guide. You need to configure the path to installed documentation from menu Window > Preferences > Help > CDN OVM/UVM User Guide. You can use Ctrl+Shift+H to quickly search through documentation (with or without selection in the editor). 28.5 OVM Templates DVT offers autocomplete templates for OVM components. Just type in the editor ovm then hit <Ctrl + Space> twice and a drop-down list will offer you the available templates. © AMIQ 260 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 28. OVM Support www.dvteclipse.com After you pick the desired template, you can fill in the template parameters (e.g. company prefix, component name etc.). © AMIQ 261 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 29. UVM Support 29.1 UVM Browser The UVM Browser view is an intuitive entry point for exploring all the classes of an UVMbased verification environment. It allows you to explore UVM-based classes grouped by categories, like agents, monitors, drivers or sequences and easily inspect the UVM flow specific API, like overridden phases, class members registered to the factory or TLM ports. Open the view from menu Window > Show View > Other... > DVT > UVM Browser. You can use CamelCase or Simple Regex to locate a specific element. © AMIQ 262 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com Toolbar Prepend Prepend the enclosing package name to the name of each class, useful when Package you explore for example all agents across packages. Name Group Group classes by package. You may chose to see for example all agents across By packages or to explore all categories in a specific package. Package The top UVM Types Panel presents all the UVM-based classes defined in your verification environment. For convenience they are grouped by categories like agents or monitors. The inheritance hierarchy between classes is shown up to the UVM base class. © AMIQ 263 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com The categories and their corresponding base classes are the following Categories Base class Agents uvm_agent Drivers uvm_driver Envs uvm_env Items uvm_sequence_item Monitors uvm_monitor Memories uvm_mem Ports uvm_port_base, uvm_tlm_if_base, uvm_tlm_extension_base, uvm_sqr_if_base, uvm_tlm_req_rsp_channel, uvm_tlm_fifo_base Registers uvm_reg Backdoor Registers uvm_reg_backdoor Frontdoor Registers uvm_reg_frontdoor Register Adapters uvm_reg_adapter Register Blocks uvm_reg_block Register Fields uvm_reg_field Register Sequences uvm_reg_sequence FIFO Registers uvm_reg_fifo Register Files uvm_reg_file Register Maps uvm_reg_map Scoreboards uvm_scoreboard Sequencers uvm_sequencer Sequences uvm_sequence Tests uvm_test Other Components uvm_component Other Objects uvm_object The bottom Members Panel panel displays class members. You can toggle the UVM Members Mode on/off using the button. In UVM Members Mode it displays the following members: • Virtual interfaces • Class members registered to the factory using the `uvm_field... macros • Class members of an UVM-based type (TLM ports included) © AMIQ 264 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com • Overridden functions and tasks from parent UVM base classes When the UVM Members Mode is off, the Members Panel behaves exactly like the Members Panel of the Type Hierarchy View. 29.2 UVM Compliance Review To perform the UVM Compliance review of your project click the SV Lint button in the toolbar of the Verilog Perspective, and select Lint As > UVM Compliance The UVM Compliance Review opens and contains the following tabs: • The Main Tab is the entry point (see image below). From here you can Export to HTML the report. • The Architecture Tab presents entities grouped by categories like agents, monitors, drivers etc. • The Checks Tab presents the status of all checks with links to relevant source lines. • The Statistics Tab presents various statistics. • The Waivers Tab can be used to edit and inspect the defined waivers. © AMIQ 265 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.2.1 Architecture Tab The architecture tab can be used to inspect the automatically detected environment architecture. 29.2.2 Checks Tab The checks tab can be used to inspect the compliance review results. Different filter combinations can be used to reduce the amount of information and have a better overview of the problems. The bottom of the view can be used to write different comments for every check as a reminder or for a later review. © AMIQ 266 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.2.3 Statistics Tab The statistics tab can be used to inspect the collected statistics. © AMIQ 267 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.2.4 Waivers Tab The waivers tab can be used to add, remove, edit and inspect the waivers. Waivers are used to change the status of the hits that are matched by the waiver properties. Hits can also be removed using the same method. The status option can be set to: • DISABLED: hits are removed • ERROR: hits are reported as errors • WARNING: hits are reported as warnings • INFO: hits are reported as info There are two types of waivers: • Manually defined waivers • Code waivers (collected from code) Manually defined waivers can be created using New... button from the Waivers tab. The Waivers Editor dialog offers an easy way to configure a waiver. The parameters that can be configured are: • Waiver Name: an unique name for the waiver • Waiver File: the file where the waiver will be saved (from the waivers include tree) © AMIQ 268 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com • Apply on: the scope of the waiver (it applies on matched or non matched hits) • Status: the status that will be applied to the matched hits • Check Names: the name of the checks this waiver applies to • Line Ranges: the line, or line ranges (StartLine:EndLine) this waiver must match • Message Patterns: the regular expression this waiver must match (Perl-like or simple regular expression) The waiver will match a hit if all defined parameters match the hit properties (the check that generated the hit, line, file, or message). If a parameter is empty (not defined) it will match any value. Code waivers can be inserted in code as comments with the following syntax: // @DVT_LINTER_WAIVER_START ["NAME"] STATUS [CHECK_1, CHECK_2] code line ... code line // @DVT_LINTER_WAIVER_END Where: • NAME: is the waiver name (optional) and must be enclosed within quotation marks • STATUS: is the status applied to the hits (mandatory) and must be one of the valid status values (DISABLE, ERROR, WARNING, INFO) • CHECK_1, CHECK_2: is a list of check names (optional) this waiver applies to, if it's not defined the waiver applies to all checks 29.2.5 HTML Report The report is divided in 3 panels. © AMIQ 269 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 1. Summary Page or Hits Page (right) 2. Categories and Checks Tree (middle) 3. Filters (left) Summary Page Summary page contains statistics charts and top failures from current state of the report. To toggle between summary page and hits page you can use the following button Donut charts represent the ratio of errors/warnings/infos/passed checks or hits. Under the charts, checks and files with the highest number of failures are displayed. Hovering over the checks or files will pop-up a filtering button that can be used to add that check or file to the filters. Hits Page The page appears when a check or category is selected in the tree or when the following button is pressed The hits table contains all the hits of the selected check or category and allows filtering and sorting. © AMIQ 270 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com To sort the table after severity, check, file or line, click on the column header of that specific property. Multiple sorting can be achieved by holding <Shift> pressed when clicking on the column header. Hovering over the checks or files column will pop-up a filtering button that can be used to add that check or file in the filters. Above the hits table a quick filter bar is displayed. It can be used to filter furthermore the hits displayed in the table. The quick filter applies to any information (check, file, line, message) available in the table and only the matching rows will show in the table. The small chart above the quick filter represents the ratio and absolute values of hit severities displayed in the table. Below the hits table a details area shows the information of the selected category, check and hit. Categories and Checks Tree Selecting a check or category in the tree will display the hits table for it. The details area will be updated with the information about that category or check. The status of a category or a check is computed based on the contained hits. © AMIQ 271 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com Filters Filters work on the information displayed in all components (summary page, checks tree, hits table). Status filters are filtering out the hits and checks that don't match and are applied on selection. Checks and files filters are filtering out the hits and checks that don't contain match. They are applied only when Reapply Filters button is pressed. The filters can also contain regular expressions. To save the state of the report (filters, selected checks, etc.) the save button can be used. Clicking it will show the URL needed to open the report in the same state © AMIQ 272 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.2.6 Problems View Integration The Problems View can be used to inspect the compliance errors with ease. As soon as the compliance is performed, all the problems automatically appear in the Problems View and as markers on the left part of the Editor. It is also possible to jump to source code or reapply the linting without leaving this view. 29.3 UVM Content Filters Out-of-the-box UVM Predefined Content Filters eliminate the unnecessary content overhead by automatically filtering out the irrelevant internal information from the UVM library. As it compiles the UVM library, DVT detects issues, collects task reminders, and analyzes the API defined by the UVM library, but it hides them by default. You can bring in the full content with a simple click. For more details see Content Filters. 29.4 UVM Factory Queries Factory Queries for config db setters, config db getters or factory overrides help quickly and accurately locate UVM factory related constructs that may influence the behavior of the testbench. You can run these queries from the UVM entry of the main menu. © AMIQ 273 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com Results are available in the Search View. • Tip Use the Quick Search to locate specific hits • Tip Navigate matches with Next/Prev buttons The Facoty Queries are detailed in the table below: © AMIQ 274 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com Query shows usages of config uvm_component.set_config_int() db setters uvm_component.set_config_string() uvm_component.set_config_object() uvm_config_db.set() config uvm_component.get_config_int() db getters uvm_component.get_config_string() uvm_component.get_config_object() uvm_config_db.get() factory uvm_component.set_type_override_by_type() overrides uvm_component.set_inst_override_by_type() uvm_component.set_type_override() uvm_component.set_inst_override() uvm_factory.set_inst_override_by_type() uvm_factory.set_inst_override_by_name() uvm_factory.set_type_override_by_type() uvm_factory.set_type_override_by_name() uvm_component_registry.set_type_override() uvm_component_registry.set_inst_override() uvm_object_registry.set_type_override() uvm_object_registry.set_inst_override() © AMIQ 275 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.5 UVM Field Editor The UVM Field Editor enables you to inspect and edit UVM field registrations. It allows you to quickly add, remove and edit the registration macros and presents field statistics (total no. of fields, no. of registered fields, no. of warnings/errors). 29.5.1 Triggering Triggering the UVM Field Editor for a certain class: place the cursor anywhere inside the class definition, right click and select Source > UVM Field Editor from the pop-up menu. If you place the cursor on a field, the UVM Field Editor will show up with the respective field selected. If there are no previously registered macros, the uvm_*_utils_begin and uvm_*_utils_end macros shall be determined based on the class found at the cursor position. For a class that inherits from uvm_sequence, a pop-up dialog will ask you to select the desired sequencer from the available ones. 29.5.2 Interface On the left side of the Field Editor Dialog there is a list containing all the fields in the class. You can register/unregister the class by clicking on the checkbox in the Class group. When the class is registered you can register or unregister fields by checking the corresponding checkboxes. When selecting a field you can also find information about the macro used for registration in the UVM Registration Macro group. If it's not the desired macro you can fix it using the Fix button. On the right side you can see the flag status of the registered fields. Its main features are highlighted and explained below: © AMIQ 276 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 1. Summary information regarding registrations: no. of registered fields, total no. of fields in class, no. of errors, no. of warnings. 2. Content Filters matched indication 3. Class checkbox that allows you to toggle the registration state. 4. Field type 5. Field name 6. Field icon. The field icons have the following meanings: Icon Meaning The class is not registered © AMIQ 277 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com The class is registered The field is a virtual interface The field is instantiated and is a UVM Component The field is instantiated and is a UVM Object The field is a port The field is an array The field is not registered. The field is registered. The field is registered and affected by a warning. The field is registered and affected by an error. 7. Field registration checkbox that allows you to toggle the registration state. 8. Select/Deselect all buttons. Used to register/unregister all the fields in a class. 9. Fix button. Used to fix a macro registration if the right one isn't used 10. The UVM Registration Macro that is currently used for the selected field. 11. Message area: displays error/warning messages. 12. Field operation checkbox. If checked, the flag will be added to the registration. 13. Field operation controls: allow you to select / clear all of the checkboxes. 14. Print radix radio button. If checked, the radix will be set in the registration. At most one radix can be specified. 15. Tooltip: hover with the mouse pointer any field operation checkbox or print radix radio button to obtain information about the flag. 16. Clear print radix: allows you to unset the print radix (set all radio buttons off). 29.5.3 Problems UVM Field Editor reports the following problems: Message Severity This field is registered with <current_macro_name> instead of Error <macro_determined_by_dvt> © AMIQ 278 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support Radix flag is specified more than once. www.dvteclipse.com Error The flags for the field registration are incorrectly specified. They should be Error OR-ed together using # (pipe character). DVT could not determine a registration macro for this field. Warning uvm_field_object will be used. 29.5.4 Tips • Shortcut • You can quickly trigger by using <Alt+Shift+G>. • Fixing problems • To fix a problem, press the Fix button if it's a wrong registration macro or unregister and register the field. Note: registering and unregistering the field will reset the flags/registration macro. • Multiple selection • You can't use multiple selection to perform registration/unregistration of more fields. Note: if you want you can register/unregister all the fields using the Select/Deselect all buttons. 29.6 UVM Smart Log DVT ships with predefined filters for UVM that allow you to view colored and hyper-linked logs like the one below. To turn on UVM Smart Log: • Select the predefined UVM filters as indicated below: © AMIQ 279 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.7 UVM Templates DVT offers autocomplete templates for UVM components. Just type in the editor uvm then hit <Ctrl + Space> twice and a drop-down list will offer you the available templates. After you pick the desired template, you can fill in the template parameters (e.g. company prefix, component name etc.). 29.8 UVM Verification Hierarchy See the Verification Hierarchy View. © AMIQ 280 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com 29.9 OVM to UVM Migration DVT provides an OVM to UVM migration wizard that automatically performs all the necessary changes within an existing OVM project. The changes may also be reviewed and customized. 29.9.1 Triggering Right click on a project in the Navigator View, then select Refactor > Migrate OVM to UVM. 29.9.2 Preferences In the first page of the wizard you can configure: 1. Refactor Script: the Refactor Script to use for performing the migration. DVT is shipped with predefined scripts (e.g. OVM 2.1.1 to UVM 1.0 EA), but you can also use custom scripts tailored to your needs (just click Browse to point to a script file on your disk). You can see the content of the selected script by clicking Inspect. 2. Skip Linked Resources: in general, linked resources are files located outside of the DVT project (like, for instance, the OVM library source files) so you might want the migration to skip them. 3. Disable OVM Project: in case your project is configured with DVT as an OVM project, the wizard removes this configuration. 4. Enable UVM Project: in case your project is not configured with DVT as an UVM project, the wizard adds this configuration. 5. UVM Library Path: if you enable UVM, the UVM library is compiled up-front, and you must specify its location. You can may use system variables ($UVM_HOME in the snapshot below). 6. Create UVM Linked Resource: for quick navigation in the library code, you may link (logical link, nothing is created on disk) the library files to your project. This way, although outside your project, the UVM sources will not be shown with gray icons and limited functionality. 7. Name of the linked folder © AMIQ 281 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com At this step you can either click OK to finish or Preview to inspect the changes that are about to be made. 29.9.3 Review changes In the review page you can inspect the changes that will be performed, and filter out (uncheck) the changes you don't want to perform. 1. Select a file/change to see the source differences produced by the refacotring. 2. Uncheck a file/change to prevent those changes from being applied. © AMIQ 282 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 29. UVM Support www.dvteclipse.com Click OK to apply the changes. © AMIQ 283 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 30. VMM Support 30.1 VMM Smart Log DVT ships with predefined filters for VMM that allow you to view colored and hyper-linked logs like the one below. To turn on VMM Smart Log: • Use +define+VMM_LOG_FORMAT_FILE_LINE in the simulator invocation or define VMM_LOG_FORMAT_FILE_LINE in the source code. • Select the predefined VMM filters as indicated below: Smart Log © AMIQ 284 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 30. VMM Support www.dvteclipse.com 30.2 Quick VMM Documentation Access • The Doxygen documentation is available at menu Help > Help Contents > VMM release number Doxygen '''. You may choose documentation version from menu '''Window > Preferences > Help > VMM Doxygen . • The SNPS VMM documentation is available at menu Help > Help Contents > SNPS VMM '''. You need to configure the path to installed documentation from menu '''Window > Preferences > Help > SNPS VMM. • The SNPS Testbench documentation is available at menu Help > Help Contents > SNPS Testbench '''. You need to configure the path to installed documentation from menu '''Window > Preferences > Help > SNPS Testbench. You can use Ctrl+Shift+H to quickly search through documentation (with or without selection in the editor). 30.3 VMM Templates DVT offers autocomplete templates for VMM components. Just type in the editor VMM then hit <Ctrl + Space> twice and a drop-down list will offer you the available templates. After you pick the desired template, you can fill in the template parameters (e.g. transactor name, environment name etc.). © AMIQ 285 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 30. VMM Support 286 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 31. Settings Management DVT allows you to customize various settings from memory allocation thresholds to run configurations or editor specific preferences like tab width and code templates. Starting with version 3.5, DVT provides an out of the box mechanism that simplifies settings management. Settings are organized in several precedence levels in order to allow a fine-grained control: • Project level settings are stored in <project>/.dvt directory • User level setting are stored by default in $HOME/.dvt/settings, the location can be customized using $DVT_USER_SETTINGS system variable • Common level settings are not stored by default, the location can be customized using $DVT_COMMON_SETTINGS system variable The order of precedence (starting with the higher one) is: • Project level • User level • Common level In order to reuse a specific setting, for example from project level to user level, all you have to do is copy it from the project level specific file to the user level specific file. In similar way you can move settings from user to common level for team or company wide reuse. 31.1 Managed Settings Not all settings are used in the same way. Some of the settings might be used only when the platform starts and others only when a specific operation is invoked. The following list presents the type of settings, the file where they are stored by default and order of precedence: • Eclipse Launcher Configuration • file name: eclipse.ini • description: settings used by the Eclipse launcher (executable) to start the process, for example memory allocation thresholds • precedence: • dvt.sh arguments • user © AMIQ 287 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com • common • $DVT_HOME/eclipse/eclipse.ini • handling: merged by precedence order; flags that have a key-value nature will be overwritten by the higher precedence value and all other flags will be accumulated • relevant settings: • memory allocation thresholds (-Xms, -Xmx, -Xss) • flags used by Eclipse • compiler exclude options • GTK RC File • file name: theme.gtkrc • description: settings used by GTK window manager under linux operating system to determine the window colors for buttons, text, etc. • precedence: • user • common • $DVT_HOME/.dvt.gtkrc • handling: replaced by precedence order; the file with higher precedence will be used • Workspace Preferences • file name: preferences.ini • description: any changes done through Window > Preferences dialog will be automatically reflected in the preferences.ini file at user level; • precedence: • user • common • handling: merged by precedence order; preferences will be overwritten by the higher precedence value • relevant settings: © AMIQ • key bindings 288 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com • global code templates • editor customizations • task tags • DVT Generic Run Configurations • file name: *.launch • description: run configurations are used to run external programs and can be serialized in *.launch files • handling: accumulated from all opened projects (including user and common locations automatically linked in DVT-Settings project) • Verissimo Linter Configurations • file name: *.launch • description: linter configurations are used to set the linter configuration files (*_lint_ruleset.xml, *_lint_waivers.xml, *_lint_user_notes.xml, *_lint_manual_checks_status.xml) and can be serialized in *.launch files • handling: accumulated from all opened projects (including user and common locations automatically linked in DVT-Settings project) • Compile Waivers • file name: waivers.xml • description: used to change the severity (promote/demote) or disable the problems reported by DVT during compilation (see Compile Waivers) • precedence: • project • user • common • handling: accumulated from all levels in precedence order • default location: <project>/.dvt/waivers.xml • Content Filters • file name: content_filters.xml © AMIQ 289 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com • description: used to eliminate the unnecessary clutter introduced by 3rd party libraries like UVM (automatically hiding their API, TODO reminders, problems, ...) • precedence: • project • user • common • handling: accumulated from all levels in precedence order • default location: <project>/.dvt/content_filters.xml • External Builders • file name: external_builders.xml • description: used to invoke any 3rd party script or tool and back-annotate its output (errors, warnings etc.) to the source code (see External Builders) • precedence: there can't be two configurations with the same name, if it happens there is no guarantee on the precedence order • handling: accumulated from all levels • default location: <project>/.dvt/external_builders.xml • Export HTML Documentation • file name: dvt_export_html.xml • description: settings used by the Export HTML Documentation Wizard (see Export HTML Documentation) • precedence: • project • user • common • handling: flags that have a key-value nature will be overwritten by the higher precedence value and all other flags will be accumulated • default location: <project>/.dvt/dvt_export_html.xml © AMIQ 290 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com 31.2 Unmanaged Settings There are also some settings that are not handled by DVT. The following list presents settings that won't be handled: • Position of dialogs • Is persisted when the same workspace is used but in can't be shared using user or common levels • Size of views • Is persisted when the same workspace is used but in can't be shared using user or common levels • Last opened perspective or saved perspectives • Is persisted when the same workspace is used but in can't be shared using user or common levels • Working Sets • Are persisted when the same workspace is used but in can't be shared using user or common levels • Secure storage information • This is preserved in $HOME/.eclipse/org.eclipse.equinox.security and is not handled by DVT • User installed plugins in a shared installation • This is preserved in $HOME/.eclipse/org.eclipse.platform* directories and is not handled by DVT • Settings used by other plugins that are not stored using the workspace preferences engine • These settings can be stored anywhere so is not possible to handle them 31.3 User and Common Settings Location • User level settings • Location is set by default in $HOME/.dvt/settings when DVT is started using dvt.sh or dvt_cli.sh scripts on Linux. On Windows and MacOS the user location is not defined and the engine for settings management is disabled. © AMIQ 291 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com • To set or change the location of user level settings the $DVT_USER_SETTINGS variable must be set in the environment before DVT is started. • Common level settings • Location is not defined by default. • To set or change the location for common level settings, the $DVT_COMMON_SETTINGS variable must be set in the environment before DVT is started. • If multiple common levels are needed then the variable can contain multiple paths separated using the OS's path separator. In this case the last directory will have the higher precedence. 31.4 Use Cases Using the same settings across all workspace and projects can be achieved by configuring the corresponding file and adding it in the user location (where $DVT_USER_SETTINGS points to). To share the settings with other users you must put the setting files in a common location and set $DVT_COMMON_SETTINGS to that location. A recommended work-flow for sharing any type of settings with other users is: 1. Start DVT in a clean workspace 2. Customize preferences 3. Define run configurations, compile waivers, etc. on a reference project and move the corresponding files in the user location (available under DVT-Settings/user) 4. Close DVT and move the files from the user location to a common location where all users can point the $DVT_COMMON_SETTINGS system variable 31.4.1 Memory Allocation Thresholds Create or modify the eclipse.ini file in the user settings location and add the new memory arguments. For example: -vmargs -Xmx2048m -Xms128m -Xss1m After adding the new memory thresholds every DVT instance will use them. If you want to change the memory only for a single invocation of DVT you can use the dvt.sh arguments (Xmx, -Xms, -Xss) in the command used to invoke DVT. © AMIQ 292 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com To share this configuration with other users you can put the eclipse.ini file in common location. Users will still be able to change the settings using an eclipse.ini in the user location. 31.4.2 Workspace Preferences Workspace Preferences are automatically saved in the user location preferences.ini file. Reusing them across workspaces is automatically achieved. To share a set of preferences you must copy the preferences.ini file in the common location. Some workspace preferences that are usually shared between users are: • Key Bindings - General > Keys • Code Templates - DVT > Code Templates • Task Tags - DVT > Task Tags • Formatting - DVT > e Language / SystemVerilog / VHDL > Editor > Formatting • Tab width and spaces > General > Editors > Text Editors 31.4.3 Run Configurations Run Configurations can be used to launch 3rd party tools and can be reused across workspaces and projects by using the Common Tab > Save as > Shared file and save it in DVT-Settings/ user project directory. To share them with other users move them in the common location. 31.4.4 Compile Waivers You can create Compile Waivers for libraries or IPs using a reference project and copy the <project>/.dvt/waivers.xml file in the user location to make it available for all projects. To share them with other users move them in the common location. 31.4.5 Content Filters You can create Content Filters for libraries or IPs using a reference project and copy the <project>/.dvt/content_filters.xml file in the user location to make it available for all projects. To share them with other users move them in the common location. 31.4.6 External Builders You can create External Builders to invoke any 3rd party script or tool and back-annotate the output to the source code using the wizard. The external builders will be saved in © AMIQ 293 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com <project>/.dvt/external_builders.xml and you can reuse them by copying the file in the user location. 31.4.7 Export HTML Documentation To use the same settings for Export HTML Documentation regardless of the project where you create the documentation you must generate a documentation using the desired settings. They will be saved in the <project>/.dvt/dvt_export_html.xml file. You can manually edit the file to remove specific settings like the <title> tag. The file can be moved afterwards in the user or common locations. 31.5 Examples To understand how settings from all levels are merged we can use the following layout for common, user and project levels: > common_settings/ > waivers.xml > preferences.ini > eclipse.ini > run_sim.launch > user_settings/ > preferences.ini > run_compile.launch > project/ > .dvt/ > ........... > waivers.xml DVT is invoked using the following command: dvt.sh -Xmx 4096m For the above example DVT will start using the flags specified in the common level eclipse.ini but the memory allocation threshold will be the one specified in the command (4096 MB) because the command line arguments have precedence. The DVT session will contain the run_sim run configuration and also the run_compile run configuration because these are accumulated from all levels. Workspace preferences will result from merging the preferences.ini from both common and user levels but if there are any conflicts the user level preferences will have precedence. Nonconflicting preferences are accumulated from both levels. When operating on the opened project, the compilation problems will be waived using the accumulated waivers from common level and project level (project/.dvt/waivers.xml). © AMIQ 294 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com 31.6 Deprecated Settings Management (before DVT 3.5) DVT settings use the Eclipse Platform settings mechanism. By settings we refer to every option that can be configured by users and are restored between different invocations of DVT. There are 3 types of settings: • Workspace Settings • Project Settings • Other Settings 31.6.1 Workspace Settings Workspace settings are mainly those that can be set in Window > Preferences dialog. These settings are persisted in the <workspace>/.metadata/.plugins/ org.eclipse.core.runtime/.settings/ There are also other settings that can be stored under <workspace>/.metadata/ directory and can be considered workspace settings. Some of them are: • The paths of the imported workspace projects • The last position of different dialogs • The settings of different views (e.g. column order) 31.6.2 Project Settings These settings are always correlated to the project and are saved under the project directory. It is very important to understand that every Eclipse plugin can create and maintain its own set of files with settings related to that plugin. .project file By default, the Eclipse Platform creates in every project directory a .project file that can contain the following information: • Project name • Project natures and builders (what kind of project is that and what are the plugins that should handle this project) • Linked resources information (files or directories from outside the project that are linked into the project's tree) .dvt directory © AMIQ 295 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com This directory is used to keep all the settings needed for a DVT project. Some of the files stored in this directory are: • .*_top_files or default.build used for compilation configuration • *_linter_waivers.xml and *_linter_ruleset.xml used for linter configuration 31.6.3 Other Settings There are another two places where DVT can store information. • $HOME/.dvt.gtkrc file is used to store GTK Theme settings on linux platforms. Since Eclipse Platform 3.x doesn't support themes, the feature uses this file to store the information about the colors. This file exists because the GTK hooks are done in the scripts before the platform is up. Be aware that GTK Theme settings are common between all DVT instances of that user. • $HOME/.eclipse directory can hold two things: • The Eclipse key ring settings, in case that any passwords are saved in DVT (e.g. CVS, SVN,... plugins can use passwords that can be protected with a master password). • User installed plugins when it uses a global installation (DVT directory is read only)/ 31.6.4 Importing Preferences From a Different Workspace Workspace Settings can be migrated between workspaces using different methods • Using Import/Export Wizard • Using dvt.sh Script • Manually Using Import/Export Wizard The recommended way to migrate workspace settings is through the Preferences Import/Export Wizard. To export the settings, start DVT in the workspace containing the settings, go to File > Export > General > Preferences, select Export All and choose the name of the file. To import the preferences, start DVT in the new workspace, go to File > Import > General > Preferences, select Import All and choose the name of the file. Using dvt.sh Script Another way to import the settings from an old workspace into a new one is to use the dvt.sh script to start DVT. © AMIQ 296 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com Argument Description workspace <dir> Path to the workspace directory. import_workspace_settings <dir> Path to the workspace from where the settings will be imported. force_import_workspace_settings <dir> Same as -import_workspace_settings, but it will overwrite target workspace settings. Manually To import workspace settings from an old workspace to a new one can be done just by copying the settings directory mkdir -p <new_workspace>/.metadata/.plugins/org.eclipse.core.runtime/ cp -r <old_workspace>/.metadata/.plugins/org.eclipse.core.runtime/.settings/ <new_workspace>/.metadata/.p 31.6.5 Customizing Default Settings Using dvt.ini Eclipse Platform supports setting the default preferences for every new workspace. This option is useful in many situations: • The user wants to use the same preferences in every new workspace, and using the export/ import is an overhead • The DVT application administrator wants to put a set of default settings for company wide deployment. The easiest way to customize the default settings is to set them in clean workspace and save them using the Show Changed Preferences Dialog in the distribution's dvt.ini file. The required steps to do this are: 1. Open DVT in a new workspace 2. Change the preferences 3. Use the Window > Show Changed Preferences dialog to identify the changed preferences 4. Add those in the dvt_eclipse/misc/dvt.ini file Now every new workspace will have those preferences. Show Changed Preferences Dialog To open the Show Changed Preferences Dialog go to Window > Show Changed Preferences The dialog allows the user to inspect the modified preferences and save them in a file. © AMIQ 297 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com Changing the Default dvt.ini To add new settings to the default settings provided with the distribution and to make them available by default for everyone who starts in a new workspace, the settings saved in the Show Changed Preferences Dialog should be added in the dvt_eclipse/misc/dvt.ini file. The dvt.ini file already contains some settings as distribution default. The user's settings should be appended to this file. Some of the default settings already present in the dvt.ini file are: Name Description org.eclipse.ui/ Enables the JVM memory monitor. SHOW_MEMORY_MONITOR=true org.eclipse.ui/ ENABLE_ANIMATIONS=false Disables the minimize/maximize animations. org.eclipse.ui.editors/ lineNumberRuler=true Shows line numbers by default in editors. org.eclipse.debug.ui/ Activates "Always org.eclipse.debug.ui.UseContextualLaunch=false application. ro.amiq.dvt/ spelling_user_dictionary= $DVT_HOME/misc/ dvt_dictionary.txt launch previously launched Sets the path to the distribution dictionary for DVT editors. Using a User Customized dvt.ini After creating a preferences file the user can replace the distribution's dvt.ini file to make them widely deployed or he or she can start DVT with a different file for default settings using the dvt.sh script: © AMIQ 298 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 31. Settings Management www.dvteclipse.com dvt.sh [any other argument] -eclipse_args -pluginCustomization <path_to_settings_file> © AMIQ 299 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 32. Reference 32.1 Common Shortcuts Ctrl+Shift+L Open the Shortcuts dialog. Use it to see all the available shortcuts. F3 Jump to declaration. Cursor must be on the entity name. Ctrl+L Open the Go to Line dialog. Use it to quickly jump to a line in the current file. Ctrl+D Delete current line. Ctrl + / Comment current line or selection. Ctrl+Q Jump to last edit location. Ctrl+Alt+R Rebuild Project. Ctrl+S Save. Ctrl+3 Brings up the Quick Access dialog - UI elements such as commands, views, wizards, preference pages etc. can be accessed directly by typing their name. Alt + / Autocomplete strings from currently opened editors. Alt+Shift+Up arrow Select the word at cursor position. Ctrl+F Open the Find dialog. Use it to find some text in the current file.If you select something, it will automatically fill the query. Ctrl+K +Shift+K Ctrl Jump to the next/prev match of the selected word in file. Shift+Alt+UP Arrow Select the identifier at cursor. F5 Refresh. Alt + r + t + With this shortcut you can quickly access a Run Configuration from Run <Configuration > Run History. Firstly, Alt + r will open the Run menu, then type t to open number> Run History and then type the number of the Configuration from that list. Ctrl+I Open the Quick Compile Order View dialog. Use it to quickly open a file. Ctrl+O Open the Quick Outline View dialog. Use it to quickly move around in large files. Ctrl+Shift+O Open the Quick Layers View. Cursor must be on the entity name. Use it to quickly locate and jump to an extension. Shift+F3 Update the Layers View to see all externsions/external implementations. Cursor must be on the entity name. Ctrl+H Open the Search dialog. Use it to search for a type, method, field, module, task, function etc. in the workspace, current project etc. If you select something, it will automatically fill the query. © AMIQ 300 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Ctrl+T Open the Quick Type Hierarchy View dialog. You can quickly see inheritance tree for a class, function etc. For methods, tasks etc. you also see the implementations along the hierarchy (icons are not grayed). Cursor must be on the entity name. Ctrl+P Open the Quick Macros View dialog. Use it to quickly jump to a macro definition. F4 Open and update the Type Hierarchy View to see the inheritance tree and members of a struct. Cursor must be on the entity name. Shift+F4 Open and update the Design Hierarchy View to see the design structure. Cursor must be on the entity name. Shift+F6 Open and update the Verification Hierarchy View to see the UVM instances structure. Cursor must be on the UVM registered class. 32.2 Editor Right Click Menu 32.2.1 Folding Collapse All Levels Fold to statement level. Show Active Preprocessing Show First Level Collapse all levels then expand one level. Expand All Levels Unfold code. Toggle Current Line Fold/unfold. Define Custom Region Create a folding marker for the selected region. 32.2.2 Macros See Macro Expansion 32.2.3 Source Jump to Pair Bracket Format Source See Code Formatting Toggle Comment Comment/uncomment selection or current line. OVM Field Editor See OVM Field Editor UVM Field Editor See UVM Field Editor Override Methods See Override Functions Emacs 32.2.4 Code Factory See Code Factory © AMIQ 301 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.2.5 Show Declaration See Use Hyperlinks to Move Around in the Code Diagram See Diagrams Type Hierarchy See Type Hierarchy View Design Hierarchy See Design Hierarchy View Verification Hierarchy See Verification Hierarchy View Layers See Layers View Quick Types See Quick Types View Quick Compile Order See Quick Compile Order View Quick Macros See Quick Macros View Quick Type Hierarchy See Quick Type Hierarchy View Quick Layers See Quick Layers View Quick Outline See Quick Outline View 32.2.6 References See Search For References 32.2.7 Trace See Trace Port Connections 32.2.8 Refactor Rename See Rename Refactoring Add Port See Add Port to Module from Selected Field or Add New Port to Module 32.3 Icons and Decorations 32.3.1 Icons Regular Verilog/SystemVerilog File Linked Resource Verilog/SystemVerilog File See Linked Resources. Out of Project Verilog/SystemVerilog File The file is not inside a project directory, nor accessible as a linked resource. Functionality is limited on "gray" files. © AMIQ 302 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Library Package Program Typedef Class Interface Module Checker Primitive Generate Field Enumeration name Constructor Function Task Event Constraint Cover Group Input Port Output Port Bidirectional Port Interface Port ModPort Wire Always Module Instance Unknown Instance Interface Instance Object Instance - Relevant for XVM methodologies, indicates a "created" object. Component Instance - Relevant for XVM methodologies, indicates a "created" component. Test Class - Relevant for XVM methodologies, indicates a "test" class. Root Class - Relevant for XVM methodologies, indicates the "root" class. Preprocessing define Preprocessing undefine Preprocessing ifdef, ifndef © AMIQ 303 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Code Template For example in autocomplete proposals. 32.3.2 Decorations Project Scope To enable/disable go to Window > Preferences > General > Appearance > Label Decorations preference page and check/uncheck Verilog Language Included File. Top Files Scope The marked entity is in the Top Files scope. See Build_Configurations. Access Modifiers To enable/disable go to Window > Preferences > General > Appearance > Label Decorations preference page and check/uncheck Verilog Language Access Modifier. Local Protected Public Errors and Warnings To enable/disable go to Window > Preferences > General > Appearance > Label Decorations preference page and check/uncheck Verilog Language Problem. Error Warning 32.4 Scripts 32.4.1 dvt.sh The DVT IDE Launcher. Usage dvt.sh dvt.sh -h[elp] dvt.sh © AMIQ 304 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com [-site site] [-workspace <dir>] [-import_workspace_settings <dir>] [-force_import_workspace_settings <dir>] [-dvt_log_location <file>] [-bg] [-eclipse_args <args>] [-Xms <size>] [-Xmx <size>] [-Xss <size>] [-eclipsespace <dir>] Where: [-workspace <dir>] Path to the eclipse workspace (temporary eclipse directory). [-import_workspace_settings <dir>] Path to the eclipse workspace from which settings will be imported. Valid only with -workspace. [-force_import_workspace_settings <dir>] Same as -import_workspace_settings, but it will overwrite target workspace settings. Valid only with -workspace. [-eclipsespace <dir>] Path to a custom eclipse storage directory (instead of ~/.eclipse). [-dvt_log_location <file>] File where DVT output will be sent (e.g. /dev/null). Default /tmp/dvt_log_13686. [-bg] Launch DVT in background. [-Xms <size>] (only in Linux) Set the initial and minimum Java heap size, size syntax is <N>[g|G|m|M|k|K]. [-Xmx <size>] (only in Linux) Set the maximum Java heap size, size syntax is <N>[g|G|m|M|k|K]. Default is 1024m for 32 bit OSs and 2048m for 64 bit OSs. [-Xss <size>] (only in Linux) Set the thread stack size, size syntax is <N>[g|G|m|M|k|K]. Default is 1m. [-eclipse_args <args>] Everything that follows this argument is passed to the eclipse executable as-is. THIS MUST BE THE LAST ARGUMENT OF THE COMMAND LINE © AMIQ 305 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Examples Start DVT without any option. You will be prompted for the workspace location. $> dvt.sh Start DVT with the maximum heap size of 4096 MB. You will be prompted for the workspace location. $> dvt.sh -Xmx 4096m Start DVT in the specified workspace. $> dvt.sh -workspace /home/cristian/dvt/workspace Start DVT in the specified workspace and use the specified eclipsespace for storing userspecific eclipse data, like for example plugins installed by user on top of a shared installation. By default this data is stored in /home/cristian/.eclipse. $> dvt.sh -workspace /nfsdisk/cristian/dvt/workspace -eclipsespace /nfsdisk/cristian/dvt/eclipsespace Start DVT with a custom configuration file. The default is /apps/amiq/dvt/eclipse/eclipse.ini. IMPORTANT NOTE: -eclipse_args must be the last argument of the command line $> dvt.sh -eclipse_args --launcher.ini /nfsdisk/cristian/dvt/mydvt.ini 32.4.2 dvt_cli.sh See Command Line Interface. 32.4.3 dvt_from_rawtokens.sh Creates and opens a DVT project from a rawtokens file. Usage dvt_from_raw_tokens.sh [-workspace <dir>] -projectpath <dir> -rawtokens <file1> [ ... -rawtokens <fileN>] -overwrite Where: [-workspace <dir>] Path to the eclipse workspace. Default: ~/dvt_eclipse_workspace -projectpath <dir> Path to the DVT project. It will be created. -rawtokens <file> © AMIQ Path to a rawtokens file. 306 Rev. 3.5.32 DVT SystemVerilog IDE [-overwrite] Chapter 32. Reference www.dvteclipse.com Delete project directory if already exists. Examples dvt_from_rawtokens.sh -workspace $HOME/dvt_workspace -projectpath $HOME/dvt_projects/aproject -raw 32.4.4 dvt_kit_installer.sh This script is a command line utility that can be used to install/uninstall plugins delivered with the DVT_KIT distribution for Linux and MacOS. The script allows you to create a DVT distribution with any combination of plugins from the following list: Plugins • CDT: C/C++ Development Tools (org.eclipse.cdt) • JDT: Java Development Tools (org.eclipse.jdt) • PYTHON: Pydev (org.python.pydev) • PERL: Perl Editor and IDE for Eclipse (org.epic) • TCL: Tcl Editor and IDE for Eclipse (org.eclipse.dltk.tcl) • CVS: Eclipse CVS Client (org.eclipse.cvs) • SVN: Subversive SVN Team Provider (org.eclipse.team.svn) • GIT: Eclipse EGit (org.eclipse.egit) • PERFORCE: Perforce plugin for Eclipse (com.perforce.team) • CLEARCASE: Clearcase plugin for Eclipse (net.sourceforge.eclipseccase) You can also see the list using: $DVT_HOME/bin/dvt_kit_installer.sh -h Usage dvt_kit_installer.sh [options] operation OPTIONS: The options must be specified before the operation [-w|workspace <dir>] © AMIQ 307 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com - Temporary workspace directory for this script (default /tmp/) [-s|simulate] - Simulate the operation [-h|help] - Display this help OPERATIONS: The operation must be specified after the options and only one operation can be specified followed by a list of plugins (containing at least one plugin) [-i|install <space separated list of plugins>] - Install the plugins specified in the list [-d|delete|uninstall <space separated list of plugins>] - Uninstall the plugins specified in the list Example Install the plugins for CVS, SVN and C++ $DVT_HOME/bin/dvt_kit_installer.sh install CVS SVN CDT Uninstall the plugin for CVS $DVT_HOME/bin/dvt_kit_installer.sh uninstall CVS Simulate the installation of JDT plugins $DVT_HOME/bin/dvt_kit_installer.sh -s install JDT 32.4.5 dvt_updater.sh This script is a command line utility that can be used to update/install/uninstall plugins (including DVT plugins) from an archived update site into the DVT Eclipse distribution. The script overcomes the unusual problems that can appear when the computer is not connected to the Internet and the user tries to install from a local update site: Script limitations: • Only root features can be listed with "-l" • If a plugin that is a dependency is uninstalled the script reports success but the plugin is still there. Usage dvt_updater.sh © AMIQ 308 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com install dvt_update_site-*.zip | update dvt_update_site-*.zip | uninstall [-w /path/to/workspace] [-f 'feature_name_1,..,feature_name_N'] [-l] [-s] [-h] Where: install - installs from the specified update site the features specified with or the default features. update - updates from the specified update site the features specified or the default features. uninstall - uninstalls the features specified or the default features. [-w /path/to/workspace] - path to a temporary workspace (default is /tmp) [-f 'feature_name_1,..,feature_name_N'] - a comma separated list of feature names, default features are: ro.amiq.dvt.feature, ro.amiq.dvt.extensions.feature com.mbartl.eclipse.viplugin.feature [-l] - lists installed root features [-s] - simulate the operation [-h] - show this help Examples Update DVT from an archived update site. $DVT_HOME/bin/dvt_updater.sh /path/to/dvt_update_site-*.zip List all installed root features. $DVT_HOME/bin/dvt_updater.sh -l com.mbartl.eclipse.viplugin.feature.feature.group/2.1.0.DVT20111227 com.mulgasoft.emacsplus.feature.feature.group/3.6.5 com.mulgasoft.emacsplus.optional.features.feature.group/3.6.5 com.xored.glance.feature.group/0.9.1 org.eclipse.dd.ipxact.feature.feature.group/0.2.2.201011301942 © AMIQ 309 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com org.eclipse.epp.mpc.feature.group/1.1.1.I20110907-0947 org.eclipse.platform.ide/3.7.1.M20110909-1335 org.eclipse.wst.xml_ui.feature.feature.group/3.3.1.v201108102009-7H7EFZ3DxumTlaI6nheRdHo2p1KaDIL org.fhsolution.eclipse.feature.csvedit.feature.group/1.1.1 ro.amiq.dvt.extensions.feature.feature.group/3.0.7.8 ro.amiq.dvt.feature.feature.group/3.0.7.8 Operation completed in 156 ms. Uninstall a plugin from the distribution. In this example the Vi and Emacs plugins are uninstalled. The name of a specific plugin can be found by listing all the root features. $DVT_HOME/bin/dvt_updater.sh uninstall -f 'com.mulgasoft.emacsplus.feature,com.mulgasoft.emacsplus.op 32.5 Toolbar Actions Icon Description Rebuild Project - See Build Configurations. Lint - Run Verissimo or XVM Compliance Checking. Diagrams - See Diagrams. Diagrams - See Export HTML Documentation. Diagrams - See GUI Filters. What's New? Report an Issue! 32.6 Views 32.6.1 Checks View The Checks View presents all the immediate, concurrent, deferred immediate assert and assume constructs in the project. Open the view from menu Window > Show View > Other... > DVT > Checks Double click on a check and jump to the source location. immediate assert concurrent assert deferred immediate assert immediate assume © AMIQ 310 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com concurrent assume deferred immediate assume 1. Quick Search. You can use CamelCase, Simple Regex or Hierarchical Search to locate a specific element. By default, hierarchical search will show all descendants: 2. Check Kind Filters. You may choose to hide immediate, concurrent assertions or assumptions - see the image below: © AMIQ 311 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.2 Code Templates View See Code Templates View 32.6.3 Compile Order View The Compile Order View presents the order of the compiled files as it results from the include's starting in the project top files. Open the view from menu Window > Show View > Other... > DVT > Compile Order. Double click on a file to open it. You can use CamelCase or Simple Regex to locate a specific element. A file that is not part of the current project (files are not under the project directory). A file in your project. Right click on a file will pop-up a menu with an option to Go To Include. By clicking on it, the file (parent) that includes the selected file instance will be opened in an editor. © AMIQ 312 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Quick Compile Order View Press Ctrl+I to quickly open a compiled file. The Quick Compile Order View will pop-up and and present a filterable list of all the compiled files in the project. You can use CamelCase or Simple Regex to locate a specific element. Select a file and press Enter or click to open it. 32.6.4 Console View Any invocation (for example a DVT Generic run) output is dumped to the Console View. The Console View is automatically raised at any invocation.You can also go to menu Window > Show View > Other... > General > Console. to open the Console View. Click on hyperlinks in the Console View to jump directly to the to source location. © AMIQ 313 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.5 Coverage View The Coverage View presents all the coverage groups and items in your project. Open the view from menu Window > Show View > Other... > DVT > Coverage. Double click on a group or item and jump to the source location. cover group simple item cross item transition item 1. Quick Search. You can use CamelCase, Simple Regex or Hierarchical Search to locate a specific element. By default, hierarchical search will show all descendants: 2. Cover Group. 3. Cover Items. © AMIQ 314 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.6 Design Hierarchy View The Design Hierarchy View presents recursively the instances in a Verilog module or the instances in a VHDL entity or component implementation. Cross-language design hierarchies are also supported. Position the editor cursor on the name of a design element and press Shift+F4 or right-click and choose Show > Design Hierarchy from the context menu. The Design Hierarchy View opens with the chosen element set as the top of the hierarchy. You can also go to menu Window > Show View > Design Hierarchy to open the view. • Select Top A drop-down menu/pop-up dialog to select from top modules for Verilog or top architectures for VHDL. For Verilog, a top element is a module that instantiates other design elements and it is not itself instantiated. Similar for VHDL top architectures. • History List Click to see the previously inspected elements. • Show Connect Toolbar Show or hide the connect instances toolbar. More details here. • Show/Hide Ports Shows or hides the ports of the selected element. You can set the ports panel to the right or below the hierarchy. © AMIQ 315 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com • Alphabetical Sort Sort instances and ports alphabetically. By default it is off which means that the instances and the ports are presented in their declaration order in the source files. The view label shows the current project, the current top element and the number of instances in the hierarchy. You can double-click on an instance to go to its declaration. Double-click on a port to go to where it is connected. Right-click on an instance in the hierarchy and you have the following options : • Connect Output See Connect Instances Using New Ports. • Show Diagram Show the HDL diagram for the current selection. More details here. • Copy Instance Path Copy to the clipboard the instance path for the current selection (for example: apb_subsystem_top.i_apb_subsystem). • Show Design Hierarchy Set the selected element as the top of the hierarchy and update the view. Right-click on a port and you have the following options : © AMIQ 316 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com • Trace Drive / Load / Drive and Load / In Subinstance See Trace Connections. • Connect See Connect Instances. You can use the filters to locate a specific instance or port. You may use slash '/' characters to filter hierarchically one level and '//' to filter hierarchically all the levels. You may use the dot '.' character to filter instances that contain a specific port. The ports that match the filter are promoted to the top of the ports panel. See Quick Search for more details. No filter. © AMIQ 317 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Filter by instance name. All instances that contain the filter text are shown. Filter strict hierarchy. All instances that contain the filter text and are in a direct hierarchical relationship (father/son) are shown. Filter non-strict hierarchy. All instances that contain the filter text and are in a direct or indirect hierarchical relationship (ancestor/../../descendant) are shown. Filter strict hierarchy and show all descendants. Same results as for filter strict hierarchy, but including all descendants of the matched instances. Filter strict hierarchy and show direct descendants. Same results as for filter strict hierarchy, but including the sons of the matched instances. © AMIQ 318 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Filter by port name. All instances with ports that contain the filter text are shown. Filter by hierarchy and port name. Hierarchical filtering and port filtering may be combined. 32.6.7 Layers View For an extern declaration you can quickly see where it is implemented using the Layers View. Position the cursor on the element's name and press Shift+F3 or right click and choose Show > Layers from the menu. The Layers View is automatically raised at any invocation. You can also open it from Window > Show View > Other... > DVT > Layers. Double click on a layer and jump to the corresponding source location. Right click on a layer to see its Usages. You can use CamelCase or Simple Regex to locate a specific element. © AMIQ 319 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 1. Show History List Click to see the previously inspected layers (see the image below): Quick Layers View Position the cursor on the element's name and press Ctrl+Shift+O. The Quick Layers View will pop-up and present a filterable list with all of the selected element's layers. You can use CamelCase or Simple Regex to locate a specific element. Select a layer and press Enter or click to jump to the corresponding source location. © AMIQ 320 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.8 Macros View The Macros View presents all the preprocessing macros in the project. Open the view from menu Window > Show View > Other... > DVT > Macros. Double click on a macro to jump to its definition. Right click on a macro to view its Usages. You can use CamelCase or Simple Regex to locate a specific element. Preprocessing define Preprocessing undefine Preprocessing ifdef, ifndef © AMIQ 321 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Quick Macros View Press Ctrl+P to quickly jump to a specific macro definition. The Quick Macros View will pop-up and and present a filterable list of all the preprocessing macros in the project associated with the active editor or the current selected project from the Navigator (if no editor is open). You can use CamelCase or Simple Regex to locate a specific element. Select a macro and press Enter or click to jump to its definition. 32.6.9 Outline View The Outline View presents an overview of the editor contents. Open the view from menu Window > Show View > Other... > General > Outline. © AMIQ 322 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com You can click on an entity to jump to its location inside the current file. You can use CamelCase or Simple Regex to locate a specific element. Filters... Select what elements to show Alphabetical Sort If alphabetical sort is on, all the entities are sorted by © AMIQ 323 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com name. By default the entities are presented in the definition order. Category Sort If category sort is on, entities are arranged by categories (fields, methods etc.), instead of being mixed as they appear in the file. Expand All Collapse All Quick Outline View Press Ctrl+O to open the Quick Outline dialog. It presents an overview of your file. You can use CamelCase or Simple Regex to locate a specific element. © AMIQ 324 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Outline View Preferences You can configure the Outline View contents from menu Window > Preferences > DVT > SystemVerilog > Outline View. © AMIQ 325 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.10 Problems View If a project contains errors, for example syntax errors, it will be indicated using decorators: © AMIQ 326 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com You can use the Problems View to inspect the errors. Open the view from menu Window > Show View > Other... > General > Problems. Double clicking on some error will jump to the source location. 32.6.11 Tasks View You can embed reminders in your source files by adding comments prefixed by certain "keywords" called task tags. There are three predefined tags: © AMIQ 327 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com • FIXME - high priority • TODO - normal priority • XXX - low priority All reminders are listed in the Tasks View. If it is not visible, open the view from menu Window > Show View > Other > General > Tasks. Double click on a task to jump to the marker definition. You can define custom reminder tags and assign them priorities: • Navigate to Window > Preferences > DVT > Task Tags You can specify if the tags should be considered case-sensitive and if the tag name should be displayed in Tasks View. • Click the Add... button on the right, enter the name of your tag and select its priority © AMIQ 328 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com • Click OK in the New Task Tag and Preferences dialogs DVT will recognize the new tag and highlight it in code comments. Note: it is recommended to rebuild the project so that DVT rescans all files for reminders. 32.6.12 Trace Connections View See Trace Connections View 32.6.13 Types View The Types View presents all the types (classes, structs, units, entities etc.) defined in your project. Open the view from menu Window > Show View > Other... > DVT > Types. Click on the Show Members button to show the Members pane. Double click on a type or type member to jump to its definition. Right click on a type or type member to search for usages or further inspect the Type Hierarchy View or the Verification Hierarchy View, where applicable. You can perform Search For Members. Toolbar Show/ Toggles the visibility of the members pane. Use the drop-down to chose Hide placement (to the right side or below the types tree). Members Sort Click to sort by category. Default sort order is alphabetical. by Category ExpandExpand all nodes in types tree. All Collapse Collapse all nodes in types tree. All © AMIQ 329 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Quick Types View Press Ctrl+Shift+T to quickly open a specific type definition for the project associated with the active editor or the current selected project from the Navigator (if no editor is open). The Quick Types View will pop-up and and present a filterable list of all the types in the project associated with the active editor or the current selected project from the Navigator (if no editor is open). You can use CamelCase or Simple Regex to locate a specific element. Select and press Enter or click to jump to its definition. © AMIQ 330 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com 32.6.14 Type Hierarchy View The Type Hierarchy View presents the inheritance and the members of a class. Position the cursor on the class name and press F4 or right click and choose Show > Type Hierarchy from the menu. The Type Hierarchy View is automatically opened at any invocation. You can also open it from Window > Show View > Other... > DVT > Type Hierarchy. You can right click in the inheritance tree and further inspect the Type Hierarchy or see Usages. Right click on a function or task member to override it. More details here: Override_Functions You can use CamelCase or Simple Regex to locate a specific element. © AMIQ 331 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Show History List Click to see the previously inspected types: Filters... Select what members to show (functions, tasks, fields, events etc.): © AMIQ 332 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com Quick Type Hierarchy View You can quickly inspect and jump to a specific parent or child in the hierarchy. Press Ctrl+T with the cursor positioned on the element name. The Quick Type Hierarchy View will pop-up and present a filterable list with all of the selected element's hierarchy. You can use CamelCase or Simple Regex to locate a specific element. Select and press Enter or click to jump to the corresponding source location. © AMIQ 333 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com For functions you can also see the implementations along the hierarchy (icons are not grayed). 32.6.15 UVM Browser View See UVM Browser. 32.6.16 Verification Hierarchy View The Verification Hierarchy View presents the UVM object instance tree. An UVM object instance is a class member of an UVM based type that is created using an UVM factory create call. Position the editor cursor on the name of an UVM based class and press Shift+F6 or right-click and choose Show > Verification Hierarchy from the context menu. The Verification Hierarchy View opens with the chosen class set as the top of the hierarchy. You can also go to Window > Show View > Verification Hierarchy to open the view. © AMIQ 334 Rev. 3.5.32 DVT SystemVerilog IDE • Chapter 32. Reference www.dvteclipse.com Select Top A drop-down menu/pop-up dialog to select from top UVM components. A top component instantiates other UVM components or UVM objects and it is not itself instantiated. • History List Click to see the previously inspected components. • Show/Hide Ports Shows or hides the UVM ports of the selected component. You can set the ports panel to the right or below the hierarchy. • Alphabetical Sort Sort instances and ports alphabetically. By default it is off which means that the instances and the ports are presented in their declaration order from the source files. The view label shows the current project, the current top component and the number of instances in the hierarchy. © AMIQ 335 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com You can double-click on any component or on any port to go to its declaration. Right-click on an instance in the hierarchy and you have the following options : • Show Usages (References) Search for the references of the selected instance. More details here • Show Layers Show the layers of the selected instance. More details here. • Show Type Hierarchy Show the type hierarchy for the selected instance type. More details here. • Show Verification Hierarchy Set the selected instance as the top of the hierarchy and update the view. • Open Type Declaration Go to the component declaration of the selected instance. • Open Create Call Go to the UVM factory create call of the selected instance. Right-click on a port and you have the options to search for its usages, its layers and for its type hierarchy. © AMIQ 336 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 32. Reference www.dvteclipse.com You can use the filters to locate a specific instance or port. You may use slash '/' characters to filter hierarchically one level and '//' to filter hierarchically all the levels. You may use the dot '.' character to filter instances that contain a specific port. See Quick Search for more details. For example, filtering hierarchically all the levels for a specific port name : © AMIQ 337 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 33. Tips and Tricks The following tips and tricks give some helpful ideas for increasing your productivity. Editing Code Navigation Searching Miscellaneous Editing Content assist Content assist provides you with a list of suggested completions for partially entered text. In the editor press Ctrl+Space. Module Automatic Instantiation © AMIQ You need to type the first letters of the module name, then press Ctrl+Space three (3) times.You can recognize module instances by their icon, it looks like a chip with ports ready to be glued in. 338 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Expand You can apply preprocessing over a selected section of code in order to see Macros how macros are expanded. You have multiple options in the right-click context (Apply menu Macros. To expand them in the source file, choose Expand One Level Preprocessing) Inline or Expand All Levels Inline. © AMIQ 339 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com To expand them in a temporary file, choose Expand One Level or Expand All Levels. Trace Macro To debug macro usage errors (especially if macros in macros are used) you can Errors see how the error is propagated from macro to macro (the error trace) either by: - going with the mouse over the error marker on the left and right click - or selecting the error in the Problems View, right click and choosing Macro Trace © AMIQ 340 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com The macro error trace will be presented in the Console View with hyperlinks to source. Code templates Code templates are presented in content assist if applicable. Matching begin - end If you double click on/after begin – end, function – endfunction etc. the block is highlighted. © AMIQ 341 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Mismatched endif You can use comments after endif to track the match with starting ifdef. If the name of ifdef doesn't match the endif comment a warning is issued. Toggle Comment You can toggle comment on/off for the current line or the selected lines. Press Ctrl+/ or use the action from the drop down menu on right click in editor. Select Word To select the word at cursor, press Shift + Alt + Up Arrow. at Cursor Format source Use the Source > Format Source action from the editor's right click menu. The whole file is formatted or the current selection, if any. Override functions To access the Override menu, in Editor, right click inside a class body > Source > Override Methods . © AMIQ 342 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com One key If you press Tab once at the beginning of a line, it is automatically aligned to indentation the enclosing context. Press twice to insert a tab. Reminders (TODO markers) When you tag a comment in source code with TODO, a corresponding tasks is automatically created as a reminder. From the Tasks View, double click on the task takes you to the TODO in the code. Same for for FIXME (higher priority) and XXX (lower priority) markers. You can also add your own tags, see the Reminders (TODO Markers) section of the documentation. Spell checking You can enable spell-checking support from the General > Editors > Text Editors > Spelling preference page. Spelling errors are displayed in the Verilog Language editor and corresponding Quick Fixes are available. Folding You can fold code sections to improve read-ability. This is how a folded file looks like: © AMIQ 343 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Folding actions (to expand or collapse) are available in the toolbar or on right click in the editor. You may also use the +''' or '-' signs on the left side of the editor. - Use '''Collapse All Levels for folding to statement (class, module ...) level. - Use Show First Level for folding to struct member (method, cover...) level. - Use Expand All to fully expand the file. When you type on a folded line, it is automatically expanded. You may see the folded code in a tooltip if you move with the mouse over the + sign. Folding You can define custom folding areas using comments to indicate the start and custom areas the end of the area: Maximize editor Double-click on the editor tab to maximize editor to full window. Doubleclick again to restore. Show line Check Show line numbers from the General > Editors > Text Editors numbers preference page © AMIQ 344 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Local history Whenever you edit a file, its previous contents are kept in the local history. Right click in the editor and choose Compare With/Replace With > Local History.... Inactive code The editor marks with a colored background the areas of code that are not highlight compiled due to preprocessing. See the Inactive Code Highlight documentation section. Emacs Automation © AMIQ You can invoke Emacs to perform automation on the file you are currently editing. In the editor window: Right click > Source > Emacs, then select one 345 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com of: Auto, DeleteAuto, InjectAuto, Indent or use the associated key bindings (the same as in Emacs). Note 1: the shortcuts are available only when Emacs mode is enabled in Eclipse; to enable Emacs mode go to Window > Preferences > General > Keys and select the Emacs scheme. Note 2: you can also add toolbar buttons to perform Emacs automation: go to Window > Customize Perspective > Command Groups Availability and check Emacs Verilog-Mode from the Available command groups on the left. Note 3: To change the default emacs command go to Window > Preferences > DVT and fill in the Emacs command you want to execute Open file in To open multiple editors for the same file you should first open the file then more editors right click on the editor's titlebar and select New Editor Split the To open multiple editors side by side follow these steps: editor view - open each file in its editor; if you wish to see the same file in a split view, right click on its titlebar and select New Editor - if you wish to split horizontally, drag the title bar of the file you want to split and drop it over the horizontal scrollbar - if you wish to split vertically, drag the title bar of the file you want to split and drop it over the vertical scrollbar © AMIQ 346 Rev. 3.5.32 DVT SystemVerilog IDE Column selection Chapter 33. Tips and Tricks www.dvteclipse.com You can switch to and from column (block) selection mode either by clicking on the “Toggle Block Selection Mode” button in the toolbar, or by using the <Shift + Alt+ A> shortcut key. Auto insert To add JavaDoc like comments to code, in Code Editor type above the code JavaDoc declaration /** and then press Enter. Depending on the code type (a class comment declaration, a function, a task etc.) a comment will be added with the respective JavaDoc tags. For more details: Export Html Documentation Code Navigation Tooltips © AMIQ When you position the mouse over a type, method, field etc., a tooltip will popup showing information on corresponding declaration. 347 Rev. 3.5.32 DVT SystemVerilog IDE Hyperlinks Chapter 33. Tips and Tricks www.dvteclipse.com If you place the mouse over a type, method, field, macro etc. and press the Ctrl key, a hyperlink will be presented. Click on the hyperlink to jump to definition. You can also jump to a definition if you put the cursor on the relevant name and press F3 Inheritance You can view the inheritance tree and all the members of a class by placing tree and the mouse over it '''and pressing the '''F4 key. members © AMIQ 348 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com (Type Hierarchy View) Design You can view the design hierarchy of a module by placing the mouse over it hierarchy of and pressing Shift+F4. a module (Design Hierarchy View) © AMIQ 349 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Class Diagrams You can create class diagrams to inspect or document the architecture of a verification environment. For more details see the Diagrams > Class Diagrams Current Scope The scope at cursor (function/class...) is always presented in the status bar. Quick Type You can quickly open a specific type definition. Press Ctrl+Shift+T. The Quick Types View will pop-up and you can enter any regular expression to locate a type. Select and press Enter or click to jump to its definition. © AMIQ 350 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Quick Outline Press Ctrl+O to open the Quick Outline for an overview of your file. You can enter any regular expression to locate a place to jump in the current file. Quick Compile Order © AMIQ You can quickly open a file that is included via the top files. Just press Ctrl+I. The Quick Compile Order View will pop-up and you can enter any regular expression to locate a file. Select and press Enter or click to open the file. 351 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Quick Type Position the cursor on the entity (struct, method ...) name and press Ctrl+T to Hierarchy see the Quick Type Hierarchy View. For methods and others, non-grayed icons means parent implementations are available. © AMIQ 352 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com External You can view the external implementations in the Layers View. Position the Implementationcursor on the relevant name and press Shift+F3 or right click and choose Show Layers from the menu. Types View © AMIQ You can view all the types (scalars, classes, module) in the project (including their fields, methods etc.) in the Types View. Open the view from menu Window > Show View > Other... > DVT > Types. 353 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Checks View You can view all the checks (immediate, concurrent, deferred immediate assert and assume constructs) in the project in the Checks View. Open the view from menu Window > Show View > Other... > DVT > Checks. © AMIQ 354 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Coverage View You can browse all the coverage definitions in the project using the Coverage View. Open the view from menu Window > Show View > Other... > DVT > Coverage. Compile Order View You can see the include tree of the files in your project in the Compile OrderView.Open the view from menu Window > Show View > Other... > DVT > Compile Order. © AMIQ 355 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Macros View You can see all the macros in your project in the Macros View.Open the view from menu Window > Show View > Other... > DVT > Macros. Outline View You can see the summary contents of the current file (structs, field, methods) in the Outline View.Open the view from menu Window > Show View > Other... > General > Outline. Mark occurrences © AMIQ When working in the SystemVerilog editor, turn on Mark Occurrences in the toolbar or press Alt+Shift+O. 356 Rev. 3.5.32 DVT SystemVerilog IDE Override Annotations Chapter 33. Tips and Tricks www.dvteclipse.com Override Annotations indicate that a function/task overrides a parent class implementation. Bookmarks Similar with a web browser, you can add bookmarks in your code without altering the code. Right click on the left vertical bar of the editor and choose Add Bookmark... Specify a meaningful name: © AMIQ 357 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com You can jump to bookmarks from Bookmarks View. Open the view from menu Window > Show View > Other... > General > Bookmarks. Go to line Press Ctrl+L shortcut or double click in the status bar to jump to a specific line. Back/ Forward navigation You can navigate between editors in a browser like way using the Back/ Forward Navigation Go to last edit Useful when you navigated around in the code, before proceeding with the location source change.Click on Last Edit Location button in the toolbar to jump to the file where you were previously editing. Searching Search for To search for the declaration of a specific type, method, field etc.: task. function, field etc. - Press Ctrl+H to open the Search Dialog - Click on the Vlog Search tab. - Type the name in the Search String (if you select in the editor before pressing Ctrl+H, the Search String is automatically set to the selection). - Select type or function etc. and Declarations - Click Search. © AMIQ 358 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Search for To search where a method (or field etc.) is used, right click on it's name > references References > Project. The results are presented in the Search View. You can also search for references from the Search Dialog (Ctrl+H). © AMIQ 359 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Search for To search for a whole word in all files, in comments or not: whole word - Press Ctrl+H to open the Search Dialog * Click on the vlog Search tab. - Type the name in the Search String (if you select in the editor before pressing Ctrl+H, the Search String is automatically set to the selection). - Select Whole Word and Do not search in comments or All occurrences - Click Search. © AMIQ 360 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Miscellaneous All shortcuts Press Ctrl+Shift+L to see all shortcuts. Project Properties © AMIQ Select the project in the Navigator View, right click and choose Properties. Or from menu Project > Properties. 361 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Export To generate the HTML Documentation click the Export HTML HTML Documentation Wizard button in the toolbar of the Verilog Perspective. documentation For more details see the Export HTML Documentation chapter. OVM/UVM Compliance Review To perform the OVM/UVM compliance review of your project click the SV Lint button in the toolbar of the Verilog Perspective. . OVM Editor Field The OVM Field Editor enables you to inspect and edit OVM field registrations. To bring up the OVM Field Editor, right click inside a class definition and select 'OVM Field Editor' from the pop-up menu, or simply press Shift Alt F. UVM Editor Field The UVM Field Editor enables you to inspect and edit UVM field registrations. To bring up the UVM Field Editor, right click inside a class definition and select 'UVM Field Editor' from the pop-up menu, or simply press Shift Alt G. © AMIQ 362 Rev. 3.5.32 DVT SystemVerilog IDE Project templates Chapter 33. Tips and Tricks www.dvteclipse.com A project template is a parameterized directory tree. Both in the file contents (.v, .sv, .sh - practically any file) and in the file or directory names you can use parameters. Combined with TODO markers, you can use a project template as a customized wizard.For more details see the Project Templates chapter in VlogDT User Guide. System See: Build_Configurations Variables and -f Support Generic You can launch external scripts: launch (make, scripts etc.) Menu Run > Run.... Select DVT Generic configuration and click the New button.# Specify name, working directory and command. Click Run. © AMIQ 363 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com You can also use the Run > Quick Run menu (or Ctrl+U shortcut key) to quickly launch any existing Run Configuration: Create dialogs scripts flows You can create Custom Dialogs for your own scripts: for & Follow the wizrd from menu New > Example > DVT > DVT Custom Dialog, then create a run configuration with the command echo ${dvt_dialog_prompt:customdialog.swtxml} and run it. External Builders © AMIQ An external builder allows you to invoke any script/tool and back-annotate its output (errors, warnings etc.) to the source code. It is a mean that allows 364 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com you to connect any 3d party tool (compiler, linter etc.) to DVT error signaling engines.You can configure one or more external builders on a project: - The commands you define will be invoked on project clean, full build and incremental build. - The patterns you define will be applied on the command output to recognize errors, warnings etc. - The pattern matches will be back-annotated to the source code and presented in a similar way DVT signals errors (file, line, in the Errors View etc.)DVT ships with some predefined example configurations to get you started.For more details see the External Tools>External Builders chapter in VlogDT User Guide. External You can browse and search through 3rd party documentation using the Eclipse Documentationhelp system.For more details see the External Tools>External Documentation chapter in VlogDT User Guide. Context Sensitive Help A focused set of help topics that is related to the current context can be shown to users on demand using context-sensitive help. This form of user assistance is delivered to users when a platform-specific trigger is activated (e.g. F1 key on Windows, Ctrl+F1 on GTK, Help key on Carbon).For more details see the Getting Started > Context Sensitive Help chapter in VlogDT User Guide. Mapping Linux Windows Linux directories can be mapped to Windows drives, thus allowing editing to files from Windows. For example /home/simi is mapped to Z:\. This has an impact on paths configured for a DVT project, for example INCDIRs etc. The paths are set using Linux conventions, however Eclipse runs © AMIQ 365 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com in Windows and the DVT builder needs to know about the mapping in order to compile the files. To specify the mapping, set the system variable %DVT_CROSSPLATFORM_MAP% before invoking Eclipse. You can add multiple mappings separated by ";" e.g.: /projects/=p:\;/home/lars/=Z:\lars\ Recover from In the event of unexpected behavior (missing results in search, types in type abnormal browsing, hyperlinks, tooltips etc.) please manually trigger a clean build from inconsistenciesmenu Project > Clean.... OVM Smart DVT ships with predefined filters for OVM that allow you to view colored and Log hyper-linked logs like the one below: See OVM Smart Log for more details. UVM Smart DVT ships with predefined filters for UVM that allow you to view colored and Log hyper-linked logs like the one below: See UVM Smart Log for more details. OVM to DVT provides an OVM to UVM migration wizard that automatically performs UVM all the necessary changes within an existing OVM project. To start the wizard: Migration right click on a project/file/directory in the navigator, then select Refactor > Migrate OVM to UVM. See OVM to UVM Migration documentation page for more details. © AMIQ 366 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Add a new Go to Window > Preferences > General > Content Types, select a category file extension from the list (for example Verilog Source File) then click on Add and then on to compile list Ok. extensions Sharing workspace settings Export all Workspace/ Eclipse customization: - Go to File > Export > General > Preferences - Make sure Export all is selected - Select a file where the preferences should be exported Now you can share this file with your team. When it is imported into another instance of Eclipse (by using File > Import > General > Preferences), the configuration (all options available in Window > Preferences) is replaced by the imported one. Note: you should restart Eclipse for the changes to be enforced ( File > Restart). © AMIQ 367 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com Using System You can use System Variables in the path of linked resources. For Variables in example ${DVT_ENV-SYSTEM_VARIABLE_NAME}/work is equivalent Linked to $SYSTEM_VARIABLE_NAME/work in a console. Resources Waive You can use Compile Waivers to promote, demote or disable the problems problems reported by DVT. reported by DVT To quickly create a new waiver, in the Problems View right click on any problem reported by DVT and waive it. DVT proposes some default values for the waiver description, path and message. You can easily change them to finetune the waiver. To quickly start up a new waivers file click on the Edit waivers button in the Problems View. The .dvt/waivers.xml is created with a default content and opened. You can easily create your own waivers from the default generated ones. In the waivers editor you can use autocomplete for tags, attributes and attribute values. Open a file in You can use the Command Line Interface like this: DVT from the terminal $> dvt_cli.sh -workspace ~/dvt_workspace openFile $(readlink -f my/file.sv) The command can be shortened by defining this alias in your ~/.cshrc: alias dvtopen 'dvt_cli.sh -workspace ~/dvt_workspace openFile `readlink -f \! *`' © AMIQ 368 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 33. Tips and Tricks www.dvteclipse.com or by defining this function in your ~/.bashrc: dvtopen () { dvt_cli.sh -workspace ~/dvt_workspace openFile $(readlink -f $1); } Then the command gets much shorter: $> dvtopen my/file.sv © AMIQ 369 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 34. Application Notes 34.1 Encrypted VIP Support In files that contain encrypted code, DVT may signal errors for mismatched language tokens, e.g. "Unexpected token 'endmodule'". The cause of this type of errors is most of the times the asymmetric encryption done to the code, e.g. an endmodule or an endif inside the encrypted code with the corresponding module or ifdef outside it, in plain text. Because DVT ignores encrypted code, some of the types may end up been compiled in the wrong scope altogether. To restore full or partial functionality, the asymmetric encrypted code must be fixed e.g. adding the missing endmodule. When the encrypted files are read-only, you will have to substitute the original broken files with the fixed ones. • Start by choosing a suitable directory to store the DVT substitute files. Often, they can be used across projects, so the directory should be outside of any DVT project directory in particular. You can define an environment variable to point to the chosen directory, like $DVT_FIXES. • For every file that needs to be fixed do: • Copy the file to $DVT_FIXES as is. • Modify $DVT_FIXES/file with the necessary fixes. • Tell DVT to use $DVT_FIXES/file as a substitute to file. This means adding to the default.build the following build directive: + dvt_file_substitute+/path/to/file=path/to/ $DVT_FIXES/file Having done the above, DVT will use the substitute files and offer valuable functionality, like hyperlinks, type hierarchy, references in the now correctly compiled code. Note The + dvt_file_substitute directive accepts only absolute paths as arguments. Environment variable can be used to define the absolute paths. Regular expressions are not supported. © AMIQ 370 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 35. Q & A 35.1 I am new to Eclipse, where should I start from? 1. Online from http://www.eclipse.org/documentation/. For example "Eclipse Ganymede Documentation (HTML Help Center)" is for Eclipse 3.4.The same documentation is available from Eclipse menu Help > Help Contents.Start with Workbench User Guide chapters Getting Started and Tasks.Really useful and relaxing is the Tips and Tricks chapter. 2. If you have installed the platform, you can always take a tour from menu Help > Welcome. 3. There is no experience compared with practice, especially for GUI intensive apps. 4. You can browse for more resources in the Eclipse site www.eclipse.org with good articles and responsive communities available. 5. Be prepared to discover nice functionality all the time. From time to time we recommend to read tips, tricks or concepts. 35.2 Where can I find DVT Help? You can access it by Help > Help Contents and Eclipse Help System is opened. The DVT Help is just another chapter inside Eclipse Help. 35.3 How do I see and configure the key shortcuts? Use Ctrl + Shift + L to get the list of all shortcuts. To configure go to menu Window > Preferences > General > Keys in the Modify tab. From the Modify tab you can also select the built-in Emacs scheme. Depending on the installed plugins, you may use other Emacs / Vi emulations. Related plug-ins: • ETEE [http://eclipseexeditor.sourceforge.net/] for Eclipse Text Editor Enhancements • Columns 4 Eclipse [http://sourceforge.net/projects/columns4eclipse/] or Column Mode for Eclipse [http://tkilla.ch/column_mode/] for rectangular selection • Lunar [http://sourceforge.net/projects/lunar-eclipse/] for editor enhancements © AMIQ 371 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.4 Are there any backup files in Eclipse? Right click on a file in the Navigator, from the pop-up menu select Compare With > Local History. To configure the history go to menu Window > Preferences > General > Workspace > Local History. 35.5 Workspace in use, cannot launch eclipse... Problem: I'm unable to select an existing workspace after my eclipse program that was accessing it was not shutdown properly. I get a "Workspace in Use" error when there are clearly no other eclipse instances running on my machine. Solution: If you are sure there is no eclipse looking at your workspace (not even another user), then you must remove the lock file located in the workspace at path_to_workspace/.metadata/.lock. On Windows, if you cannot delete this file (because another process is using it), then close all eclipse IDE sessions, do Control-Alt-Delete to bring up Windows Task Manager, select Processes page, and delete javaw.exe. 35.6 Locking is not possible in the directory... Problem: I'm unable to start DVT from a shared location, at launch time I'm receiving an error "Locking is not possible in the directory..." Solution: If you are using DVT in a shared installation setup, make sure that the installation directory is read-only for users. 35.7 How to start DVT Eclipse with a different eclipse.ini You might encounter situations when changing the default eclipse.ini configuration file is necessary, but you don't have write permissions over it. You can pass a different eclipse.ini file using laucnher.ini argument. If you use DVT as plugin: ./eclipse --launcher.ini <location> © AMIQ 372 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com If you use the prepacked distribution: ./dvt.sh -eclipse_args --launcher.ini <location> 35.8 Save could not be completed You might encounter the following error message while trying to save a file in the DVT editor: Save could not be completed. Reason: Some characters cannot be mapped using "CHAR_ENCODING" character encoding. Either change the encoding or remove the characters that are not supported by the "CHAR_ENCODING" character encoding. This means there are other characters than "CHAR_ENCODING" (e.g. ASCII) in the edited file, most probably introduced by another tool that was used for editing the same file. In order to locate (and eventually remove) these characters, you can use the following perl command: perl -nwe 'print if /[^[ :ascii: ]]/' filename 35.9 IBM Clearcase Plugin • It is not recommended to add new elements as this might result in unexpected behavior (existing files can be lost/renamed, new files might be created). • When working over a slow server connection, the Clearcase Plugin might report errors like: Exception in thread "ClearCaseDialogProgressMechanism" org.eclipse.jface.util.Assert $AssertionFailedException: Assertion failed: An operation is already in progress. 35.10 Non existing package mti_fli mti_fli is a non-standard proprietary SV package built into Questasim. To let DVT read it you should prepend the following line to your build configuration. {QUESTA_ROOT}/verilog_src/dpi_cpack/dpi_cpackages.sv where {QUESTA_ROOT} denotes the location where questa is installed. NOTE: In case you have an external builder configured to use the default.build, this setting will also be passed to the simulator. Therefore, the simulator will issue errors like: ** Error: /apps/questasim/verilog_src/dpi_cpack/dpi_cpackages.sv(4): Builtin package "mti_fli" cannot be replaced. To work around this issue, you need to have different command files for DVT and for the external builder. © AMIQ 373 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.11 libxul.so undefined symbol In case you encounter an error like the following: symbol lookup error: gdk_screen_get_resolution <path-to-xulrunner>/libxul.so: undefined symbol: you should check that the version of xulrunner installed in <path-to-xulrunner> is 1.8.x. Xulrunner is a library developed by Mozilla and used by the Eclipse platform to display web content. Unfortunately, the 1.9.x versions are known to have problems integrating with SWT. After installing xulrunner-1.8.x, there are two ways to tell eclipse where to find it: 1. In the console where you launch eclipse: setenv LD_LIBRARY_PATH=<NEW-XULRunner-directory-path> 2. Add the following line: -Dorg.eclipse.swt.browser.XULRunnerPath=<NEW-XULRunner-directory-path> in the " dvt_eclipse_directory/eclipse/eclipse.ini" file after " '-vmargs' " line where <NEW-XULRunner-directory-path> denotes the location of the newly installed xulrunner. 35.12 How to use Working Sets for filtering Problems/Task/Search views? First of all, in general you can customize the contents of the Problems/Tasks/Search views by using the View Menu > Configure contents. To see only the issues/tasks related to "your own code", you must first tell Eclipse what "your own code" means, and this can be achieved by using Working Sets. For easier access to Working Sets related commands, you should first enable two command groups: go to Window > Customize Perspective > Command Groups Availability, and from the Available Command Groups list on the left select Window Working Set and Working Set Manipulation. © AMIQ 374 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Now, there should be three new buttons in the Eclipse toolbar that allow you to select/deselect current working sets and add/remove resources from existing working sets. 1. Modify workbench working sets 2. Add the selected elements to a working set 3. Remove the selected elements from a working set Using the add/remove buttons you can craft one or more Working Sets to contain various sets of resources (i.e. files/folders). If you haven't created any working sets before you will be prompted to create a new one. Then, using the ' Modify Workbench Working Set ' button you can select several sets of resources form the ' Current Working Set '. © AMIQ 375 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Finally, to achieve the Problems View/Tasks View filtering you require, you should create a filter ( View Menu > Configure contents > New) where the Scope should be ' On Working Set: Window Working Set '. With this filter activated, the Tasks and Problems views will only show the errors that are contained in the sets selected from the toolbar dropdown. © AMIQ 376 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.13 How can I do an incremental textual search in any view? DVT distributions contain a plugin called Glance that can search incrementally in any view. Just select the view and press Ctrl+Alt+F to activate the search bar and start searching for text. 35.14 Diagram error - image has not been created There might be two kinds of errors related to Graphviz: 1. Graphviz is not (correctly) installed. © AMIQ 377 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com You can get graphviz from http://www.graphviz.org/Download.php, either as a package for your distribution or as source tarball. 2. Graphviz does not support png format. The problem might be related to the formats supported by the Graphviz package you have installed. DVT works with png format. To find out if your installation supports png, please issue this command in a shell: dot -T? and check if png is among the list of supported formats. If not, this can be easily solved by installing the package called graphviz-gd that adds png support to your current Graphviz installation. The official download location is here: http:// www.graphviz.org/Download.php - you just have to select the one matching your OS version & architecture. 35.15 How to handle Simulator and Command Line Macros Some simulators define proprietary pre-processing that might have some implications on the actual simulated code (see for example in OVM lib ifdef INCA occurrences). Also, many times, compilation/run scripts take as arguments macro definitions. See Build Configurations for enhanced support of simulator commands files. Until we'll fully integrate with all simulators and/or we provide preferences for specifying macros and means for easily turning them on/off, we recommend to create a dummy *.sv file that you set first in the top files project property as follows: 1. Create a separate dummy *.sv file ( eclipse_simulator_macros.sv) where you'll define simulator macros guarded by ifndefs. 2. Put the dummy macros file in your project. © AMIQ 378 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 3. Configure the Project Top Files so that the dummy macros file will be the first one. 4. Rebuild. Dummy macros might look like: Build Project 35.16 How do I Access Files Outside Project Dir - Working with Linked Resources In order to see the contents of some directory on your disk, you must create an Eclipse project in that directory (see also What is a Project ). If your project is spread across multiple directories without a reasonable common root or if you need to access files somehow related to your project that are not located in the project directory , you can open them from menu File > Open File.... If the file is outside any project in your workspace, the editor will open and the tab icon will be grayed. For example if you have a single project xbusonly in your workspace located in /ovm/ examples/xbus that includes files from /ovm/src and you open ovm.svh (for example via a hyperlink from the include directive) the editor tab will look like this: The same will happen if you jump to a definition located in the /ovm/src directory. The functionality in "gray iconed" editors is limited (no hyperlinks etc.). NOTE: This "capability" serves as an alarm that you are out of your project scope and avoid touching the files. But if you are just navigating in order to understand the world around your project (module), limited functionality it's not what you want. Solution 1. Create the project in a "root directory" that encloses all directories with relevant files (or emulate) This is a simplistic solution. Besides additional relevant files, it is most likely to get in a lot of unrelated files that might also slow the platform. A variant might be to create a special "root" directory with file system links to each directory whose contents you must access. Then create an Eclipse project in the "root". It requires changes to disk (links) just to work with Eclipse, not really acceptable. © AMIQ 379 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Solution 2. Create a project in each relevant directory This solution might work for you. In the example above, it is most probable that a project is already defined for ex_atm. But if a project is just spread in multiple directories without a common root and each directory it's not really a separated project, it will be cumbersome to have my_p__dir_1, my_p__dir_2 projects. Solution 3. Linked Resources Choose one "main" directory to locate the project and create linked resources from it to other relevant external directories. Linked resources are very similar with file system links, except they are registered in the .project file, not created on the disk. For more details see Linked Resources. Full functionality is available for files accessible via linked resources. Linked Resources What is a Project What is a Workspace 35.17 Mapping Linux to Windows (/ proj/ to Z:\proj\) Linux directories can be mapped to Windows drives, allowing editing files from Windows. For example /home/simi is mapped to Z:\. This has an impact on paths configured for a DVT project, for example INCDIRs etc. The paths are set using Linux conventions, however Eclipse runs in Windows and the DVT builder needs to know about the mapping in order to compile the files. To specify the mapping, set the system variable %DVT_CROSSPLATFORM_MAP% before invoking Eclipse. You can add multiple mappings separated by ";" e.g.: /projects/=p:\;/home/lars/=Z:\lars\ NOTE: Please do not put any mapping of type /=\, we are handling this automatically. 35.18 Subversive vs Subclipse Subversive does not automatically recognize svn projects while Sublicpse does. © AMIQ 380 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.19 How do I associate a project with both DVT and CDT? There are two situations: 1. You have a DVT project containing C/C++ sources and want to associate it with CDT Go to File > New > Other and select C/C++ > Convert to a C/C++ project. After completing the wizard, the C/C++ files in the project should handled by CDT. 2. You have a CDT project containing Verilog/SystemVerilog sources and want to associate it with DVT Just right-click on the project and choose Toggle Verilog Nature. Now the Verilog/ SystemVerilog files in the project should be handled by DVT. See Build Configurations for further project configuration. 35.20 Can I use vi/vim along with DVT? DVT contains ViPlugin OEM ( http://www.viplugin.com/viplugin/index.php/viplugin) for vi emulation. To use it download a prepacked version of DVT or install viPlugin for DVT feature from DVT Update Site. Below you can find a list with other vi emulation plugins for Eclipse: 1. http://vrapper.sourceforge.net/home/ • free • easy install from update site • has some basic vi commands that work in editors • DVT editors work perfect with it 2. http://eclim.org/ • free • hard to install • integrates Eclipse in vi or vi in Eclipse (it has many modes) • has not been tested extensively with DVT 3. http://vimplugin.org/ • free © AMIQ 381 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com • easy to install from update site, but requires needs JDT (Java Development Tools) installed in eclipse and gvim in os • it replaces editor window in eclipse with gvim window, therefore no DVT editor feature is preserved 35.21 Can I perform dos2unix or unix2dos from DVT? Yes, you can access this built-in functionality from File > Convert line delimiters > <desired format>. Depending on the focus, the conversion is performed either for the current editor or for the files selected in the navigator view. 35.22 How can I configure Eclipse to use a local CVS repository? 1. Create a shell script with the contents below somewhere on disk and make it executable. 2. In Eclipse, go to the CVS peference page (Window > Preferences > Team > CVS > Ext Connection Method) • Select "Use an external program to connect" • For "CVS_RSH" enter the path to the script you just created • For "Parameters" enter a whitespace (won't work if left empty) • For "CVS_SERVER" you should have "cvs" 3. Add a new CVS repository location in Eclipse (File > New > Other > CVS > CVS Repository Location) • For "Host" enter "localhost" • For "Repository path" enter the local absolute path to your repository • For user and password you can enter anything (will not be taken into account) • For connection type select "ext" At this point the repository you've just created should be functional in Eclipse. You can checkout a module to see that everything is OK. In order to make cvs work in the command line as well (with projects checked out from Eclipse) you have to set the system variable CVS_RSH to point to the script and CVSROOT to the the local absolute path to your repository. Script content © AMIQ 382 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com #!/bin/sh if [ "$1" != "cvs" ]; then # Remove -l {user} {host} shift shift shift fi exec "$@" 35.23 I am using the Common Desktop Environment via Citrix and experiencing crashes. What can I do? This seems to be a problem related to running Eclipse under CDE via Citrix. Try changing CDE to another Desktop Environment, like the Java Desktop System (JDS). 35.24 How do I change the background color of the Editor? Go to Window > Preferences, then navigate to General > Editors > Text Editors. In the panel on the right, from the Appearance color options list select Background color, then use the color picker to choose the desired color (the System default checkbox must be unchecked). 35.25 How do I change the color of the interface? If you are using the linux distribution of DVT you can change these colors by going to Window > Preferences, then navigate to DVT > GTK Theme. This will overwrite the GTK theme of your system just for DVT when you start it using a distribution script. After applying a theme a restart is required. For Windows and MacOS users it is not possible to define an application theme, so the only workaround is to change your system theme to the desired colors. 35.26 How to apply the dark color theme or other themes? If you want to change the color for all the editors and the interface you can use the DVT Themes feature. Go to Window > Preferences, then navigate to DVT > DVT Theme and select a predefined theme or import a theme file. © AMIQ 383 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com To use dark colors you can select the Dark predefined theme. After applying a theme a restart is required. This theme will apply on the selected edtitors and also to GTK if you're using Linux or Solaris distributions. Keep in mind that applying a theme will overwrite the color preferences for the selected editors. 35.27 How do I change the tooltip colors? If you want to change the tooltip colors and GTK Themes are not available (Windows, MacOS) then you can use Preferences > General > Appearance > Colors and Fonts > DVT > Tooltips and for content assist Preferences > General > Appearance > Colors and Fonts > Basic' 35.28 How do I change Internet Proxy Settings? If you want to change the proxy settings go to Window > Preferences > General > Network Connections Active Provider - Specifies the settings profile to be used when opening connections. Choosing the Direct provider causes all the connections to be opened without the use of a proxy server. Selecting Manual causes settings defined in Eclipse to be used. On some platforms there is also a Native provider available, selecting this one causes settings that were discovered in the OS to be used. © AMIQ 384 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Proxy entries - The table displays entries that are available for all providers. Checkboxes in the first column of the table indicate entries to be used for the currently selected provider. Proxy bypass - Use this table to specify, either by name or pattern, the hosts that should not use any proxy. A direct connection will always be used for matching hosts. Checkboxes in the first column of the table indicate entries to be used for the currently selected provider. When using Manual proxy provider there are three predefined schemas to set settings for: HTTP, HTTPS and SOCKS. Configuration for each schema is displayed in the Proxy entries table. To edit settings for a particular schema double-click the entry or select the entry and click Edit... button. If Port field is left blank default port number will be used: (HTTP - 80, SSL - 443, SOCKS- 1080). 35.29 Eclipse does not start, there is no Workspace, metadata or log file created A possible cause for this could be the lack of access rights to all, part or one of the files under $DVT_HOME. Solution: • check the log in the ~/user'shome/.eclipse/org.eclipse.platform_/configuration/.log and see what is the file that can not be accessed • make sure that you have rx rights on all files & folders under $DVT_HOME 35.30 Workspace permissions A possible solution for the following errors (or similar issues) is to add write permission for the Workspace you are currently using and all files inside it. © AMIQ 385 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Keywords: unable to save, failed to write, ResourceException, unable to store; 35.31 How to install our server as a service in Windows? To start the server in background you can use a freeware tool named hstart that can run commands without using a terminal. You can download it from here: http://www.ntwind.com/download/hstart.zip The archive contains two files: hstart.exe and hstart64.exe. Use the one appropriate for your Windows (32bit or 64bit). Assuming that hstart.exe, the license file and dvt_server_1.9.jar are in the same location you can create a batch file, named for example start_dvt_server.bat with the following content: hstart.exe /NOCONSOLE "java -jar dvt_server_1.9.jar your_license_file" When you run the script, the server will start in background with no console attached. To stop the service you can use the dvt_utils.jar tool or you can stop it from Windows Task Manager. 35.32 How do I link mylyn with Bugzilla? It works like this (if mylyn is installed): © AMIQ 386 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com In the editor, comments that include text of the form bug#123 or task#123 or bug 123 will be hyperlinked. Ctrl+clicking on this text will open the task or bug in the rich task editor. To support hyperlinks within other text editors such as code or .txt files, the project that contains the file must be associated with a particular task repository. This is configured by right-clicking on the project and navigating to Properties > Task Repository and selecting the task repository used when working with this project. 35.33 How do I print source code? For black and white printing you can use enscript - if it is available on your platform. Go to Run > External Tools > External Tools Configurations… and follow the next steps: 1. Create a new Launch Configuration 2. enscript location (you can use which enscript command to get its path) 3. enscript arguments 4. Apply > Run © AMIQ 387 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com The above enscript arguments ( '-2rT4v -DDuplex:true -dPhotosmart_C5100') used in this example mean: 2 = 2 columns on page,r = landscape, T4 = tab size 4, v = verbose, Photosmart_C5110 = a printer name See also "man enscript" (in a Unix/Linux console). For color printing, you can copy/paste into Word / Open Office. The highlight is preserved. You can customize fonts / preview etc. in office tools. 35.34 How do I disable Eclipse Software Sites? Eclipse contacts all Update Sites even if the option is un-checked ( Help > Install New Software... > Contact all update sites during install to find required software). To disable update sites querying, go to Window > Preferences > Install/Update > Available Software Sites and unselect all the references to software sites in that list. 35.35 How do I revert to a previous version? In case you have updated DVT Eclipse and you want to go back to a previous installation checkpoint you can do that using: Help > About Eclipse > Installation Details > Installation History. Using this page you can select a previous configuration and inspect the installed plugins and versions. If you decide to go back to one of the old configurations just select it an click Revert. © AMIQ 388 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com NOTE: Sometimes Eclipse might need the update site for the plugins involved in the revert operation, to add them go to Window > Preferences > Install/Update > Available Software Sites. 35.36 What are the most common shortcuts in DVT? If you type Ctrl + Shift + L a list with all available Eclipse shortcuts will pop-up. For more information: Common Shortcuts 35.37 How does DVT integrate with emacs? 1. DVT integrates some emacs Verilog-Mode actions (provided that emacs is already configured): indent code, inject/delete/run automation. To activate: go to Window > Customize Perspective, then select the Command Groups Availability tab and in the list on the left select the checkbox Emacs Verilog-Mode. You should then see the emacs buttons in the toolbar. 2. Eclipse has a built-in emacs keyboard scheme. To activate it: go to Window > Preferences then General > Keys and change the Scheme to Emacs 3. There is an emacs plugin for Eclipse available at http://www.mulgasoft.com/ 35.38 How does DVT integrate with CVS? Get the CVS plugin: The simplest way is to install DVT from a prepacked distribution that includes the CVS plugin for Eclipse. For an Eclipse installation that find in the Navigator View that the projects that were previously checked out are now recognized as shared projects. If you right click on a file/directory in the Navigator View, you should have common operations under the Team menu ( Update/Commit/Show history etc). 35.39 How to set an environment variable within a Run Configuration? More details here © AMIQ 389 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.40 How to run a remote Unix commnad from DVT Eclipse for Windows? Presuming that you use ssh or telnet to connect to the unix environment you can use a putty tool to do this. The name of the command is plink.exe [http://www.chiark.greenend.org.uk/ ~sgtatham/putty/download.html] and it can be considered the analog of ssh for Windows. You can use the plink.exe command with the DVT Generic Launch Configuration. More information about how to use plink.exe can be foudn here http://the.earth.li/~sgtatham/ putty/0.61/htmldoc/Chapter7.html#plink. There is also a sub chapter about how to use plink unattended (it won't require any interaction like user or password input). 35.41 Rebuild shortcut (Ctrl + Alt + R) does not work If 'Ctrl + Alt + R' does not trigger a rebuild, you can change it from Windows > Preferences > General > Keys > select 'Default' scheme > search for 'Rebuild Project' > change the binding > OK © AMIQ 390 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.42 Sometimes I experience DVT GUI hangs, what should I do? When you experience GUI hangs please follow the next steps in order to provide us some valuable debug information about your situation: • While the GUI is hanged, run the following command $DVT_HOME/bin/dvt_debug_utils.sh -workspace /path/to/dvt_workspace -thread_dump -nof_kills 60 • When the command above is done (in ~1 minute), it prints the path to the log file it has generated, like this: DVT log file is: /tmp/dvt_log_<pid#> • Send us the generated log along with a brief description of the activities you were performing in DVT when the hang occured (like for example creating a New Project, invoking the Content Assist, maximizing a view, etc.). 35.43 Sometimes I experience DVT GUI hangs when switching from another X application to DVT In some GTK/X versions, when switching from various X applications to DVT, you might experience unresponsive UI for various periods of time (from tens of seconds up to complete hangs). This behavior has its roots in the way the respective applications, X and GTK manage the System Clipboard. First off, you should make sure you are running a recent GTK version. If it's not possible to update your GTK / if the problem persists when running with the newest GTK available for you, this section covers an alternative solution. To confirm that you are affected by this problem, follow the steps in this section in order to generate a debug information file (in the example: ~/dvt_threads.dump) and in addition, run the following command: $> grep gtk_clipboard_wait_for_contents ~/dvt_threads.dump 2>&1 1>/dev/null && echo "Yes" || echo "No" If the grep result is No you are probably not affected by this specific issue, so we recommend sending us the ~/dvt_threads.dump file in order to furhter investigate the problem. If the grep result is Yes you can fix the problem by patching your Eclipse installation. For patching, DVT must be installed from a prepacked distribution. Follow the steps below: • Suppose your DVT Eclipse installation directory is $DVT_HOME. First make a backup of the file to be replaced: $> mv $DVT_HOME/eclipse/plugins/org.eclipse.swt.gtk.<os>.<arch>_<version>.jar $DVT_HOME/eclipse/ © AMIQ 391 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com where <os>, <arch> and <version> are specific to your system & installation. • Then copy the patched jar file: $> cp $DVT_HOME/misc/patch/org.eclipse.swt.gtk.<os>.<arch>_<version>.jar $DVT_HOME/eclipse/plugi • Restart DVT. You should not experience any more hangs. NOTE In some cases it was reported that although the patch eliminated long GUI lagging/ hangs, it introduced some minor lags when changing the file selection in the navigator. If this is your case, you should set the following environment variable: $> setenv DVT_SWT_CLIPBOARD_PATCH_TEXT_ONLY_MODE true before launching DVT. Navigator selection will work smoothly again. The only drawback is that you won't be able to paste files directly in the Navigator view. 35.44 I want to use an alias in a DVT Generic Run Configuration, but it's not recognized More details here 35.45 How to set multiple paths as sources of predefined projects ? You can set an environment variable starting with "DVT_PREDEFINED_PROJECTS_EXT_" for each directory that contains predefined projects. For example, if there are two directories - let's say dir1 & dir2, you must create two environment variables pointing to them: • $DVT_PREDEFINED_PROJECTS_EXT_1 -> dir1 • $DVT_PREDEFINED_PROJECTS_EXT_2 -> dir2 Note 1: Each environment variable must point to only one directory that can store any number of projects Note 2: Avoid duplicate projects in different directories 35.46 Lines are suddenly changing indentation when I edit text or move the cursor through the editor. This might happen if you don't use a monospaced font ( e.g: Courier ). To change the editor font: © AMIQ 392 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 1. Go to Window > Preferences. 2. From here go to: General > Appearance > Colors and Fonts. 3. In the window on the right side choose: Verilog Language > Editor > Verilog Language Text Font 4. Press Edit and check that the font you are using is monospaced. If it isn't, choose one from the list ( ex: Courier, Monospace). 5. Ok > Apply 35.47 How to change the directory where the build log file is saved ? Open the active .build file under the .dvt diredctory (e.g. .dvt/default.build) and add these flags: +dvt_build_log_to_file+true/false +dvt_build_log_file_location+path/to/folder (use "." for project's root) 35.48 How to find the DVT logs on Linux/Unix ? If you run DVT with dvt.sh: • To print the logs location go to the workspace dir and: $ dvt_debug_utils.sh • To dump the threads of a running DVT go to the workspace dir and: $ dvt_debug_utils.sh -thread_dump Other logs are in the <path_to_workspace>/.metadata folder. 35.49 How to create resource filters ? Right click on a project > Properties > Verilog Language > Resource Filters. From this wizard you can select what resources to exclude from the selected project. By default it only shows 50 children for each directory. If a directory contains more than 50 children you are not allowed to filter its content. You can modify this limit, globally, from Maximum number of children for each directory or by right-clicking on a directory and selecting Show more files. There is also a Timeout option if the project's resources are located on remote computers and the network lag may slow down the platform. The wizard will display only those children (files/ folders) that were scanned before the timeout is reached. © AMIQ 393 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com WARNING: DVT Resource Filters are not fully compatible with Eclipse's filters. If you already use standard platform's filters, it is recommended to disable them before applying DVT filters. NOTE: Linked-Resources (project's resources linked to file system directories) cannot be filtered; you can only filter their children. 35.50 How to create custom shortcut and button for a Run Configuration? More details here 35.51 I know that file.foo is present in the project location, but I can't see it in the Navigator View Check if there is a Navigator filter enabled preventing the file from being displayed. Bring down the Navigator View Menu and select 'Filters': © AMIQ 394 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com Make sure there is no pattern in the list that matches the name of the file (like for example *.foo). 35.52 How to copy the full path to the file in the current editor? Right click in the current editor > Copy Full Path. You can also assign it a shortcut: go to Window > Preferences > General > Keys (or press twice ctrl + shift + L ) and assign a shortcut to Copy Full Path. It's a global shortcut, you can call it from anywhere but only the active editor's input will be considered (or the current selection in the navigator if you call it when the navigator view is active e.g. after you select a file). 35.53 How to adjust the console logs filters matching parameters? Go to: Run > Run Configurations... > select a run configuration > open Filters tab. Here you can adjust how many characters per line (between 1-999, default 256) and how many consecutive lines (between 1-99, default 8) can be matched by a filter. These limitations prevent inifinite recursive matching if a log message does not follow a standard pattern or it is too long. 35.54 When I switch to Block (Column) Selection mode the font changes Please make sure the Text Font and the Text Editor Block Selection Font are the same: • go to General > Appearance > Colors and Fonts © AMIQ 395 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com • in the list on the right, under the Basic category you should see • Text Font • Text Editor Block Selection Font • The fonts should be the same 35.55 In Block (Column) Selection mode I see strange editng artifacts Please make sure the Text Editor Block Selection Font is a monospaced font: • go to General > Appearance > Colors and Fonts • in the list on the right, under the Basic category you should see Text Editor Block Selection Font • The font should be monospaced 35.56 How to modify the font size in the code editors? You can increase/decrease the font size in code editors using these buttons, on the main toolbar: You can can also modify the font settings from Window > Preference > General > Appearance > Colors and Fonts. For global settings (used by all editors), select Basic > Text Font and for editor specific settings, select (e , Verilog, VHDL) Language > Editor > Text Font. © AMIQ 396 Rev. 3.5.32 DVT SystemVerilog IDE © AMIQ Chapter 35. Q & A 397 www.dvteclipse.com Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.57 How to automatically checkout/ lock files from the revision control system ? Let's suppose your project is tracked by a revision control system, for example Perforce, DesignSync or Clearcase, that keeps non checked out files read-only. In this scenario, you can instruct DVT to perform some actions on any read-only file that gets modified by direct editing or by refactoring: 1. Create a new run configuration, named DVT_CHECKOUT_HOOK. 2. In the newly created run configuration, add any script or command you wish to be performed on the read-only files that get modified. The list of files is in ${selected_resources_loc} variable, by default separated by colon (:). You can use custom separators. See the examples below, supposing the list of files is: file1.e, file2.sv, file3.vhdl. • ${selected_resources_loc} would expand to file1.e:file2.sv:file3.vhdl • ${selected_resources_loc: } would expand to file1.e file2.sv file3.vhdl • ${selected_resources_loc: >> } would expand to file1.e >> file2.sv >> file3.vhdl 3. You can now use the DVT_CHECKOUT_HOOK run configuration in two ways: • simply start to modify a read-only file and it will get triggered automatically • select some files (in the Navigator) and manually launch the "DVT_CHECKOUT_HOOK" run configuration; note that you can map the run configuration to a toolbar button (see Custom Shortcut and Button for a Run Configuration) Also, you can disable the checkout confirmation by inserting the following attribute in the DVT_CHECKOUT_HOOK run configuration file: <booleanAttribute key="ro.amiq.dvt.launch.REQUIRE_CHECKOUT_CONFIRMATION" value="false"/> 35.58 How can I see if a file is readonly? To enable read-only decorators for Navigator(1), Editor(2) and Refactoring Preview(3) go to: Window > Preferences > DVT and select the Show read-only decorators checkbox. © AMIQ 398 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com 35.59 How can I open a file in DVT from the terminal? You can use the Command Line Interface like this: $> dvt_cli.sh -workspace ~/dvt_workspace openFile $(readlink -f my/file.sv) The command can be shortened by defining this alias in your ~/.cshrc: alias dvtopen 'dvt_cli.sh -workspace ~/dvt_workspace openFile `readlink -f \!*`' or by defining this function in your ~/.bashrc: dvtopen () { dvt_cli.sh -workspace ~/dvt_workspace openFile $(readlink -f $1); } Then the command gets much shorter: $> dvtopen my/file.sv 35.60 How do I change the name of the xterm opened by a DVT Generic Run Configuration? At the beginning of your script/command insert these commands: © AMIQ 399 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 35. Q & A www.dvteclipse.com echo -ne "\033]0;YOUR_WINDOW_TITLE_HERE\007" echo -ne "\033]1;YOUR_TASKBAR_TITLE_HERE\007" © AMIQ 400 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 36. What is New? #.# - major version - Includes new features, major enhancements, architectural changes, bug fixes. #.#.# - minor version - Includes bug fixes, minor enhancements. 3.5.32 (18 December 2014) Features • DVT-1243 Ability to generate getters and setters, see Generate_Getters_and_Setters Enhancements • DVT-4498 Enclose selected text when typing bracket or quote or begin/end • DVT-6856 Code Formatting: Add vertical align patterns for classes and functions Bugfixes • DVT-6580 Eclipse 4: Tool Bar Customization / Dynamic Launch Configuration Toolbar category is showing icons from every toolbar refresh • DVT-6581 Eclipse 4: Commands for Dynamic Launch Configurations are persisted after the launch configuration is deleted • DVT-6909 Wrong auto-indentation when adding new line immediately before a string • DVT-6915 Search for references should look into all compiled files regardless of their content type • DVT-6918 Refactoring should be performed into all compiled files regardless of their content type • DVT-6920 Content assist shows no proposals after end delimiter without matching block name • DVT-6921 Code Formatting: Add whitespace before/after should not break '+:' and '-:' operators 3.5.31 (5 December 2014) Bugfixes • DVT-6603 Eclipse 4: Build toolbar should resize on large build names instead of displaying a drop-down • DVT-6662 Eclipse 4: Updated ViPlugin for DVT to 2.13.1 (fixes for Eclipse 4) • DVT-6858 False DUPLICATE_NAME error on genvar use © AMIQ 401 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6859 False UNDECLARED_IDENTIFIER error on genvar use in nested for blocks • DVT-6883 ViPlugin: Fixed "invalid stream header" error and some NullPointerExceptions • DVT-6885 New DVT File Wizard doesn't allow selecting the directory in the DVT AutoLinked hierarchy • DVT-6894 New DVT File Wizard doesn't recognize paths on shared partitions • DVT-6896 DVT Editor line delimiter should be set by the "New text file delimiter" workspace and project preferences Enhancements • DVT-6895 Code Formatting: Ability to vertically align to open curly • DVT-6897 Code Formatting: Ability to place function/task declaration arguments on new line/same line • DVT-6898 Code Formatting: Ability to place class declaration parameters on new line/same line • DVT-6899 Change default state of Prepend Package Name and Group By Package buttons 3.5.30 (28 November 2014) Features • DVT-3222 Ability to create a project from template using dvt_cli.sh Enhancements • DVT-6027 Add capability to use commands to open custom hyper links created by run configuration filters • DVT-6682 Mention shown UVM types in UVM Browser documentation • DVT-6683 Add Ports Category in UVM Browser • DVT-6855 Verissimo: Add check title to HTML lint report • DVT-6860 Add Register Maps Category to UVM Browser • DVT-6873 Add +dvt_env_no_override build directive Bugfixes • DVT-6834 False UNDECLARED_IDENTIFIER when accessing interface parameters by modports • DVT-6838 False UNDECLARED_IDENTIFIER error for method access on event triggered property © AMIQ 402 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6857 False UNDECLARED_IDENTIFIER error when accessing a typedef parameter field • DVT-6862 Field Editor "Select all" button clears set print radix • DVT-6872 Build log file is not automatically refreshed if it resides inside the workspace 3.5.29 (21 November 2014) Enhancements • DVT-6832 Improved error recovery on missing semicolon • DVT-6849 Support for net declaration using non-standard packed dimension (expression instead of range) • DVT-6848 Demote to warning the non-standard IMPORT_IN_CLASS semantic indication Bugfixes • DVT-6824 Eclipse 4: NullPointerException in ContentMergeViewer $ContentMergeViewerLayout.layout (patch for Eclipse Luna 4.4.1, Eclipse Bug 348429) • DVT-6841 Content assist is very slow in some cases when more than 100k proposals • DVT-6842 No error reported on incomplete define declaration (e.g. `define followed by new line) 3.5.28 (16 November 2014) Enhancements • DVT-5743 Add expand all in current scope to code folding • DVT-6028 Match Questa errors and invoke "verror" tool to open them Bugfixes • DVT-6790 Sometimes autocomplete does not work after `macro_calls. • DVT-6751 Verissimo: HTML lint report saved state should work between different reports • DVT-6803 False UNDECLARED_IDENTIFIER semantic error in parameterized class • DVT-6804 False UNDECLARED_IDENTIFIER semantic error when class extends its param inside a package • DVT-6826 Using many Auto-Linked roots results in "Value is too long" error • DVT-6827 Field Editor adds registration macros outside of the class body • DVT-6828 Project build fails when default.build directive contains formatted numbers (e.g +define+DEFAULT=32h'FFFFFFFF) © AMIQ 403 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com 3.5.27 (7 November 2014) Enhancements • DVT-6252 Report illegal virtual static function/task • DVT-6714 Move cursor position to field area in code templates for UVM classes • DVT-6774 Code Formatting: Ability to vertically align to open parenthesis • DVT-6783 Ability to customize run configurations console title according to the output of the process • DVT-6801 Slow post full build semantic resolve configurations phase in mixed SystemVerilog/VHDL mode Bugfixes • DVT-6409 False SystemVerilog UNDECLARED_IDENTIFIER error when referring VHDL-defined types with package::qualification • DVT-6410 False SystemVerilog UNDECLARED_IDENTIFIER error when referring members of VHDL-defined records • DVT-6745 Field editor should add the registration macros at cursor position not at the end of the class • DVT-6763 Autocomplete in Windows OS might throw exceptions when triggered outside any scope • DVT-6765 Sometimes dictionary save fails at platform shutdown • DVT-6771 False DUPLICATE_NAME semantic error on generate blocks declared inside an else branch of an enclosing generate block • DVT-6778 "Conflicting handlers" log entry for each run configuration button • DVT-6779 False UNDECLARED_IDENTIFIER semantic error when parent element type is a typedef inside a parameterizable parent class • DVT-6780 Interfaces, modules, programs, primitives or checkers not always visible from a different library • DVT-6781 DVT crashes after CentOS and RHEL updates with "_cairo_operator_bounded_by_source: Assertion `NOT_REACHED' failed" (fixed in distributions) • DVT-6782 dvt.sh -eclipse_args doesn't work with -vmargs • DVT-6784 SystemVerilog build time increases exponentially with chained if else if generate blocks © AMIQ 404 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6785 UVM Field Editor throws an internal error and erroneously deletes registration macros • DVT-6788 Suppress "First launcher.execute()" messages from ClearCase plugin (patch for distro) 3.5.26 (31 October 2014) Enhancements • DVT-4964 Code Formatting: Ability to specify a list of operators that must be surrounded by space • DVT-5420 Ability to trim trailing whitespace on save (Preferences -> General -> Editors > AnyEdit Tools) • DVT-5832 Disabled incremental build should also disable views updates • DVT-5988 Show value, file and line information in Macros View • DVT-6029 Support for URL hyper-links in run configuration filters • DVT-6152 Ability to hide from macros view "ifndef guards" • DVT-6241 Ability to customize run configurations console title • DVT-6381 Support for non-standard fprint() and print() global routines • DVT-6739 Ability to visualize all `ifdef/`ifndef that may affect the environment • DVT-6741 Add $test$plusargs $value$plusargs to predefined functions • DVT-6759 Support for non-standard syntax import "DPI-C" escaped_identifier = function int function_name() • DVT-6766 Specador: Use new HTML look & feel by default • DVT-6773 Added AnyEdit plugin in all distributions and updated CLEARCASE, PERFORCE, PERL and PYTHON plugins Bugfixes • DVT-5849 False NON_EXISTING_TYPE semantic error on port declaration not cleared on incremental build • DVT-6030 Run configuration filters of type NOTE not working when ${line} is not used inside pattern • DVT-6148 Dynamic run configuration buttons should be filtered by working sets • DVT-6462 +dvt_incremental_compile_max_lines not taken into account by semantic checking © AMIQ 405 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6613 Auto-instance should not generate duplicate wires • DVT-6750 Incorrect auto-instance generated wires for signals with packed dimension • DVT-6769 False UNDECLARED_IDENTIFIER error when accessing API of a typedef-ed parameter type • DVT-6772 No prompt for rebuild when unable to restore from a dictionary saved with pre-3.5.24 3.5.25 (23 October 2014) Enhancements • DVT-5694 Trigger semantic error on duplicate constraint name • DVT-6384 Trigger semantic error on duplicate generate block name • DVT-6723 Verissimo: Add title to HTML lint report • DVT-6724 Verissimo: Double clicking a hit in HTML lint report opened in DVT's browser will open the file • DVT-6736 Verissimo: Add hits table summary to HTML lint report • DVT-6737 Verissimo: Visual and usability enhancements for HTML lint report Bugfixes • DVT-5851 Wrong autocomplete at the end of keyword • DVT-6054 Do not show modules/other global types after dot as valid proposals when the context cannot be defined • DVT-6240 Autocomplete, hyperlink and hover support for function/task named arguments • DVT-6329 False UNDECLARED_IDENTIFIER semantic error for the type_option of a coverpoint • DVT-6673 Library-global assertions are duplicated in Checks View • DVT-6727 Verissimo: HTML lint report hits table column widths are wrong after a resize • DVT-6725 Project Statistics yields all metrics zero when full build option is checked • DVT-6728 Rebuild buttons visible only on main window after multiple windows platform restart • DVT-6734 Autocomplete after a function that takes a macro call as argument hangs • DVT-6742 Verissimo: Filter out all checks with no hits when file filters are used in HTML lint report © AMIQ 406 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6744 Field Editor should allow registration of unregistered classes 3.5.24 (10 October 2014) Features • DVT-6335 Verissimo: New HTML report with advanced functionality for filtering and searching Enhancements • DVT-5635 Simplify override function with autocomplete (Java-like) • DVT-6589 Report error if target interface signal does not exist in modport declaration • DVT-6591 Record ports in clocking blocks • DVT-6647 Added new predefined project based on UVM 1.2 - UBUS • DVT-6693 Report error for mismatched modport and interface port directions • DVT-6704 Auto-complete window does not remember the width and height between invocations • DVT-6710 Specador: Added support for clocking blocks Bugfixes • DVT-5548 Setting a template as auto-insertable doesn't work • DVT-6638 Ports should be filtered from the Outline View when showing only modules • DVT-6692 False UNDECLARED_IDENTIFIER error on modport access • DVT-6697 False NON_EXISTING_TYPE_ERROR on non-standard enum declaration • DVT-6700 Waive Problem from Problems View context menu does not escape less than < greater than > and quote " characters • DVT-6719 Added XULRunner library in Linux distributions to avoid crashes when the internal browser starts on old systems 3.5.23 (2 October 2014) Deprecated OVM Field Editor key binding will be removed in the next major release • DVT-6661 Use same shortcut for OVM and UVM field editor Enhancements • DVT-1714 Field Editor - class parameters need to be added • DVT-4972 Support for tooltips/hyperlinks/autocomplete/refactor for genvars © AMIQ 407 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6590 Report error when accessing interface level signals out of modport/clocking blocks • DVT-6650 Support for non-standard cast construct "int(some_var)" • DVT-6651 Support for macro argument identifier or operator split on 2 lines (VCS mode) • DVT-6677 Content Filters for Field Editor • DVT-6681 When DVT_USER_SETTINGS or DVT_COMMON_SETTINGS point to a location inside a project no links are created in DVT-Settings project Bugfixes • DVT-61 OVM Field Editor - Unregister/Register vs. Fix • DVT-1931 References search issue for members declared in files included multiple times • DVT-2799 OVM Field Editor doesn't pop when no fields • DVT-5533 Inhibit macro expansion in signal declarations for Code Factory templates and auto-instance generated wires • DVT-5714 Field editor does not work on classes with no fields • DVT-5989 Field editor should use uvm_component_param_utils macro for parameterized classes • DVT-6382 False UNDECLARED_IDENTIFIER semantic error genblk<N> on implicit generate blocks • DVT-6405 Problematic undeclared identifier when accessing a function from parent module instance • DVT-6479 No build after CLI createProject on a project that was previously deleted • DVT-6490 Refactor genvar leaves declaration unchanged • DVT-6604 Eclipse 4: Settings management eclipse.ini merger doesn't support case sensitive arguments • DVT-6635 The Design Hierarchy View text filter is cleared after rebuilt • DVT-6641 Quoted arguments of dvt_cli.sh -<name>.build are not handled correctly • DVT-6643 Non-deterministic build config errors on large build configurations of mixedlanguage projects • DVT-6644 Wait for clipboard contents hangs (Eclipse Bug 241957 patch) • DVT-6649 False UNDECLARED_IDENTIFIER semantic error when element is from a different library © AMIQ 408 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6658 Auto-indentation very slow for imbricated levels of "begin...end" that have "begin" immediately after closing parenthesis • DVT-6569 Trigger semantic error for missing type used as default value for a parameter • DVT-6657 DVT CLI does not accept DVT as argument of -perspective option • DVT-6660 Classes are no longer visible across libraries • DVT-6663 Enclosing scope is not determined correctly when moving the cursor from outside a type • DVT-6669 Editor preferences for autocomplete not working 3.5.22 (9 September 2014) Features • DVT-6377 Ability to specify current build configuration name and content by dvt_cli.sh Enhancements • DVT-4767 Example Makefile.dvt for a predefined project • DVT-4911 Run configurations: improve error handling and visibility of project / working dir resolution • DVT-5571 Autocomplete SystemVerilog constraints in subclasses Bugfixes • DVT-5328 UVM Field Editor shouldn't translate typedefed types • DVT-6637 Wrong UNDECLARED_IDENTIFIER semantic error pkg_name::type_name is used and pkg_name declared in a different library when 3.5.21 (3 September 2014) Enhancements • DVT-6026 Ability to specify path to Custom Dialog swtxml as relative to the location of the run configuration • DVT-6387 Hyperlinks not working on instance ports when module name is specified with macro • DVT-6600 Add modport as element type option for content filters Bugfixes • DVT-4149 Don't jump to files from other projects when double-click in views • DVT-5323 Build configurations are not correctly parsed when -ncelabargs is encountered © AMIQ 409 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5622 Semantic search does not work for global tasks • DVT-5737 No autocomplete for static events after class_name:: • DVT-6357 Compile waivers don't work for problems whose description contains newlines • DVT-6601 When creating a content_filters.xml views are not refreshed • DVT-6620 Search view quick search is shown at the bottom of the view instead of the top 3.5.20 (28 August 2014) Features • DVT-5000 Add 'show usages' hyperlink entry Bugfixes • DVT-5322 Refactoring a package name results in "Unexpected error when checking for new name" • DVT-6612 Members sorting in Types/Verification Hierarchy Views is unstable • DVT-6560 Missing semantic UNDECLARED_IDENTIFIER error when accessing undeclared method on queues in parameterized classes • DVT-6566 Missing semantic UNDECLARED_IDENTIFIER error on wrong :: access in classes extending their parameters • DVT-6574 Missing semantic UNDECLARED_IDENTIFIER error when using virtual interface (e.g. cls#(virtual intf)) • DVT-6598 Wrong icons for mixed mode instances • DVT-6610 Parser stops after finding a non-printable character (e.g. 0x1A) • DVT-6611 Fix ambiguous syntax error reporting inside macro invocation • DVT-6618 Wrong UNDECLARED_IDENTIFIER errors when an ancestor of the class extends its parameter 3.5.19 (21 August 2014) Features • DVT-5932 Ability to browse module parameters • DVT-5933 Ability to browse global functions • DVT-6592 Ability to browse and search type members in Types View Enhancements © AMIQ 410 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4050 Add -perspective switch to dvt_cli.sh importProject • DVT-5418 Ability to specify prefixes that trigger autocomplete • DVT-5613 In ius.irun compatibility mode if irun is not available -uvm should fallback to DVT_UVM_HOME with warning • DVT-6051 Hierarchical search in Types View • DVT-6158 Cross-platform Quick Search clear button • DVT-6404 Hide some of the "gray" functions from Quick Hierarchy • DVT-6465 Bold Quick Search matches in UVM Browser • DVT-6587 Automatically show Types Members / Verification Hierarchy Ports and select first match when search string includes dot • DVT-6593 Parameters don't show up in outline view Bugfixes • DVT-4736 Eclipse 4: Dynamic Launch Configuration Shortcuts key bindings do not work • DVT-6110 Wrong semantic error for parameters used in bind instances • DVT-6250 Sometimes project open causes a NullPointerException • DVT-6459 New DVT File wizard throws NullPointerException when filling in file name with .build extension • DVT-6556 Wrong icon for array of interface instances in Design Hierarchy View • DVT-6506 Cross bin automatically defined types • DVT-6538 False undeclared identifier error when binding parameterized modules • DVT-6570 Specador: FileNotFoundException (Not a directory) when generating documentation using the new HTML style • DVT-6571 Parse error on "with" used in bins selection • DVT-6584 Program and checker instances appear with the module instance icon in the Outline View • DVT-6588 Content Filters do not match SV CONFIGURATION element-type • DVT-6596 Settings management engine doesn't always work on key bindings with parameters • DVT-6597 No tooltip/hyperlink and potential matches on some identifiers when using UTF-16 chars in comments © AMIQ 411 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com 3.5.18 (1 August 2014) Enhancements • DVT-5553 Error recovery not working properly when "endmodule" is missing • DVT-5715 F2 on identifier should show tooltip • DVT-6234 Custom Dialogs: DirectoryFilesListing widget should support listing directories • DVT-6508 Add code templates for UVM library • DVT-6543 Non-standard support for "static const local" declaration in class • DVT-6549 Override indication when overriding by autocomplete Bugfixes • DVT-5829 Quick Macros and Print have conflicting key bindings, changed Quick Macros to Shfit + Ctrl + M • DVT-6065 Eclipse 4: Waive Problem in Problems View context menu doesn't work • DVT-6066 Eclipse 4: SVN plugin throws an error when DVT Auto-Linked is created • DVT-6209 Fixed cause for "Job found still running after platform shutdown" message on exit • DVT-6461 Eclipse 4: No content in Problems/Tasks View when focus is on a different stacked view (patch for Eclipse Luna 4.4.0) • DVT-6482 Eclipse 4: Missing Copy Full Path action in Navigator View context menu • DVT-6513 Eclipse 4: Tool Bar Customization / DVT Build category shows multiple empty buttons • DVT-6518 Wrong comment association for anonymous enum class variables • DVT-6522 False UNDECLARED_IDENTIFIER semantic error on binded module instance • DVT-6536 False UNEXPECTED_IDENTIFIER semantic error when property with arguments used • DVT-6539 False NON_EXISTING_TYPE semantic error when queue find_index call is accessed by :: • DVT-6540 False NON_EXISTING_TYPE semantic error when array index is accessed by :: in a sum() predefined function call • DVT-6541 No hyperlink, hover and autocomplete on item when array index is accessed by :: in a sum() predefined function call • DVT-6542 Wrong auto-indentation for assume/assert/cover/restrict property statements © AMIQ 412 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6544 Incorrect reparse of an identifier followed by a macro call (without whitespace in between) • DVT-6545 Unsupported property expression of kind (exp) |-> (exp) or if (exp) else (exp) 3.5.17 (25 July 2014) Features • DVT-5560 Specador: Ability to customize the HTML look & feel when new HTML style is used • DVT-6487 Specador: Ability to inject HTML in generated documentation when new HTML style is used Enhancements • DVT-6113 Ability to "add as -y library", similar with "add as incdir" from Navigator right click menu Bugfixes • DVT-6517 Wrong number of compiled files when +dvt_cache_incdirs_content is enabled • DVT-6520 Trace Connections from Editor not working for cross language signals and ports • DVT-6523 False UNDECLARED_IDENTIFIER semantic error when accessing nested action block labels • DVT-6525 False UNDECLARED_IDENTIFIER semantic error when class extends type parameter mapped to a typedef • DVT-6526 Specador: Watermark footer missing in new HTML style 3.5.16 (8 July 2014) Features • DVT-6485 Specador: New HTML look & feel Enhancements • DVT-4775 Ability to insert single proposals automatically • DVT-5321 Enhance autocomplete & tooltip for typedefs • DVT-6279 SystemVerilog API defined under a class should appear only under that class and not under global API • DVT-6434 SystemVerilog remove covergroups, assertions, functions, tasks, variables from index page and search • DVT-6471 Added support for 'nettype' declaration © AMIQ 413 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6474 Optimized algorithm to remove unnecessary action blocks from dictionary • DVT-6492 Rebuild fails after adding a nature to a project • DVT-6498 Eclipse 4: Fixed java.lang.NoClassDefFoundError in AbstractTextEditor affecting some versions of Eclipse 4.2 • DVT-6499 NullPointerException when DVT_COMMON_SETTINGS is used and DVT_USER_SETTINGS is not set Bugfixes • DVT-5197 File not opened in the correct folder, but in DVT Auto-Linked • DVT-5550 Specador: Method argument comments are not extracted • DVT-6210 Specador: Fixed JavaDoc @link hyperlink extraction when similar links are used • DVT-6432 Specador: Refresh web browser after new documentation is generated • DVT-6473 Performance degradation on searching modules to resolve instances • DVT-6476 Verification Hierarchy view freezes the GUI for large environments • DVT-6486 Wrong index type solving when size is based on enum item • DVT-6488 Optimize the incdir file search and revisit cross platform map implementation • DVT-6504 Performance degradation when creating Auto-Linked resources • DVT-6511 Semantic timeout dialog appears when the build is started by the linter 3.5.15 (8 July 2014) Enhancements • DVT-6438 GUI freezes when computing a large verification hierarchy • DVT-6439 Verification hierarchy computation is slow for a large number of classes • DVT-6445 UVM Verification Hierarchy View hangs when showing recursive instances Bugfixes • DVT-5775 No tooltip/hyperlink inside randomize with {} • DVT-5914 Hierarchical references to static task or functions variables not working • DVT-6457 Wrong compilation error on a -> soft b • DVT-6460 Slow semantic checking/linting eventually leading to out of memory 3.5.14 (24 June 2014) © AMIQ 414 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-4411 Trace Connections of internal signals from editor • DVT-6162 UVM Browser should work with legacy OVM based environments • DVT-6298 UVM / Verification Hierarchy update is slow for large environments • DVT-6347 Add implicit declaration for assign if left value is a concatenation or assignment pattern • DVT-6367 Slow file open and right click menu in editor when environment has millions of defines • DVT-6372 Unify the task tags and comments collection with the parsing of the file • DVT-6391 Do not restore when using CLI createProject command Bugfixes • DVT-5274 Wrong potential match on the port of an undeclared module • DVT-5275 Wrong potential match on a port of a not compiled module in a -v file • DVT-5869 Linting performs an unnecessary restore operation prior to build • DVT-5968 Read-only pop-up not working for file with rw:r:r permissions when opened by other user • DVT-6001 Trace Connections from editor when only one top module candidate is available should automatically select it • DVT-6343 False semantic error on array iterator index method • DVT-6344 False UNDECLARED_IDENTIFIER error in the initialization of nested structs • DVT-6352 Parameterized macro called with empty argument does not expand • DVT-6355 False UNDECLARED_IDENTIFIER error in classes which extend their own parameter • DVT-6358 False errors in duplicate functions after project restore • DVT-6360 Wrong formatting for interface class constructs • DVT-6366 Auto-indentation issue after pure virtual/extern/DPI method prototypes • DVT-6368 Out of memory exception on second build when environment has millions of defines directives • DVT-6369 Project is restored twice on project open • DVT-6370 Project restore cannot be interrupted by cancel button © AMIQ 415 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6371 Macros view is populated after long time when environment has millions of defines directives • DVT-6376 Read-only indication not working for file with rw:r:r permissions when opened by other user • DVT-6418 Semantic errors no longer reported inside 'randomize() with {...}' block 3.5.13 (13 June 2014) Enhancements • DVT-6341 Support for `protected128 ... `endprotected128 construct • DVT-6345 Support for deprecated predefined sequence method 'ended()' Bugfixes • DVT-6312 No hyperlink, tooltip, autocomplete in foreach inside randomize with{} when type is in a different package • DVT-6324 No hyperlink, tooltip, autocomplete for port names after 1'b1 value for signal • DVT-6325 No hyperlink, tooltip, autocomplete for port names if parameter value is an expression • DVT-6331 Specador: Wrong hyperlinks when including external documentation directories • DVT-6333 Specador: Show the external documentation title under the 'Referenced Documentation' section in TOC • DVT-6337 Opening a the imported hundreds of times containing thousands of macro defines and/or undefines freezes the GUI • DVT-6338 Exception while searching in Design Hierarchy • DVT-6342 `pragma protect data_block complains about missing "=" • DVT-6348 Layers View displays wrong information when invoked on an element while the view is hidden 3.5.12 (10 June 2014) Enhancements • DVT-6275 Support for function declaration in cross body declaration (LRM 2012) Bugfixes • DVT-5469 Editing a file during build freezes the GUI • DVT-5729 Wrong semantic error for module signal in bind © AMIQ 416 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? • DVT-6023 UVM Field Editor uvm_field_array_int for static arrays should use www.dvteclipse.com uvm_field_sarray_int instead of • DVT-6150 False semantic error for field member in 'randomize with {...}' when type is in a different package • DVT-6204 Comments on items followed by `uvm_\`ovm_ on the next line are not collected • DVT-6221 False UNDECLARED_IDENTIFIER error in clocking block input/output/inout signal declarations • DVT-6239 XVM Field editor should order the registration macros • DVT-6271 False semantic UNDECLARED_IDENTIFIER error reported when the type of the accessed member declared in a parent class is of a type • DVT-6276 Content assist not working for the enumerated items of a enum type • DVT-6277 Autocomplete doesn't show parent class fields in a coverpoint • DVT-6288 Specador: FileNotFoundException when documentation is generated with diagrams in same location for multiple projects • DVT-6297 False semantic UNDECLARED_IDENTIFIER error when identifier is a member in a nested class in other package • DVT-6299 Auto-indent issue after pure virtual method prototype • DVT-6302 Infinite loop when "typedef myType myType" is encountered during semantic checks • DVT-6304 Specador: progress dialog should also include design diagrams and design diagrams with ports • DVT-6308 License checkout error not reported properly due to an exception in FlexLM • DVT-6316 Console Log Filters: missing hyperlinks for UVM instances containing "@" character • DVT-6330 False syntax error on property assertion variable assignment 3.5.11 (30 May 2014) Enhancements • DVT-5202 Specador: option to generate module diagrams with ports • DVT-6056 Open files compiled by DVT with the corresponding DVT editor (for example from Navigator) • DVT-6069 Open problems reported by DVT with the corresponding DVT editor (for example from Problems View) © AMIQ 417 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6108 Slow parse with multiple imbricated concatenation and ? : conditional operators • DVT-6159 Inconsistency: Outline/Quick Outline/Type Hierarchy/UVM Browser filters dialog should have Select/Deselect All buttons • DVT-6215 Specador: Show functions/tasks in global scope • DVT-6251 Specador: Include package comment in package summary page Bugfixes • DVT-6179 When using -uvmhome, UVM API is not filtered by content filters • DVT-6180 When using -uvmhome, Compile Order displays wrong order of files • DVT-6244 Sometimes Show Whitespace Characters throws an error • DVT-6268 Missing semantic UNDECLARED_IDENTIFIER error when hierarchical identifier inside a parameterizable class does not depend on the class parameters • DVT-6270 False semantic UNDECLARED_IDENTIFIER error on package access inside a generate • DVT-6273 When same sources are Auto-Linked multiple times go to declaration (from view/ hyperlink) asks user to chose project 3.5.10 (22 May 2014) Features • DVT-4129 HTML Documentation: by default show inherited API collapsed Enhancements • DVT-6208 Settings management engine should handle .dvt.gtkrc settings • DVT-6230 Provide an example Makefile wrapper for dvt_cli.sh in the uvm-ubus predefined project Bugfixes • DVT-5478 HTML Documentation: boolean values in dvt_export_html.xml that contain empty spaces are not recognized • DVT-6192 Auto-indent issue after a open-close group of parentheses • DVT-6207 Fixed ConcurrentModificationException preventing DVT CLI daemon to start • DVT-6219 False semantic UNDECLARED_IDENTIFIER error when referring VHDLdefined types/enums/constants in Verilog • DVT-6220 Compare Dialog is not using the editor background color © AMIQ 418 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6227 False semantic UNDECLARED_IDENTIFIER error when using explicit package::type parameter • DVT-6229 Changed Quick Search default messages 3.5.9 (12 May 2014) REMOVED • DVT-6174 Remove support for +dvt_reparse_duplicate_top_files+ build directive Enhancements • DVT-5821 Added category sort button in Coverage and Checks Views Bugfixes • DVT-6104 Search view Quick Search should be reset between searches • DVT-6105 Search view is populated slower when Quick Search is active • DVT-6151 No hyperlink/tooltip/autocomplete/refactoring class#(param)::param_ret_fun().param_api() support for • DVT-6157 Build configurations: in ius.irun compatibility mode, SPECMAN_PATH is ignored • DVT-6166 Eclipse 4: Fixed org.eclipse.swt.SWTException: Invalid thread access when running "dvt_cli.sh -newwindow" • DVT-6167 Eclipse 4: Fixed java.lang.NoSuchMethodError in AbstractTextEditor caused by a bug in DVT Patcher • DVT-6171 False semantic UNDECLARED_IDENTIFIER error when directly accessing under a generate block an instance name located within the parent design hierarchy • DVT-6173 Invoking a single External Build Configuration triggers a full rebuild with all the External Builders • DVT-6181 HTML Documentation: cannot trigger a project rebuild from the documentation wizard • DVT-6183 False semantic UNDECLARED_IDENTIFIER error in hierarchical names passing through anonymous generates 3.5.8 (30 April 2014) Features • DVT-6132 Support for C like preprocessing (#define, #if, #elif, etc.) Enhancements © AMIQ 419 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5692 Auto-indentation after brackets (curly, square and parentheses) • DVT-6147 Issue a warning at startup if incremental build (Project > Build Automatically) is disabled Bugfixes • DVT-4645 Copy/Paste doesn't always work (Eclipse Bug 368354 patch) • DVT-4657 dvt_cli.sh -newwindow opens two windows if DVT was not already running • DVT-5653 Incorrect auto-indentation after "foreach" in curly brackets • DVT-5736 Sometimes when closing a project files remain open and display an error message • DVT-5842 Added Outline View button for configuring element filters • DVT-5691 Do not auto-indent "else" to "if" in different block • DVT-6035 dvt_cli.sh openFile command issues an error if -line is not specified • DVT-6068 Restrict default content filters to */uvm_pkg.sv not *uvm_pkg.sv • DVT-6090 False semantic error for struct members from another package used in an assignment pattern • DVT-6131 False semantic UNDECLARED_IDENTIFIER class#(param)::param_ret_fun().param_api() error for • DVT-6133 Views should update when linter window is selected • DVT-6135 Duplicate lint configurations when starting with dvt_sv_lint_gui.sh • DVT-6136 Race condition prevents the linter to start when dvt_sv_lint_gui.sh is used • DVT-6138 Semantic timeout dialog always shows at incremental build when +dvt_file_compile_timeout is set to 0 (disable) • DVT-6143 Linter default preference files prefix changed from "custom_lint" to "verissimo" • DVT-6144 Linter not-matched waivers disable all checks when used with path or message filters • DVT-6145 Reapplying linter checks after removing a waiver that matches (and disables) a check doesn't enable the check back 3.5.7 (22 April 2014) REMOVED • DVT-6121 Removed deprecated scripts run_gui_mode.sh and run_batch_mode.sh Enhancements © AMIQ 420 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4747 Filter out API defined by UVM macros or inherited API in class diagrams when Content Filters are enabled • DVT-5002 Ability to show only selected parents and children in class diagrams • DVT-6036 Build config: incorrect number of expected arguments for -no_error directives • DVT-6099 Build config: warn of unknown +dvt_enable_unknown_directive_warnings +dvt directives regardless of • DVT-6112 Add empty package code template • DVT-6122 Ability to use $DVT_PROJECT_LOC environment variable in build config and external tools Bugfixes • DVT-5157 External builder markers disappear when paths in default.build are target files of symlinks from project • DVT-5897 Project restore might run out of memory on a dictionary built with same max memory • DVT-6012 Views should not be updated when they are not visible • DVT-6077 Wrong jump to file from external builder console error when the path is relative • DVT-6096 False unexpected end of file syntax error in ml_uvm • DVT-6097 Dynamic Launch Configuration Shortcuts should not be visible if they refer to closed projects • DVT-6044 False semantic UNDECLARED_IDENTIFIER error when using imported modport task • DVT-6100 Unexpected syntax error on typed coverpoint • DVT-6106 False semantic UNDECLARED_IDENTIFIER errors when identifier is also a struct member • DVT-6109 Pre-restore dictionary size too big due to Java serialization inner class issue 3.5.6 (15 April 2014) Enhancements • DVT-5771 Ability to copy hierarchy path in Verification Hierarchy View • DVT-5831 Ability to Show Type Hierarchy when inside a class • DVT-5888 Hierarchical search in Compile Order View © AMIQ 421 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5974 Auto-link files even if compilation skips them by +dvt_skip_compile • DVT-5999 Auto-link files even if compilation times out • DVT-6006 Add basic support for 'vunit' PSL construct • DVT-6013 Non-standard "automatic" lifetime for class constructor prototype • DVT-6018 Allow various operations like jump to definition or show hierarchy for the "after cursor" identifier • DVT-6016 Incremental compilation should not be performed for a build config file opened with a SystemVerilog editor (for example when using -f my_list_of_files.sv) • DVT-6081 +dvt_file_substitute should work DVT_CROSSPLATFORM_MAP is applied to them for paths before Bugfixes • DVT-3877 Last external builders marker takes over previous markers on same file/line • DVT-4796 Errors reported by external builder incremental build are not displayed in Problems View • DVT-5669 Bind module_name should add instances to all module_name instances • DVT-5705 Whitespace characters at the end of a line and after a code statement, should be ignored in auto-indentation • DVT-5766 Interface instances bound to modules are not recognized • DVT-5790 JavaDoc comments autocomplete should not insert the "javadoc_function" template for a function defined inside a macro • DVT-5913 False semantic UNDECLARED_IDENTIFIER errors when accessing members of instances introduced using 'bind' • DVT-6000 Sometimes hyperlink not working after a certain line • DVT-6005 Compile Order view in "Show only files with errors" mode should refresh after reapplying compile waivers • DVT-6008 Wrong semantic error on extern function implementation return type parameter • DVT-6021 Views are not updated across multiple Workbench Windows when building a project • DVT-6024 Renaming the type of a field having same name as the type fails (e.g. " my_class my_class;") • DVT-6047 External Tools: "Note" filters should use the same color © AMIQ 422 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-6052 Using parens as vertical align tokens doesn't work for port connections • DVT-6070 False semantic UNDECLARED_IDENTIFIER error when accessing labels of conditional statements • DVT-6071 False semantic UNDECLARED_IDENTIFIER error when accessing members of labeled always blocks • DVT-6072 Wrong undeclared identifier for queue.pop_front().field • DVT-6073 Hyperlink not working when directly accessing an element located within the parent design hierarchy • DVT-6079 Wrong undeclared identifier error in task when default_nettype is not none • DVT-6080 Undeclared identifier not signaled on direct access of variable declared in enclosing module • DVT-6089 Function/task autocomplete missing a whitespace before name • DVT-6091 Subsequent module ports have wrong implicit type • DVT-6095 Sometimes when opening symlinked files they get recompiled 3.5.5 (1 April 2014) Enhancements • DVT-5666 Content Filters for Design Hierarchy view • DVT-5943 +dvt_file_compile_timeout pop-up dialog should specify the filename • DVT-5945 Add "Prepend Package Name" button to the Verification Hierarchy View • DVT-5950 Support for 'let' construct • DVT-5952 Support for non-standard string API like match(), prematch(), postmatch(), thismatch(), backref() • DVT-5967 Ability to control "Disable code folding if file exceeds ### lines" Bugfixes • DVT-5938 Specific DVT project selection dialogs must show only DVT projects • DVT-5946 False semantic error when using virtual instances defined in other libraries • DVT-5947 False semantic action_block_name" syntax UNDECLARED_IDENTIFIER when using "disable • DVT-5948 Wrong handling of string defines in default build e.g +define+NAME=\"literal \" leading to unexpected semantic errors © AMIQ 423 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5949 False semantic UNDECLARED_IDENTIFIER semantic error when ports of a module are mapped to an expression • DVT-5951 HTML Documentation: do not remove the enclosing "*" characters in comments if they are not followed/preceded by an empty character • DVT-5958 Wrong syntax error on "coverpoint"... "bins"... "with" construct • DVT-5961 Adding a DVT nature to a project should create the .dvt sub-directory if it does not exist • DVT-5962 Strange behavior of dvt_cli.sh when using "-newwindow -workingset": no console, workingset visible on focus, old window updates • DVT-5964 False UNDECLARED_IDENTIFIER when directly accessing an instance name located within the parent design hierarchy • DVT-5965 HTML Documentation: comment formatting is not applied on the module description • DVT-5975 Missing semantic UNDECLARED_IDENTIFIER error when accessing members of actual class parameters • DVT-5976 Wrong NON_EXISTING_TYPE class_typedef::sub_class/sub_typedef in variable declaration • DVT-5979 False error for multiple import statements before the port declaration of a module • DVT-5980 Console Log Filters: missing hyperlinks for relative paths starting with "../../" • DVT-5981 Wrong default template when creating a new file with explicitly specified extension in a mixed language project • DVT-5982 Do not notify views when incremental compilation is not performed (for example because of max number of lines) • DVT-5984 Scanning -y and -v for undeclared modules should ignore only the modules/ interfaces/primitives/etc. which are not used by the design • DVT-5986 Missing semantic UNDECLARED_IDENTIFIER error when classes are extending parameterizable classes 3.5.4 (21 March 2014) Enhancements • DVT-5887 Search View Quick Search should bold the matched parts of branches like in all other views • DVT-5923 Support for non-standard multidimensional array select in 'foreach' loop using expression © AMIQ 424 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5927 Scanning -y files should look only for undeclared modules in '+dvt_init +vcs.vlogan' compatibility mode • DVT-5929 Support for non-standard "endfunction class_scope::function_name" syntax • DVT-5930 Missing read-only notification when formatting a read-only or unchecked out file Bugfixes • DVT-3653 Undeclared variable identifiers used in functions are not being caught • DVT-3655 Assignment referencing undefined identifier not reported as error • DVT-3657 Assignments to undefined members of a structure are not caught • DVT-5911 Wrong handling of a macro with default parameters • DVT-5912 False semantic NON_EXISTING_TYPE errors when associative array packed dimension contains 'signed/unsigned' • DVT-5915 False semantic NON_EXISTING_TYPE interface.modport modport_reference error when declaring an • DVT-5917 False semantic UNDECLARED_IDENTIFIER error when accessing variables from labelled action blocks • DVT-5918 Infinite loop sometime when BadLocationException is thrown in tooltip parser • DVT-5919 False semantic UNDECLARED_IDENTIFIER error '`macro_name' when macro is not defined • DVT-5921 False semantic UNDECLARED_IDENTIFIER error when array select is a conditional expression • DVT-5922 ClassCastException in dictionary due to same hash on some elements • DVT-5925 Default content of a New > DVT Content Filters XML may filter out all tasks in windows • DVT-5926 VHDL entities placed in different libraries are not visible from SV top module • DVT-5928 Wrong vertical align by parenthesis close, bracket close or curly close 3.5.3 (14 March 2014) Enhancements • DVT-5892 Support for non-standard select of bin identifier • DVT-5900 Support for non-standard rand_mode call on fields with missing 'rand/randc' qualifier Bugfixes © AMIQ 425 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5816 Although only fields should be visible in Type Hierarchy Show All Predefined Members also shows functions • DVT-5843 Content filtered indication for Type Hierarchy should be right above the members panel • DVT-5872 False semantic UNDECLARED_IDENTIFIER errors when accessing fields from a generic interface port • DVT-5890 Semantic error when unpacked dimensions contain brackets • DVT-5893 False semantic error on sized arrays of associative arrays, when size is a localparam • DVT-5894 Quick Hierarchical Search in Coverage and Checks Views does not match any element if the filter starts with "." or contains a "!" character • DVT-5896 Trace Connections View search for port does not bold the matched ports • DVT-5899 Hyperlink not working on included files defined through a macro • DVT-5901 False semantic UNDECLARED_IDENTIFIER errors when using foreach 'item' access • DVT-5902 Wrong file and line number for errors reported in files included using macro • DVT-5903 Content Filters: Errors and tasks in symbolic linked files are not filtered • DVT-5905 Content filters do not apply for problems reported on files outside project • DVT-5907 SystemVerilog Verification Hierarchy does not show TLM1 ports 3.5.2 (11 March 2014) Bugfixes • DVT-5855 False semantic UNDECLARED_IDENTIFIER error for hierarchical named block access • DVT-5857 False semantic UNDECLARED_IDENTIFIER after list select containing package::value access • DVT-5868 False semantic UNDECLARED_IDENTIFIER errors signaled when accessing parameters from an undeclared module or interface • DVT-5877 HTML Documentation: filter out duplicate inline comments for port declarations • DVT-5885 False semantic UNDECLARED_IDENTIFIER errors when package::value used as associated array key type • DVT-5886 Quick Search does not perform prefix matching on CamelCaseStrings © AMIQ 426 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com 3.5.1 (7 March 2014) Enhancements • DVT-5788 Copy full path of multiple resources • DVT-5818 Content Filters: ability to filter Search View by element text Bugfixes • DVT-5700 HTML Documentation Generator should not report progress for each diagram • DVT-5795 HTML Documentation Wizard does not refresh all the settings when changing the project • DVT-5803 Support for non-standard attribute_instance • DVT-5804 Some formatter preferences (like Vertical align > Module port declarations) are not saved under Windows OS • DVT-5805 Wrong semantic error after 'find_index' when item type is a typedef • DVT-5808 Performance improvements for Content Filters • DVT-5809 Performance improvements for Checks and Coverage Views • DVT-5810 Outline should not reveal the first matched element when new content is added • DVT-5811 Internal builder console is cleared when saving a build configuration file • DVT-5814 Struct members are not visible from assignment patterns inside a class • DVT-5815 Changed Code Factory shortcut conflicting with Copy Full Path shortcut from Shift+Alt+P to Shift+Alt+K • DVT-5822 False UNDECLARED_IDENTIFIER error when identifier is member of a struct • DVT-5823 Content Filters: Some include-children top file patterns wrongly match all files • DVT-5824 Fixed incompatibilities with Eclipse 3.6 • DVT-5826 Fixed dvt.sh issues on MacOS 3.5 (27 February 2014) HIGHLIGHTS • Enhanced Semantic Checks: check that each identifier is properly declared and used • Improved UVM Support: • UVM Browser is the entry point for exploring all the classes of an UVM-based verification environment © AMIQ 427 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • The Verification Hierarchy View presents the UVM object instance tree • Ability to locate UVM factory related constructs that may influence the testbench behavior using UVM Factory Queries • Out-of-the-box Predefined Content Filters to hide the UVM library internals like tasks, problems and API • Ability to explore the checking aspect of a verification environment using the Checks View • Ability to explore the coverage aspect of a verification environment using the Coverage View • Trace Connections usability improvements, enhancements and bug fixes. • Ability to use Content Filters in order to eliminate unnecessary information overload. • Redesigned the tool configuration and preferences sharing capabilities. See Settings Management • Redesigned the code formatting engine. See Code Formatting • Completely unified the DVT Perspective across all languages. • Quick Search available in most views • Redesigned icons (see Icons and Decorations), tool-bars and menus. • Renamed the Hierarchy View to Type Hierarchy View • Renamed the Instance Tree View to Design Hierarchy View REMOVED • DVT-4293 Remove all incdir and define variables for External Tools Integration ${dvt_current_build_file} should be used instead • DVT-5765 Removed deprecated scripts dvt_trap.sh, dvt_xterm.sh, license_utils.sh Features • DVT-650 & DVT-1021 & DVT-2451 & DVT-2430 Ability to control preferences for site, team, user, project levels • DVT-1180 Link Back to Console from External Builder Marker • DVT-1654 Quick Macros View for SystemVerilog • DVT-2382 Filter out tasks from imported OVM or UVM libraries • DVT-2943 Ability to use waivers for build configuration problems • DVT-3637 Format option to align to first letter of signal © AMIQ 428 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4017 Unify Type Hierarchy View • DVT-4049 Auto-Link files included by default.build • DVT-4337 Ability to hide UVM/Custom library content from Hierarchy, Types, Tasks, Macros ... Views • DVT-4390 Bad indentation for consecutive if (...) `ovm_info(...) statements • DVT-4412 & DVT-5112 Add ports view to Trace Connections View • DVT-4706 Added new Verification Hierarchy view. See Verification Hierarchy View • DVT-5111 Add filter to Trace Connections View tree • DVT-5128 Unify Views context menu actions: Show References, Layers, Hierarchy, Instance Tree, Diagrams • DVT-5243 Unify Macros & Quick Macros Views • DVT-5264 Unify Coverage View • DVT-5265 Unify Checks View • DVT-5277 Ability to disable format for a marked region of code • DVT-5302 Coverage View for SystemVerilog • DVT-5368 Unify Layers View • DVT-5388 Extended support for configurations and libraries • DVT-5610 Unify Trace Connections View • DVT-5763 Changed Instance Tree view to Design Hierarchy View. See Design Hierarchy View Enhancements • DVT-532 Ability to easily share code templates at site level • DVT-4040 Unify icons across languages • DVT-4408 CamelCase support for quick views and views text filters • DVT-4440 Undeclared signal semantic error is not issued under always_comb construct • DVT-4482 Semantic check for unknown package reference • DVT-4483 Semantic check for class members associated type • DVT-4795 Predefined project mx_1 does not compile using Questa Simulator © AMIQ 429 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5025 Trace Connections toolbar icons are not intuitive • DVT-5068 Show matched/total number of instances in Instance Tree • DVT-5084 New icon for interface ports • DVT-5155 Ability to control memory using dvt.sh arguments • DVT-5268 Element count in top label of views should show filtered/total info • DVT-5330 Mark the current trace path in the Trace Connections View tree • DVT-5331 Show port/signal icons in the Trace Connections View menus and ports view • DVT-5347 Align HTML Documentation with Coverage / Checks Views • DVT-5387 Undeclared module warning is still reported even after resolving the module using the configuration • DVT-5396 Minimize number of disk accesses when writing to dvt_build.log • DVT-5495 Signal with a different icon undeclared modules in instance tree • DVT-5618 Ability to control compilation timeout via build configuration directives: +dvt_file_compile_timeout and +dvt_incremental_compile_timeout • DVT-5764 Updated JRE in distribution to version 1.7.0u4 Bugfixes • DVT-3811 Formatting issue when ';' is missing at the end of a statement • DVT-3942 Formatter bug when with double bracket closing on the last line of block • DVT-4559 When the Instance Tree gets empty after an incremental build the "work" library is shown • DVT-4582 Formatting issue after constraint block • DVT-4583 Formatting issue after multiline comment block • DVT-4614 Cursor jumps on another line after auto-format when using spaces instead of tabs • DVT-4669 Place each parameter on a new line doesn't work properly • DVT-4970 Source Format: incorrect indent after a "wait fork" statement • DVT-5099 SV Formatter internal error • DVT-5101 SV Formatter preference "compact whitespace groups" does not always work • DVT-5106 Instance Tree and Trace Connections views memory leak © AMIQ 430 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5210 Types View should reset after a project is cleaned • DVT-5239 Wrong formatting for imbricated begin-end blocks • DVT-5351 References, hyperlink, tooltip not working on wire in default clocking construct • DVT-5342 Format foreach $display doesn't indent properly • DVT-5352 Checker instantiation is considered a module instantiation • DVT-5380 Invoking Trace Connections in Editor triggers an error when Instance Tree is filtered • DVT-5454 Formatter indent UVM/OVM field registrations • DVT-5448 When the platform starts and there is no resource selected, the current project is not in sync with the highlighted project in Navigator • DVT-5485 & DVT-5554 Instance Tree loses selection when the editor is changed or when Navigator View is selected • DVT-5588 Format broken for "else if" chains • DVT-5638 Show enclosing scope in Quick Layers View • DVT-5650 Wrong formatting of "repeat" loops without begin/end • DVT-5722 Instance Tree shows the first element when it should be empty • DVT-5723 Show Instance Tree is not working on a VHDL entity when the top is Verilog module • DVT-5769 Assertion flagged as undeclared identifier • DVT-5770 Enumerated type is not recognized in function declaration 3.4.28 (24 February 2014) Enhancements • DVT-3828 Perform full semantic checks for types defined in current file on incremental build • DVT-4411 Trace Connections from Editor of internal signals, not only ports Bugfixes • DVT-5597 Hierarchical references in coverpoint only show wires, not module instances • DVT-5724 Do not treat as case-insensitive gcc-like build config directives in ius.irun compatibility mode • DVT-5730 Sequence arguments are not resolved except for the first and the last © AMIQ 431 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5738 Autoinstance with "Preserve port order" does not declare signals • DVT-5740 External Tools custom filter does not work if the pattern text ends with space/ tab/new line char • DVT-5742 External Tools can't read from an external_builders.xml file that contains patterns with the same id 3.4.27 (29 January 2014) Enhancements • DVT-5704 Allow //{{ and //}} symbols as user defined code folding region • DVT-5687 Update DVT_UVM_HOME to point to latest uvm_1.1d Bugfixes • DVT-5696 Wrong tooltip/hyperlink on some fields followed by a "randomize with" call • DVT-5726 Preprocessing issue when using `timescale followed by a macro call under `if [ n ] def ... `endif 3.4.26 (8 January 2014) Bugfixes • DVT-5676 Commas in multiline comments are not ignored for macro arguments • DVT-5677 Macro parameters are not recognized if they are not on the same line with the macro call • DVT-5679 NullPointerException when full semantic checking is enabled 3.4.25 (18 December 2013) Enhancements • DVT-5641 Non standard support for misplaced attribute instance specification when instantiating a module • DVT-5663 Support for non-standard global deferred immediate assertion item Bugfixes • DVT-3661 Duplicate fields, modules, variables, etc. should be reported as warnings instead of errors • DVT-5619 Expand all levels for large macro stacks never finishes • DVT-5658 Content assist stack overflow when parent class is declared inside child class © AMIQ 432 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5659 HTML Documentation: generating documentation throws an error when the option "Exclude files outside project" is set • DVT-5661 <anonymous_enum>.name() is not recognized as call to a predefined function under Windows OS • DVT-5662 False IMPLICIT_PORT_CONNECTION errors for binds inside a module • DVT-5664 Inserting text in block selection mode skips characters in some environments, fixed for Eclipse Platform 3.8.1 and DVT distros 3.4.24 (2 December 2013) Enhancements • DVT-5615 Macro definition optional '\' to continue on next line when inside a multiline comment • DVT-5616 Open non-DVT perspectives when creating project with dvt_cli.sh • DVT-5629 Trim whitespace characters after new line in auto-indentation Bugfixes • DVT-5494 Incorrect created wire in Code Factory testbench for enum type • DVT-5620 Very long parse time for thousands of nested concatenations • DVT-5623 Quick Hierarchy does not show implementations for tasks on children classes • DVT-5632 Instance tree should not be updated on every resource selection 3.4.23 (22 November 2013) Enhancements • DVT-4906 Automatically continue comment on new line when editing inside a block comment • DVT-5481 Show the parameter descriptions instead of the parameter names in Add From Project Template dialog • DVT-5596 Added support for non-standard $setup syntactic issue when using min max type expression as timing check limit • DVT-5601 Non-standard support for packed dimension instead of constant range in typedef enum declaration • DVT-5603 Non-standard support for missing modport port [ s ] declaration (e.g. "modport mp_name();") • DVT-5604 False error reported in default.build for -licwait directive © AMIQ 433 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5609 Support for multiline preprocessing directives Bugfixes • DVT-5556 Javadoc comments (/**...) should not insert empty lines for empty tags • DVT-5600 Auto-indentation stuck when trying to match unrecognized group • DVT-5602 False syntax error for missing arguments on constructor prototype (e.g. "extern function new;") • DVT-5608 Macro invocation reports error when parameters are not on the same line with the macro name • DVT-5607 Long-running background activity after Replace All with many occurrences 3.4.22 (15 November 2013) Bugfixes • DVT-5492 Don't include localparams in Code Factory created testbenches • DVT-5575 Inside single-line comment '\r' should not be considered a newline • DVT-5579 "Resource is inaccessible" error in DVT Auto-Linked when updating change sets for SVN • DVT-5580 Wrong NOF_PORT_CONNECTIONS error for instances of modules with duplicated ports • DVT-5581 `default_nettype is not reset between invocations 3.4.21 (14 November 2013) Enhancements • DVT-5566 Added dvt_cli.sh -p4 flag for sharing project with Perforce • DVT-5573 Increase the maximum recurrence limit for a macro using itself as argument Bugfixes • DVT-5574 Internal builder console hyperlinks don't work for locale-specific number format (like 1,234) 3.4.20 (8 November 2013) Enhancements • DVT-5530 dvt_cli.sh -silent flag should shut down all INFO & WARNING messages Bugfixes © AMIQ 434 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5471 External Tools: avoid error/warning/note color nuances for automatic smart log colors • DVT-5531 In ius.irun compatibility mode -assert directive should take no args • DVT-5559 After platform startup, text selection in a DVT editor triggers restore from dictionary for all projects 3.4.19 (1 November 2013) Bugfixes • DVT-5484 Module diagrams sometimes throw NullPointerException • DVT-5489 '$root' variable reported as unknown identifier when performing full semantic checks 3.4.18 (30 October 2013) Enhancements • DVT-4651 Show package information in UML class diagrams Bugfixes • DVT-5482 Wrong syntax error when whitespace missing between decimal formatted number and conditional operator • DVT-5483 Stack overflow exception thrown when solving loop variables 3.4.17 (29 October 2013) Enhancements • DVT-3895 & DVT-5439 Auto-indent after if statement without "begin...end" block • DVT-3931 Auto-indent after "`ovm_*_utils_begin" and "`uvm_*utils_begin" • DVT-5431 Improved auto-indentation for blocks • DVT-5468 Build Progress indication with invocation and top file granularity Bugfixes • DVT-1717 No auto-indentation after "function void name_funct();" • DVT-5225 Module auto-instance code is not indented correctly • DVT-5437 Change Extended help dialog title from "DVT Generic - Extended error ID info" to "Error ID info" • DVT-5438 New File Wizard stuck when changing nature and filtering template © AMIQ 435 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5470 "Create Testbench" not working for values of module parameters that start with $ 3.4.16 (11 October 2013) Feature • DVT-3755 Ability to "copy" module and "paste" as instance, signals or testbench. See Code Factory Enhancements • DVT-5455 Added enum ranges tooltip, content assist, HTML documentation and semantic checking • DVT-5465 Add from Project Template scans for default parameter values in both source and target template.config Bugfixes • DVT-5459 Multiple selects issue when performing semantic checking • DVT-5460 Semantic issue when determining 'foreach' array index type on incremental compilation • DVT-5461 Platform not closing sometime due to save dictionary pop-up (pop-up cannot be dismissed) • DVT-5466 Project Template Wizards don't work with parametrized directory names 3.4.15 (4 October 2013) Enhancements • DVT-5428 Non-standard support for missing semicolon after the property statement • DVT-5446 Save dictionary in compressed format Bugfixes • DVT-4664 Restore opened files when running dvt_cli.sh createProject -force • DVT-5361 Set active build configuration is not consistent across multiple Eclipse Workbench Windows • DVT-5426 The "please wait..." info box sometimes persists after successfully generating diagrams • DVT-5432 Macro expansion for macro call followed by `undef doesn't replace parameters • DVT-5449 Add From Template: add option to select a predefined project as a source directory © AMIQ 436 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5450 New Project from Template and Add from Template corrupts the binary files in the template project 3.4.14 (25 September 2013) Deprecated Support for deprecated build configuration files will be removed in the next major DVT release (.dvt/.vlog_defines, .dvt/.vlog_top_files, .dvt/.vlog_ignore_files, .dvt/.vlog_vmm_project, .dvt/.vlog_uvm_pr Enhancements • DVT-4273 & DVT-5410 Added dot in Windows distros Bugfixes • DVT-5166 Macro references don't include `ifdefs • DVT-5415 Duplicated key binding Ctrl+Y for "Redo" in Windows 3.4.13 (20 September 2013) Enhancements • DVT-1180 Link Back to Console from External Builder Marker • DVT-5096 Ability to include compile waivers • DVT-5165 Add "read only" file indication in Navigator View, Editors and Refactoring Preview • DVT-5314 Match brackets to the left and right of the cursor • DVT-5344 Clean up +defines from Predefined Projects build configuration files • DVT-5375 Incremental build causing editor freeze on big environments (possible cause disk access to write dictionary) • DVT-5378 Editor setting for changing the color of the matched bracket highlight • DVT-5390 Updated ViPlugin for DVT to 2.11.0 • DVT-5392 Corresponding matching bracket highlight when emulating vi • DVT-5393 Added support for non standard construct 'foreach (a.b [ c.get() ][ index ])' • DVT-5396 Minimize number of disk accesses when writing to dvt_build.log Bugfixes • DVT-4107 & DVT-4630 Allow cyclic includes with ifndef guards (false cyclic include error) • DVT-4631 False cyclic define error © AMIQ 437 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4654 ViPlugin state not persisted between sessions • DVT-5316 Some UVM Code Templates contain compile errors • DVT-5375 Incremental build causing editor freeze on big environments (possible cause disk access to write dictionary) • DVT-5384 User interface is not responsive while generating diagrams • DVT-5385 Configuration clause instance using liblist is not searching the correct libraries • DVT-5386 Explicit import directive "import PACKAGE::TYPE" does not search for the PACKAGE name in the configuration default liblist • DVT-5407 Ability to cancel diagram generation 3.4.12 (11 September 2013) Enhancements • DVT-5147 Disable auto-complete triggering (beep) when typing a '.' inside comments Bugfixes • DVT-5358 Some project template variable names have extra underscores 3.4.11 (9 September 2013) Enhancements • DVT-3091 Show project name in console title for Run Configurations and External Builders • DVT-4558 New ${dvt_cli} run configuration variable • DVT-5087 Ability to query the running status of DVT • DVT-5223 Ability to query the version of running DVT • DVT-5315 Ability to customize nchelp tool name/path to show extended help in console • DVT-5359 Support for SystemVerilog 2012 checker syntax Bugfixes • DVT-4657 dvt_cli.sh -newwindow opens two windows if DVT was not already running • DVT-4757 & DVT-4995 When tracing inout ports no target icon decorations are shown in the Trace Connections View • DVT-4778 When creating/importing a project via dvt_cli.sh, auto-select "Window Working Set" in Open Resource dialog • DVT-5354 Syntax highlighter broken for multiline string ending with newline © AMIQ 438 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5355 Invocation using -y or -v must search for the undeclared elements from the current invocation library only • DVT-5356 Instance tree is not populated after project restore • DVT-5360 Fixed configuration instance and default liblist directives 3.4.10 (26 August 2013) Bugfixes • DVT-4690 dvt.sh/dvt_cli.sh should issue an error if provided a non-existing eclipse.ini • DVT-5172 A syntax error in covergroup breaks the error recovery for subsequent tasks/ functions • DVT-5241 Miss-leading syntax error message generated by the parser when syntactic predicates are involved • DVT-5313 Rebuild buttons are only visible in the first Eclipse Workbench Window • DVT-5333 Trace Connections View memory not cleaned properly between trace port operations • DVT-5338 Switching a project doesn't update the Instance Tree View when no top module is specified • DVT-5340 Update Clearcase plugin to version 2.2.34 to fix some small issues • DVT-5341 Change distro name form DVT_CUSTOM_KIT to DVT_KIT 3.4.9 (14 August 2013) Features • DVT-5264 Unify Coverage View • DVT-5302 Coverage View for SystemVerilog Enhancements • DVT-5306 Hide "Project" sub-menu for non DVT project's context menu • DVT-5307 Hide "Validate" and "Format Source" menu items added by XML plugins on non XML files Bugfixes • DVT-5308 Cancel does not work for hyperlink file selection dialog • DVT-5311 Open declaration hyperlink no longer working correctly (flickering) 3.4.8 (12 August 2013) © AMIQ 439 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-5120 Added support for -eclipse_args for dvt_cli.sh • DVT-5297 Add External Tools filters for SpyGlass logs Bugfixes • DVT-5036 Types/Compile Order Views should refresh when opening a project • DVT-5244 Compare with > Other Resource ... from editor does not work • DVT-5295 Expand all levels for uvm_field_int macro does not work • DVT-5294 Port connection hyperlinks not working for module instantiations with several hundred port connections • DVT-5296 Sometimes the external tools filter variable '${file}' does not match correctly • DVT-5300 Multi-line macro calls are not correctly expanded 3.4.7 (5 August 2013) Features • DVT-1654 Quick Macros View for SystemVerilog • DVT-5243 Unify Macros & Quick Macros Views Enhancements • DVT-5279 Update $DVT_UVM_HOME to uvm-1.1c • DVT-5208 Slow hyperlink to module definitions in large designs Bugfixes • DVT-4749 Run configurations session wrapper doens't check for all necessary binaries • DVT-4787 Run configurations default command/script should not use csh/tcsh with -i flag • DVT-4788 Run configurations generated script doesn't run the last when using csh/tcsh • DVT-5266 External builders persistence file defaults to the deprecated .dvt/.dvt_builders instead of external_builders.xml • DVT-5269 External Build button should invoke all external builders instead of the last ran builder • DVT-5280 Code folding intensive computation when multiple opening/closing keywords are placed on the same line • DVT-5281 Code folding doesn't work for property ... endproperty © AMIQ 440 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5284 Disabled EMACS+ plugin auto activation in distros to prevent clipboard problems • DVT-5286 Adding linting/compliance code waiver from hit results in an "Index out of bounds" exception • DVT-5287 Adding linting/compliance code waiver from hit should check if file is writable or invoke team providers for checkout • DVT-5289 Wrong compilation issues reported due to non-standard module parameter #PARAM 3.4.6 (26 July 2013) Enhancements • DVT-4896 Added KIT distro for Linux and MacOS. See dvt_kit_installer.sh • DVT-5126 Show a change indication when collapsing a modified macro/macro expansion • DVT-5256 Added support for configuration (instance clause, cell clause, default liblist clause and design clause) Bugfixes • DVT-4997 Auto-instance a VHDL entity in Verilog using content assist • DVT-5234 HTML Documentation: spacing and tabs indentation problems for NaturalDocs formatting • DVT-5246 Compile Order View: collapse all does not work • DVT-5249 Error expanding a macro when parameters are not provided • DVT-5254 Collapse macro expansion by editor marker right click does not work • DVT-5257 Wrong syntactic error reported when edge description contains 0x, 0z, 1x, 1z 3.4.5 (22 July 2013) Enhancements • DVT-4509 Build configurations: +dvt_auto_link_root (without trailing +) issues "unknown directive" instead of "badly specified directive" • DVT-4820 Build configurations: allow usage of +dvt_auto_link_root only in first invocation • DVT-4960 Survive duplicate directives like "-liblist -liblist arg" • DVT-5009 View filters should cancel an ongoing search operation when filter text is changed and trigger a new search (Instance Tree/Types/Compile Order) • DVT-5024 Redesigned the select instance dialog for Trace Connections from Editor © AMIQ 441 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5080 Ability to redraw diagrams on demand instead of auto-update • DVT-5199 Use a bidirectional edge when indirectly connecting incompatible ports Bugfixes • DVT-4663 dvt_cli.sh exit code should reflect the operation result • DVT-5203 Trace Connections View is cleaned after building any project • DVT-5205 Semantic error when defining a function with the same name as a task • DVT-5211 Set the correct window size for module diagram's legend • DVT-5215 DVT views flicker after building projects that shouldn't affect them • DVT-5222 Eclipse Juno - "Cannot get the parent identifier from an undefined context..." exception • DVT-5226 HTML Documentation: wrong hyperlinks on default class parameters • DVT-5228 A non-matched quote (") triggers non-standard warning on every line of code • DVT-5229 Cross language hyperlinks open the file in wrong editor • DVT-5233 Code Templates View: no error message when creating a template with unescaped "$" characters • DVT-5236 JavaDoc code templates auto-complete does not work if there is a whitespace character after "/**" 3.4.4 (9 July 2013) REMOVED • DVT-5188 Removed support for DVT Auto-Linked language specific subfolders ("SystemVerilog", "e-Language" and "VHDL") Enhancements • DVT-4313 Inform that extended checks markers are obsolete on incremental build • DVT-4748 Use cache when clicking through diagrams • DVT-4754 Add an indication for array of instances in module flow diagrams • DVT-4768 F3 is not working in the Build Configuration editor • DVT-4870 Trigger an error when using DVT-defined Environment Variables for +dvt_auto_linked_root • DVT-4934 Auto-indentation in blocks delimited by curly brackets © AMIQ 442 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5114 Module diagram hyperlinks not working when navigating using breadcrumb • DVT-5123 Update the legend of module flows diagrams with hyperlink hints • DVT-5136 Update default SystemVerilog language Syntax to SystemVerilog 2012 • DVT-5138 Wrong editor tab tooltip for DVT Auto-Linked files starting with e-Language/ SystemVerilog/VHDL prefixes • DVT-5158 Code folding and double click selection on `elsif • DVT-5177 Added support for non standard construct 'interface::self()' Bugfixes • DVT-4033 Report an Issue: "save as zip" not closing the wizard • DVT-4745 Two spaces in generated wire declaration when doing a module auto-instance • DVT-4802 Black box module should inherit the ports direction using the enclosing module or other instantiated elements • DVT-5078 Gate primitives not shown in instance tree • DVT-5092 Cancel does not work while generating HTML Documentation with diagrams • DVT-5116 Formatter hangs with certain vertical alignment token sets • DVT-5117 Wrong hyperlink to declaration or assignment when the name of the wire is an escaped identifier that contains ".", "[" or "(" • DVT-5118 Wrong NON_EXISTING_PACKAGE error triggered when the package name is an escaped identifier • DVT-5119 Hyperlink is not working on a class field when its name is an escaped identifier • DVT-5122 Wrong jump to editor for ports/signals with similar names • DVT-5139 Run configurations session wrapper throws errors in some "sh" replacements (e.g. dash in Ubuntu) due to non POSIX syntax • DVT-5142 Refactor rename not working properly when more than 10 files are changed • DVT-5156 Double click on Compile Order View during build freezes the DVT • DVT-5173 Coverage event 'with function sample()' not allowed if no arguments provided to 'sample' • DVT-5180 `default_nettype not correctly computed when instantiating a module (it inherits the `default_nettype from module definition) • DVT-5194 New File Wizard does not show an error message when creating a new file in a virtual folder © AMIQ 443 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5196 HTML Documentation: open index.html in the platform's internal web browser (instead of the default editor) • DVT-5204 Fixed "Could not set character size" error when displaying diagram's legend and preferences 3.4.3 (21 June 2013) Enhancements • DVT-4542 Pair only elements of same kind when folding code and performing doubleclick selections (like task, class, `ifdef, etc) • DVT-5093 Display the relevant documentation when requesting the legend for UML diagrams • DVT-5107 Improved the display of ports and signals in the Trace Connection View • DVT-5109 Changed shadows indication to overrides indication for class constructors Bugfixes • DVT-3182 Concatenate comments from extern and implementation for inline documentation • DVT-4966 Hyperlink jumps to an enum item with the same name instead of module parameter • DVT-5038 Types View: after platform restart icons are not visible • DVT-5102 Wrong instance name when using escaped identifiers 3.4.2 (14 June 2013) Enhancements • DVT-4223 Persist the Instance Tree Ports View settings • DVT-4761 Add a button to show the legend of module flows diagrams • DVT-4992 Disable "Use dot from distribution" checkbox in non-linux environments • DVT-5086 Automatically detect and ignore VCS-encrypted (binary) SystemVerilog source files Bugfixes • DVT-4223 Persist the Instance Tree Ports View settings • DVT-4858 Quick filter in Types View should expand the tree and select the first match • DVT-4974 Auto-complete inside "randomize() with { ... }" does not recognize hierarchy past first level © AMIQ 444 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5035 Types View search filter sets focus on wrong type if project has multiple natures • DVT-5052 Trace Connections View is not cleaned when closed • DVT-5076 Add to default.build does not add build configuration files • DVT-5077 Always open with DVT editor when double click in Compile Order View • DVT-5083 Trace Connections from Editor does not work on a primitive's port • DVT-5091 Instance Tree View memory leak • DVT-5094 All refactoring operations should only validate editing of the files that will be modified (make writable/check out) • DVT-5095 Incorrect trace path shown in Trace Connections View for signals with the same name • DVT-5097 Syntactic error reported on previous included files when unexpected char occurs at the beginning of a file (binary file) 3.4.1 (7 June 2013) Performance • DVT-5050 Trace Connections optimizations for big instance trees • DVT-5073 Performance improvement on DVT-Auto Linked files creation (part 2) Enhancements • DVT-4827 Print total build time in human-readable form • DVT-4910 Add support for non-standard syntax foreach(a.b.foo().an_array[ i ]) • DVT-4999 Module instantiation without instance name has wrong label in Instance Tree • DVT-5039 Add defined macros to `timescale directive • DVT-5074 Added Trace Connections message dialog for operation already in progress Bugfixes • DVT-5026 Diagram preference page incorrectly manages invalid dot executable • DVT-5027 Types View drag and drop entity auto-instance does not work on Windows • DVT-5028 Trace Connections View memory leak • DVT-5034 Quick Types/Compile Order Views should show Select Project dialog if no project is selected © AMIQ 445 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5046 Quick Types/Compile Order Views do not close when trying to open an element that is already opened in an editor • DVT-5047 Types View drag and drop module auto-instance doesn't scroll through vlog/vhdl editor • DVT-5053 HTML Documentation Wizard overview description file error if the file "readme.txt" is not found • DVT-5059 Trace Connections from Editor does not work on interface ports • DVT-5063 Path hyperlinks are improperly formatted when file name contains '&' character • DVT-5064 Path hyperlinks are improperly formatted when file name contains whitespace • DVT-5069 Hyperlink jumps to right location but override annotation goes to gray file 3.4 (2 June 2013) HIGHLIGHTS • Override Annotations in the Editor. See Override Functions • Ability to inspect each step from source to destination when tracing connections. See Trace Path • Ability to trace connections from editor. See Trace Connections from Editor • Ability to search for ports in the design hierarchy. See Search Port in Design Hierarchy • Ability to instantiate a module using drag and drop. See Autoinstance Using Drag and Drop • Unified Types and Quick Types Views across languages. See Types View • Unified Compile Order and Quick Compile Order Views across languages. See Compile Order View • Unified Tasks Tags Preferences across languages. See Reminders (TODO Markers) Performance • DVT-5032 Performance improvement on DVT-Auto Linked files creation • DVT-5033 Performance improvement on implicit net assignment semantic checks Features • DVT-141 Mixed Language Support: Unify Compile Order View and Quick Compile Order View. See Compile Order View • DVT-147 Mixed Language Support: Unify Types View and Quick Types View. See Types View © AMIQ 446 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3107 Mixed Language Support: Unify Task Tags Preferences. See Reminders (TODO Markers) • DVT-4434 Trace port directly from editor. See Trace Connections from Editor • DVT-4724 Mixed Language Support: Unify Project Statistics • DVT-4933 Add an indication in the editor that a class function or task is overridden. See Override Functions Enhancements • DVT-3131 Remove checkboxes from the entries in Tasks View • DVT-4023 Added Why section in the Trace Connections View to see trace path of a port or signal. See Trace Path • DVT-4634 Mixed Language Support: Quick Types View should show information for all languages instead of asking to select a language • DVT-4682 Support for drag and drop Verilog module auto-instance • DVT-4957 Update OVM/UVM Field Editor "Preliminary Check" dialog • DVT-4975 Synchronized Why section with the Trace Connections View • DVT-4976 Add icons to the ports displayed in the Why window • DVT-4977 Differentiate between sources and destinations in the Trace Connections View • DVT-4987 Enable "Change DVT Nature" popup menu action, regardless of current perspective • DVT-4990 Mixed Language Support: Quick Compile Order should show information for all languages instead of asking to select a language • DVT-5004 Ability to search for ports in the Instance Tree View • DVT-5018 Added progress reporting for trace port operations Bugfixes • DVT-4247 Refactor Connect: unable to reuse an existing port when connecting two instances • DVT-4674 Diagram "Save as" should update supported extensions when dot binary changes • DVT-4714 Refactor Connect: toolbar changes position depending on the order of button presses (ports view, connect toolbar) • DVT-4929 Add support for simple wildcards (* and ?) for Instance Tree filtering • DVT-4973 Relative paths in environment inherited $SPECMAN_PATH are not resolved as relative to compilation root © AMIQ 447 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-5005 Build Config Editor - Some top files include patterns don't get recognized under Windows • DVT-5019 Quick Hierarchy View (Ctrl+T) not showing the expected info on class constructor 'new' • DVT-5020 Override Method (via autocomplete or right click menu) doesn't work for predefined functions • DVT-5031 Connect ports: toggle ports view after performing a connect operation duplicates the connect toolbar 3.3.8 (24 May 2013) Performance • DVT-5010 Performance improvement on post build resolve import (RI) and check for duplicate (RD) steps Bugfixes • DVT-5011 Missing tooltip and content assist for rand_mode() function and task on rand/ randc declared fields • DVT-5012 Missing tooltip/hyperlink and content assist on implicit iterator of lists (e.g list.find_index(my_index) with { my_index = index; }) 3.3.7 (17 May 2013) Enhancements • DVT-3139 Allow creating a new file under the DVT Auto-Linked folder using the New File Wizard • DVT-4961 References of a port when using list of instances works only for the first instance (potential matches for the subsequent instances) • DVT-4963 Non-standard support for module instantiation without instance name • DVT-4981 Non-standard support for keyword 'design' used as an identifier (e.g. 'modport design (...)') • DVT-4982 Support for Aspect Oriented Programming (AOP) using +dvt_enable_sv_aop flag in *.build configuration files • DVT-4991 Code templates changes: removed 'uvm_1_0_ea' templates and renamed 'uvm_1_1' to 'uvm' Bugfixes • DVT-4815 Fixed MacOS dot crashes by disabling orthogonal routing option for this platform © AMIQ 448 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4834 Files under DVT Auto-Linked roots are not removed when added as linked resources • DVT-4959 Registration macro for array of events is not computed correctly • DVT-4962 Macros should not be expanded inside strings (e.g. "`DEF_NAME = " should not change if DEF_NAME is defined) • DVT-4968 Smart log styles don't work for run configurations • DVT-4983 Wrong location of tooltips/hyperlinks at left word boundary • DVT-4993 Prevent a dictionary restore when a full build will follow 3.3.6 (27 April 2013) CLEANUP • DVT-4944 Renamed "Trace in Design" as "Trace Drive and Load" to reflect the changed functionality Enhancements • DVT-4661 Build Config: turn off "Unknown directive" warnings by default • DVT-4662 Build Config: add support for +dvt_enable_unknown_directive_warnings Bugfixes • DVT-4626 On MacOS dvt.sh issues an error (tee: illegal option -- -) • DVT-4803 Custom Dialogs: Directory Files Listing widget presents an empty list on the first run • DVT-4879 Expand macros defined like `define a_macro(arg) `macro1``arg`macro2 according to compatibility mode • DVT-4904 Non-standard support for missing return type of a method prototype 'function foo()' • DVT-4910 Non-standard support for hierarchical method call in 'foreach' construct (e.g. foreach(a.b.foo().an_array[ i ])) • DVT-4922 Project right click > Add to default.build should work if .dvt directory does not exist or is empty • DVT-4923 Project right click > Add to default.build should refresh default.build file after updating it • DVT-4938 Trace Connections View doesn't show the vertical scrollbar • DVT-4941 Project right click > Ignore Files does not add the correct path to default.build © AMIQ 449 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4943 DVT Wizards menu entries not visible in DVT Perspective in project right click menu • DVT-4947 Some images are not displayed in the built-in documentation • DVT-4956 Reapply checks in the linter GUI not working after rebuilding the project 3.3.5 (22 April 2013) REMOVED • DVT-4900 Predefined Projects: uvm-1.1(a,b,c)_ubus projects removed Enhancements • DVT-4876 HTML Doc Wizard: enhanced support for absolute paths for documentation output directory path • DVT-4899 HTML Doc Wizard: enhanced support for system variables in paths • DVT-4914 Improve Instance Tree filtering performance • DVT-4921 Document Instance Tree View filtering Bugfixes • DVT-4849 Predefined Projects: launch configurations might not work because of 32/64 bits compatibility problems • DVT-4877 HTML Doc Wizard: open index.html in web browser after generating documentation in a directory outside the project • DVT-4878 Trace Connections View doesn't show assign statements • DVT-4902 New File Wizard shows an error message when trying to create a new file inside a virtual folder • DVT-4912 Slow parsing for large macro expansion stack 3.3.4 (15 April 2013) Performance • DVT-4731 Limit the number of proposals on autocomplete • DVT-4851 Code formating is slow when applied to large files • DVT-4852 Autocomplete auto-instance slow when large number of modules or large number of ports • DVT-4866 Populating the instance tree is slow for large designs Enhancements © AMIQ 450 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4603 Content assist option to combine both search algorithms (CamelCase and prefix match) • DVT-4722 Changed Trace in Design to show the reunion of Trace Drive and Trace Load • DVT-4740 Semantic DUPLICATE_ENUM_LITERAL problem should be demoted to WARNING • DVT-4799 Add pointers to Code Template property pages in New File Wizard • DVT-4800 Predefined Projects: uvm-1.1d library and uvm-1.1d_ubus project added • DVT-4813 Updated FlexLM libs to v.11.11.1 to add support for "INCLUDE ... PROJECT" option • DVT-4847 Non-standard support for hierarchical method call in 'foreach' construct (e.g. function_call().field[]) • DVT-4863 Non-standard support for range selection in randomize argument (e.g. std::randomize(rand_var[ 7:0 ]) with ...) • DVT-4873 Non-standard support for packed dimension on stream concatenation simple type Bugfixes • DVT-4325 Added fork ... join/join_any/join_none block selection, similar with begin ... end pair • DVT-4592 Fixed dvt.sh to work with "-eclispe_args -pluginCustomization ..." arguments • DVT-4794 New Project Wizard should not overwrite existing default.build • DVT-4830 "Resource is inaccessible" error when the DVT Auto-Linked folder is cleaned • DVT-4842 dvt_plugin_installer.sh delete directive uses only the last delete argument and ignores the rest • DVT-4861 Code enclosed between `protect ... `endprotect pragmas should not be ignored by compiler • DVT-4864 Generating HTML Documentation does not work if a build job is in progress • DVT-4868 Autocomplete not inserting the proposals when $ sign in the middle of involved identifiers (function arguments, parameters, candidate name, etc.) • DVT-4872 Duplicate error message missing first hyperlink if element declaration line number > 999 • DVT-4880 NON_EXISTING_PORT error triggered when a port's name is an escaped id containing '.' (dot character) 3.3.3 (2 April 2013) © AMIQ 451 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Performance • DVT-4225 Module flow diagram performance improvements for large designs • DVT-4742 Slow hyperlink to definition or tooltip in very large files • DVT-4743 Slow hyperlink to assignment in very large files • DVT-4744 Slow typing or navigating (scroll) through very large files Enhancements • DVT-4308 HTML Doc Batch: Ability to report progress • DVT-4758 Jump to assignment should go to the first port connection, if any • DVT-4784 Project Statistics - collect macro expansion statistics should be off by default • DVT-4769 Rebuild buttons should have the corresponding action in the drop-down menu Bugfixes • DVT-1231 Diagram, HTML Documentation, and OVM/UVM Compliance editor windows should close on project close/delete • DVT-4518 Hyperlink and tooltip should point to sequence argument instead of field • DVT-4624 Unsupported syntax 'bit[ a:b ] mem[ bit[ c ] ];' • DVT-4685 Automatic module instantiation should indent the generated code • DVT-4700 For SVN distros, after update to 3.3.1, errors are incorrectly thrown by the DVT Auto-Linked folder • DVT-4717 Empty menu entry in Window -> Customize Perspective -> Toolbar Visibility tab-> DVT Build • DVT-4725 Predefined Projects - Makefile.questa does not work if the predefined projects are stored in a read only location • DVT-4729 Copy full path doesn't work for DVT Auto-Linked folders • DVT-4735 Dynamic Shortcuts in Eclipse 4 - generated icons are not visible on the main toolbar • DVT-4774 External Questa builder is not working out of the box on Windows • DVT-4780 Hide OVM/UVM members on outline view not working after platform restart • DVT-4781 Unsupported list associated to a localparam (e.g. localparam [ 7:0 ][ 7:0 ] X = {8'h08 << 1, 8'h08 << 2};) • DVT-4782 "default" code template not visible in New File Wizard © AMIQ 452 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4783 Remove footer from "verilog file" code template • DVT-4789 Auto-complete on system tasks with no argument adds an extra dollar sign (e.g. $time()) • DVT-4798 The +dvt_env+ build directive should accept quoting the environment variable value 3.3.2 (22 March 2013) Bugfixes • DVT-4604 Fixed FlexLM client to prevent opening too many threads in some situations • DVT-4693 Fixed FlexLM client reconnection problems by reducing reconnection time after idling • DVT-4707 Predefined Projects Wizard - some fields are not displayed correctly when the monitor resolution is less than 1024x768 • DVT-4708 Outline view is notified multiple times after an incremental compile • DVT-4710 Compilation fail sometime when the project contains linked resources 3.3.1 (15 March 2013) Enhancements • DVT-4584 Support for uniqueness_constraint construct • DVT-4639 Overwrite closing brackets instead of adding another • DVT-4658 Support for specparam PULSEPATH$ = constant_mintypmax_expression • DVT-4666 Autocomplete in coverpoint field hierarchical access • DVT-4675 Diagram save as should append the .<ext> to file name specified by the user Bugfixes • DVT-2006 Fixed hyperlinks, references, tooltips for escaped identifiers • DVT-4579 Extend automatic check-out to "Search and Replace" • DVT-4619 Hyperlink after keyword virtual should always point to a type and not to a field definition with the same name • DVT-4649 Wrong syntax error reported when using event control "edge" • DVT-4652 Override Methods - bracket bug in auto generated code • DVT-4653 Override Methods should not work inside a comment block © AMIQ 453 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4670 Stack overflow when adding a key binding to a dynamic shortcut • DVT-4676 Diagram preview dialog errors out with "cannot find font" • DVT-4681 False syntactic error triggered by two consecutive semicolons inside function body block item declaration list • DVT-4684 Use of platform dependent FontData fields leads to unexpected behavior in trace port connections view • DVT-4688 Increase/Decrease Editor Font Size does not work after modifying the default font from Windows -> Preferences 3.3 (10 March 2013) HIGHLIGHTS • Ability to save a diagram in various graphical formats like jpeg, png, svg (see Diagrams) • Ability to specify the "Run Configuration Session Type", mainly in order to allow for proper termination of all spawned processes when launching an external tool (see Run Configuration Session Type) • Ability to select if a run configuration is a command or a multi-line script (see Run Configurations) • Ability to specify one or more "roots" that DVT Auto-Link can use instead of the full hierarchy, in order to flatten the deep Auto-Link hierarchy (see DVT Auto-Linked) • New HTML Documentation wizard with support for mixed language projects (see Export HTML Documentation_Wizard) REMOVED • DVT-4370 Removed support for pre DVT 2.9.7 local licenses (DVT_LICENSE_VERSION is not used anymore) DEPRECATED • DVT-4575 dvt_trap.sh is deprecated by Run Configuration Session Type • DVT-4577 dvt_xterm.sh is deprecated by Run Configuration Session Type Features • DVT-4217 Ability to specify one or more "roots" that DVT Auto-Link can use instead of the full hierarchy. See DVT Auto-Linked • DVT-4466 Integrated dvt_trap.sh and dvt_xterm.sh functionality in run configurations (see Run Configuration Session Type) • DVT-4578 Ability to select if a run configuration is a command or a multi-line script © AMIQ 454 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-3780 Mixed Language Support: New HTML Documentation wizard with support for projects with multiple natures • DVT-4042 When changing project nature, don't create default.build if .*_top_files already exist • DVT-4047 Mixed Language Support: Unify toggle nature actions • DVT-4100 Ability to save a diagram in various graphical formats like jpeg, png, svg • DVT-4161 Generate wires for all ports when doing module auto-instance • DVT-4202 Linter HTML Report generates a ovm/uvm/verssimo.html.report file that can be used to open the report from DVT • DVT-4203 Unified Linter/Compliance HTML viewers listed in Open With context menu • DVT-4310 HTML Doc Batch: Ability to generate documentation without the xml settings file argument • DVT-4321 Show inheritance tree for all classes in a package in the generated HTML Documentation • DVT-4343 Enhance autocomplete for `include (take into account the specified incdirs) • DVT-4365 Generate Html Documentation in dvt_html_doc directory • DVT-4419 Add color preferences page for the *.build configuration file editor • DVT-4433 Serialize Instance Tree top module in default.build and automatically populate the view • DVT-4464 Outline View option to hide the content behind OVM/UVM macros • DVT-4593 Allow sub-second granularity for dvt_debug_utils.sh -thread_dump • DVT-4600 Update copyright in plugin description • DVT-4640 Don't prompt the user for making files writable, when automatic check-out fails Bugfixes • DVT-2672 & DVT-3005 Console View Terminate does not work (due to background processes holding stdout) is fixed when using a new session (see Run Configuration Session Type) • DVT-4083 HTML Documentation for struct/enum and typedefs is not extracted for global scope • DVT-4315 Html Documentation Wizard is not in sync with the .xml settings file © AMIQ 455 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4413 Shift + F4 on non-types should not clear the instance tree but bring it into focus • DVT-4428 False errors in default.build when multiple directives starting with uvm are present in the dvt compatibility mode • DVT-4465 Project root is added to incdir list instead of compilation root • DVT-4503 Wrong hyperlink for struct/enum fields in HTML Documentation • DVT-4521 Wrong line/file is reported for some directives (e.g. uvmhome) in default.build • DVT-4557 Rename "CDN OVM User Guide" to "CDN OVM/UVM User Guide" in Preferences -> Help • DVT-4570 BuildConfig Editor doesn't correctly match numbers • DVT-4638 New File Wizard - "Browse" button does not work if "Directory" field is empty • DVT-4646 Automatic check-out: text following ${selected_resources_loc} variable gets lost 3.2.21 (8 March 2013) Bugfixes • DVT-4638 New File Wizard - "Browse" button does not work if "Directory" field is empty • DVT-4643 Fixed duplicate error message path • DVT-4644 Fixed duplicate error message shown in the same file when files are outside project dir 3.2.20 (6 March 2013) Bugfixes • DVT-4628 Internal builder triggers external builder for files opened from outside project • DVT-4629 Errors reported on a wrong top file when the issue is inside a library (-y) file • DVT-4632 Compile order view not showing the correct order for the library (-y) files • DVT-4636 Set current build complains about read-only build_config.xml 3.2.19 (5 March 2013) Bugfixes • DVT-4621 Wrong redefined __LINE__ and __FILE__ warnings signaled outside project • DVT-4622 Spurious internal debug messages in console 3.2.18 (4 March 2013) Bugfixes © AMIQ 456 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4590 Tab indent issue for comments • DVT-4597 Hyperlinks/tooltips are computed very slow when there is a heavy macro on the LHS of the word • DVT-4599 Set current build fails silently when build_config.xml is read only • DVT-4605 Source format might fail to check out a license • DVT-4606 In OSX, generating a predefined diagram with no dot in PATH and no type compiled opens several windows that cannot be dismissed with the mouse • DVT-4613 Memory leak when importing/deleting projects several times • DVT-4615 `undefineall directive should not undefine CLI or predefined macros like `__FILE__ and `__LINE__ • DVT-4616 Add `wrealZState and `wrealXState in the ius.irun compatibility mode build config 3.2.17 (20 February 2013) Enhancements • DVT-4030 Workingset selection toolbar button is missing in DVT perspective • DVT-4302 Add buildProject command to DVT CLI • DVT-4496 Show [] array indication in autocomplete balloon • DVT-4538 Custom Dialogs: when ElementListSelectionDialog widget has many entries the previous selection is restored very slow • DVT-4552 Add -blocking flag to DVT CLI refreshProject • DVT-4564 Support for non-standard class_name::task_name.block_label;" syntax inside task "disable Bugfixes • DVT-4435 Unwanted sticky selection when reloading a file that changed on disk • DVT-4512 Bus width is ignored when connecting ports across the design hierarchy • DVT-4551 Don't auto-insert closing bracket )]} if there are characters after • DVT-4557 Rename "CDN OVM User Guide" to "CDN OVM/UVM User Guide" in Preferences -> Help • DVT-4561 Add support for auto-complete across binds in expressions • DVT-4565 Format preference page - NullPointerException when enabling/disabling external program formatting © AMIQ 457 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4566 Format preference page - broken layout for line wrapping note • DVT-4572 Auto-indent issues for identifiers that start with keywords 3.2.16 (11 February 2013) Features • DVT-1690 Hooks for scripts to perform automatic check-out when editing a read-only file Enhancements • DVT-3132 Autocomplete only interfaces after 'virtual interface' when inside a class • DVT-3384 Button for collapse all grayed out code (along with collapse first level etc) • DVT-4504 Restrict proposals to types when "protected" and other qualifiers are used when declaring fields in classes • DVT-4540 Support for non-standard 'automatic' lifetime when declaring class constructor Bugfixes • DVT-4418 Double click 'endmodule' selection pairs with 'property' instead of 'module' • DVT-4492 When using split editors, selecting a word in one of them reveals the cursor position in the other • DVT-4494 Macro reparse stack file paths should be always absolute • DVT-4514 Fixed possible deadlock situation in DVT Launch Configuration modification listener • DVT-4515 A more informative error message if there is a name collision between an imported project and one from the current workspace • DVT-4522 Tooltip on 'new' implicit constructor not working • DVT-4523 Sequence declared inside clocking block not correctly handled • DVT-4524 Resolve name from "name::" as package or type even if a variable with the same name exist in the context • DVT-4537 Refactoring field should update 'coverpoint' and 'covercross' field references • DVT-4539 Sequence instance followed by consecutive repetition not allowed as sequence argument • DVT-4543 Missing hyperlinks in console log 3.2.15 (28 January 2013) © AMIQ 458 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-4491 Run Configurations wizard is very slow when changing settings • DVT-4501 Missing associative index type references in direct association diagram • DVT-4497 Console hyperlink is opening the wrong file when both physical and symbolic link files are under project 3.2.14 (23 January 2013) Bugfixes • DVT-4490 Delete at cursor position removes text at the last selected region offset 3.2.13 (23 January 2013) Bugfixes • DVT-4487 Incremental build not always working (sometime not working for the files under project root) • DVT-4488 Exception thrown sometime when deleting text under vertical selection • DVT-4447 Building a C project will cause ClassCastExceptions to show up in the Error Log 3.2.12 (22 January 2013) Enhancements • DVT-4403 Inconsistent quoting when reporting errors (e.g. Expecting "something", found 'something else') • DVT-4468 Update Clearcase plugin to version 2.2.27 • DVT-4470 Overwriting closing quotation marks after typing some text • DVT-4484 Brush-up the defaults for external builders Bugfixes • DVT-4463 Wrong hyperlink from Run Configuration Filters if there are more files with the same name • DVT-4472 External builders should read from .dvt_builders if it exists but no external_builders.xml exists • DVT-4477 Error reported on the wrong file (e.g. reported on the file that include the one with the error) • DVT-4478 Wrong syntactic error reported when event expression used as sequence call argument © AMIQ 459 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4479 Dynamic Run Configurations shortcuts wizard page - cannot change "toolbar order number" • DVT-4485 The toolbar containing New Project & File wizards is not visible on the main toolbar 3.2.11 (11 January 2013) Enhancements • DVT-4426 +dvt_env+ directive should accept environment variables in variable names • DVT-4436 Improved parser recovery mechanism when syntax errors due to protected code • DVT-4459 Dynamic Launch Configuration Shortcuts - show toolbar icon & consider key binding for read-only configurations Bugfixes • DVT-3179 Javadoc auto-complete does not fill in function/task arguments • DVT-3642 Select word under cursor and find next occurrence (Ctrl + 8 <=> Alt + Shift + Up, Ctrl + K) • DVT-3765 Wildcard patters don't work for Windows network paths like \\...\...\... • DVT-3978 Build Config Editor - Environment vars defined in the build file are not shown by content assist • DVT-3979 Build Config Editor - Content assist for relative paths will not work properly if compilation root changes • DVT-4376 In default.build, when trailing + is missing for a directive, DVT throws an IndexOutOfBounds error • DVT-4393 In IUS.IRUN compatibility mode, directives should be case-insensitive. • DVT-4423 Code Templates View automatically expands on resource change causing selection loss • DVT-4424 In default.build: allow defining env variables with names containing other env variables • DVT-4425 External tools reported errors are not always back-annotated to the editor as problems (java exception thrown) • DVT-4431 Allow text being selected in a single editor at a time • DVT-4437 Project Templates should not consider x_param__ or __param_x as valid parameters • DVT-4444 Specman error message not recognized by run configurations filters © AMIQ 460 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4445 Specifying -snpath in default.build without any prior SPECMAN_PATH definition triggers an internal error • DVT-4446 In default.build, warn when -snpath appends to an existing SPECMAN_PATH value • DVT-4448 Disable DVT section from project properties page if the project does not have any DVT natures • DVT-4453 Ability to change path pattern wildcard timeout for default.build by +dvt_path_pattern_timeout+<seconds> directive 3.2.10 (24 December 2012) Enhancements • DVT-1363 Cancel linting when full build is canceled • DVT-3105 Change project (update views) when working with editors on config files • DVT-3479 Enforce that a project must be specified in lint configurations • DVT-4127 Trace port in gate level designs (netlists) • DVT-4279 Auto-insert pair character when typing '"', '{', '[' or '(' • DVT-4291 Hierarchy View - Add new filter for “virtual functions/tasks” in hierarchy view member filters • DVT-4303 Auto-indent issue for false-positive keywords (e.g.'super.end_') • DVT-4309 Update external builder default command to use ${dvt_current_build_file} • DVT-4395 2x -v library scanning speed up in large environments • DVT-4397 Support for multiple selection in Directory Files Listing (Custom Dialogs widget) • DVT-4398 New Linked Resource Wizard fields are empty when triggered after selecting an Auto-Linked file • DVT-4400 Ability to discard the id of a Custom Dialog widget, when its value is empty Bugfixes • DVT-3179 Javadoc style autocomplete sometime not working (i.e. does not fill in function args) • DVT-3798 Inline randomization of objects doesn't allow prediction (content assist) of signals • DVT-4278 Diagram editor help button doesn't work • DVT-4353 Eclipse Juno - Cancel Custom Dialog triggers an error instead of canceling the action © AMIQ 461 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4399 Eclipse Juno - Add support for build buttons and dynamic Run Configuration shortcuts • DVT-4404 Refresh on external builders property page does not work after removing/ modifying a builder • DVT-4417 Misc fixes in UVM code templates 3.2.9 (11 December 2012) REMOVED • DVT-4383 Removed Glance plugin because it was causing problems with views repainting Enhancements • DVT-3809 Buttons on main toolbar for increasing / decreasing the editor's font size • DVT-4367 Updated code templates to place cursor in right position after insertion • DVT-4379 Cleaned formatting for code templates • DVT-3950 DVT CLI should select the project after createProject/importProject • DVT-4147 Trigger warnings for the ignored directives encountered in default.build • DVT-4180 Add invocations list and number of waived issues to build log • DVT-4213 Add refresh command to DVT CLI • DVT-4268 In ius.irun compat mode, -libext <ext> should be recognized as a valid directive • DVT-4358 Add quit command to DVT CLI • DVT-4364 Trigger an error if +/-libext is specified without preceding '.' • DVT-4371 Console button for printing build log summary Bugfixes • DVT-4169 On some OSs, after Quick actions (e.g. Quick Outline) the focus is lost for entries in the current file • DVT-4184 Cannot delete project from disk, in windows and some linux OSs due to dvt_build.log still held open • DVT-4366 File extension resets to default when changing file's name in New File Wizard • DVT-4374 Fixed OVM/UVM Field Editor inserting _object_utils over any other _utils • DVT-4375 Updated UVM Field Editor to use uvm_object_utils instead of deprecated uvm_sequence_utils macro © AMIQ 462 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4378 Console logs filters don't properly highlight some log message regions • DVT-4382 Code templates preview does not use the global font settings • DVT-4389 Fixed Project -> Add to Test files, incdir... for Eclipse Juno • DVT-4384 The -f include tree is printed multiple times in the build console for mixed language projects • DVT-4385 Semantic errors are not reported in Build Console 3.2.8 (4 December 2012) Enhancements • DVT-4209 Changed the "verissimo_html_report" generated Verissimo HTML report directory to • DVT-4231 Verissimo checks can be reapplyed one by one from tree's context menu 3.2.8 (4 December 2012) REMOVED • DVT-4361 Removed key binding for "Select Project" because it was in conflict with the new binding for "Redo" Bugfixes • DVT-3984 Added back the key binding Ctrl+Y for "Redo" as it was changed in Eclipse to Ctrl+Shift+Z • DVT-4333 Bad indentation on 'if else if else' statements • DVT-4359 $root and $unit scope is not correctly computed for hyperlink and hover info • DVT-4362 Fixed empty key bindings for rebuild internal and external commands 3.2.7 (3 December 2012) Enhancements • DVT-4069 Updated Eclipse Platform to 3.8.1 and all the plugins from distribution • DVT-4156 Semantic references search in the current file • DVT-4222 Hierarchical Filtering in the Instance Tree View using slash (/) • DVT-4272 Run Configurations Launch Command - add support for Windows • DVT-4294 Issue error in default.build if -y is specified but no +libext+ directive • DVT-4311 Show file extensions based on project's natures in New File Wizard © AMIQ 463 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4318 Added default.build editor color preferences in DVT Themes • DVT-4324 HtmlDoc comment pragma to exclude types from documentation (@dvt_no_html_doc) • DVT-4328 Added invocation number for console reported syntactic errors • DVT-4332 Support for soft constraints (under "1800-2012" keyword set) • DVT-4339 Disabled Eclipse Update Site in distributions to speed up the updates (to enable use Preferences -> InstallUpdate -> Available...) Bugfixes • DVT-3990 Bad index (incremented) in syntax error report when errors at the end of the file • DVT-4036 OVM/UVM Field Editor should use ovm_field_utils_begin for virtual classes • DVT-4060 Wrong key used by OVM/UVM field editor for ovm_field_aa_int_key • DVT-4081 In ius.irun compatibility mode, for -xvm[ home ] directives, report errors on the -xvm[ home ] line instead of next +dvt_init • DVT-4164 Fixed default spelling dictionary for DVT distros • DVT-4211 In column selection mode, fixed line duplication when inserting a space after closing item (ex. after endfunction) • DVT-4305 Wrong tooltip on variables of enum type • DVT-4314 Missing text wrap in generated HTML documentation • DVT-4322 Incremental `include files are not correctly handled in a multiple invocations build config • DVT-4330 Spurious AssertionFailedExceptions might occur when switching current build • DVT-4350 Autocomplete issue when function/task argument name matches one of the template variable name (e.g 'file_name') • DVT-4351 Missing toolbar labels (in Window -> Customize Perspective -> Toolbar visibility) 3.2.6 (19 November 2012) Enhancements • DVT-4075 Added 'add directory as incdir' action (right click on a directory -> Project Menu -> Add as Incdir) • DVT-4185 Added Custom Dialog screenshot to documentation • DVT-4216 Right-clik on a folder in DVT Auto-linked and Link Resource in Project Root © AMIQ 464 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4254 Inserted code template by drag & drop from Templates view now indents the code • DVT-4257 Added a Build tab for DVT Generic Launch Configuration • DVT-4282 HtmlDoc - option added to remove "by <username>" watermark in the generated .html pages • DVT-4285 Update the problem markers differentially Bugfixes • DVT-3888 Skipped/Ignored files are not properly decorated • DVT-4137 Code templates editor now has the same background color as the DVT editor • DVT-4240 Bad begin/end delimiters matching (by double-click) due to assert property • DVT-4259 Tracing signal missing connections when signals declared inside generate block • DVT-4269 Slow editing when block selection mode is used on hundreds lines of code • DVT-4270 System variables are not translated for -uvmhome directive • DVT-4271 UVM library path is not computed correctly from -uvmhome directive • DVT-4280 Incremental build duplicates errors when file is a symbolic link • DVT-4283 Sometimes opening a file causes its error markers to disappear • DVT-4284 Incremental build disables marker limits for the semantic problem markers • DVT-4286 In default.build, some windows paths are interpreted as unicode • DVT-4290 In vcs compatibility modes, un-escaping of strings does not work correctly in argument files included with -file directive • DVT-4297 Code Templates View hangs when creating a new template • DVT-4300 Sometimes semantic errors are not restored at platform restart 3.2.5 (6 November 2012) REMOVED • DVT-3975 Removed outline view link with editor feature (not always working correctly on lazy tree) Enhancements • DVT-3827 Update error markers when opening a file that has errors but no markers (due to Problems View marker limits) • DVT-4212 Automatically infer arguments for macros aliases © AMIQ 465 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4221 Ability to Show Instance Tree on right-click on a node in the Instance Tree View Bugfixes • DVT-3565 HTML Documentation - Extract comment from output/input port declaration • DVT-4132 Custom dialog example missing from File > New > Example menu • DVT-4146 System variables not expanded for +dvt_compilation_root directive • DVT-4162 Auto-complete inside 'if (...)' in an always block does not show wires and ports • DVT-4187 In tooltip, local variable name is replaced with internal __identifier__ • DVT-4189 Escaped identifier and identifier are semantically same element • DVT-4200 Un-escaping of strings in default.build does not work • DVT-4220 Wrong notification about empty default.build when using dvt_sv_lint_gui.sh • DVT-4224 Missing connections between submodules in module flow diagram • DVT-4237 Some compile options like +libext+ or -y, -v are evaluated globally and not per invocation • DVT-4260 Preprocessing defines management across multiple invocations in default.build is broken • DVT-4261 Wrong syntax error on 'for' generate loop following a block definition 3.2.4 (26 October 2012) Enhancements • DVT-3607 Compile Order View - Ability to see where a file is included from. See Compile Order View • DVT-4095 Support for non-standard hierarchical identifier for cover point inside 'binsof' specification • DVT-4097 Support for non-standard array of typedef struct data type • DVT-4102 Predefined Projects - uvm-1.1c library and uvm-1.1c_ubus project added • DVT-4103 Support for non-standard specify $width ( negedge clr, 1, , notif ); • DVT-4104 Support for primitive without a table (the table can be in protected code) • DVT-4106 Support for nonstandard typedef covergroup • DVT-4183 Support for non-standard empty arguments list '()' when arguments are declared inside function/task body" © AMIQ 466 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-4084 Enter after /** regenerates comment leading to a wrong comment e.g. /** * * * */ * * */ • DVT-4098 Compilation errors on "let" constructs • DVT-4105 In ius.irun compat mode the -uvmhome directive searches for ovm_pkg.sv instead of uvm_pkg.sv • DVT-4126 New Project Wizard - Unable to create a project when the project location is changed • DVT-4176 Build Config Editor: incorrect autocomplete proposals for +dvt_e_sn_which • DVT-4177 Build Config Editor: no tooltip for directives that set internal builder properties • DVT-4182 Compilation errors on macro parameters declarations on multiple lines • DVT-4188 in ius.irun compatibility mode, DVT does not recognize the -ccext flag • DVT-4205 Fixed custom ruleset checks name based on library attribute 3.2.3 (17 October 2012) Enhancements • DVT-554 Dropdown for external build button: invoke a certain external builder. See How to invoke external builders Bugfixes • DVT-4088 New Project Wizard - add option to specify the project's name. See Open a Project • DVT-4092 New File Wizard exception when creating files that are not associated with DVT editors • DVT-4093 Html Documentation - Exception on wildcard index type for associative arrays 3.2.2 (12 October 2012) Enhancements • DVT-3618 Instance Tree View: option to copy instance path (right-click menu). • DVT-4045 Store predefined diagrams (and diagrams generated via shortcuts) in the dvt_diagrams/ directory Bugfixes • DVT-4078 For certain irun versions, in ius.irun Compatibility Mode, the -ovm/-uvm directive does not infer correctly the irun installation location © AMIQ 467 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-4079 Code templates not visible when creating them from the Code Templates View 3.2.1 (11 October 2012) Enhancements • DVT-4062 Show busy indicator when generating large diagrams • DVT-4066 Also dump "generate blocks" in instance tree dump • DVT-4067 Improve instance tree view performance on trees over 100k elements • DVT-4072 Ability to include ports by name in module diagrams Bugfixes • DVT-4071 Selection slow-down in DVT editors • DVT-4073 Too many view (instance tree, types, layers, etc.) update notifications received during build 3.2 (9 October 2012) HIGHLIGHTS • Support for multiple build configurations. • Enhanced the support for mixed language projects. Hyperlinks, design hierarchy, tracing and diagrams work across Verilog and VHDL. • Unified default.build instead of .edt_top_files, .vlog_top_files and .vhdl_top_files. See Build Configurations. • Enhanced Module Diagrams including colors, click-through design hierarchy and breadcrumb. • Enhanced Trace Port Connections by analyzing concatenations, bit selection and assign statements. • Out of the box Architecture UML Diagrams and Sequences UML Diagrams. REMOVED • DVT-4021 Removed eclipse.sh and eclipse.bat scripts (deprecated in 3.0.4) DEPRECATED • DVT-3498 Deprecated internal builder preference "Restrict '*.v' and '*.vh' files to Verilog-2001 syntax" (use Language Syntax directives instead). See All Build Directives. • DVT-3669 Deprecated .dvt/.edt_top_files. .dvt/.edt_defines, .dvt/.edt_ignore_files, .dvt/.edt_test_files, .dvt/.edt_specman_path. See Build Configurations. © AMIQ 468 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3708 Deprecated dvt_cli.sh createSVProject (use createProject -lang e instead) See Command Line Interface. • DVT-3883 Deprecated internal builder preference pages. See Build Configurations. • DVT-3885 Deprecated disable_ext+all (use +dvt_ext_unmap_all instead). See All Build Directives. • DVT-3997 Pop-up deprecation warning when using old .dvt/.*_top_files configuration files with the ability to dismiss per session. See Build Configurations. CLEANUP • DVT-3937 Move language specific workspace preferences under the DVT section • DVT-3938 Move language specific project properties under the DVT section • DVT-3891 Mixed Language Support: Modify "add to top files" to "add to *.build" • DVT-4052 Rename run_dvt_from_rawtokens.sh to dvt_from_rawtokens.sh • DVT-4053 Rename .dvt/.dvt_builders file to external_builders.xml. See External Builders. • DVT-4054 Rename .dvt/log_styles file to log_styles.xml. See Smart Log Features • DVT-130 Mixed Language Support: Unify the Instance Tree View. • DVT-1088 Support for multiple build configurations. See Build Configurations. • DVT-2846 Mixed Language Support: Unify .*_top_files under default.build. See Build Configurations. • DVT-3085 Autocomplete in *.build and command (*.f) files in general • DVT-3577 Mixed Language Support: Module diagrams for mixed Verilog and VHDL projects. See Module Diagrams. • DVT-3890 Mixed Language Support: New editor for *.build files. See Build Configurations. • DVT-3893 Mixed Language Support: Unify the wizards for creating projects and files • DVT-3907 Mixed Language Support: Unify the external builders. See External Builders. Enhancements • DVT-68 Support for compilation root specification in default.build. See All Build Directives. • DVT-554 Dropdown for selecting a specific external builder. See External Builders. • DVT-2608 Cross language check when reporting undeclared components/modules © AMIQ 469 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3089 Propagate system variables to external tools integration. See External Tools Integration. • DVT-3246 Semantic error for duplicate port connections in an instance • DVT-3252 Improved file navigation for the files exceeding 10K lines • DVT-3335 Support for generate blocks for refactor connect ports • DVT-3354 Option to hide typedefs in the select types dialog for class diagrams. See Class Diagrams. • DVT-3355 Option to hide the ovm/uvm package types in the select types dialog for class diagrams. See Class Diagrams. • DVT-3356 Out of the box UML Diagrams: Architecture diagrams and Sequences diagrams. See Architecture UML Diagrams and Sequences UML Diagrams. • DVT-3359 Trigger diagrams from the Types View, Instance Tree View and Editor context menu. See Module Diagrams. • DVT-3397 +dvt_init+ should behave like a new parsing invocation. See Build Configurations. • DVT-3491 Issue warning when dvt_cli doesn't get both arguments for -map. See Command Line Interface. • DVT-3522 Include instances with undefined types in Module Diagrams. See Module Diagrams. • DVT-3541 Updated predefined projects. See Predefined Projects. • DVT-3555 Customize graph direction (e.g. top-bottom, left-right) for Module Diagrams. See Predefined Projects. • DVT-3556 Context menu shortcuts when Tracing Ports for Trace Drive, Trace Load. See Trace Port Connections. • DVT-3559 Context menu shortcut for Module Diagrams to open subinstance diagram. See Module Diagrams. • DVT-3578 Add support for +dvt_skip_compile+ directive in default.build. See Build Configurations. • DVT-3586 Module Diagrams: ability to navigate back from submodule diagram. See Module Diagrams. • DVT-3589 Trace Port Connections across array selection (i.e. connecting an instance port to several bits selected from a bus). See Trace Port Connections. • DVT-3590 Show signal flow across array selection in Module Diagrams. See Module Diagrams. © AMIQ 470 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3592 Module Diagrams: extend functionality to include simple assignments when determining connections. See Module Diagrams. • DVT-3603 Shortcut for opening submodule diagram. See Module Diagrams. • DVT-3615 Customize the "u_<module name>" module instance name when using content assist (auto-instance). See Module Automatic Instantiation. • DVT-3659 Trace Port Connections through assign statements. See Trace Port Connections. • DVT-3680 Use customizable colors in module flow diagrams. See Trace Port Connections. • DVT-3691 Refactor add port ability to add ports of other types like: logic, structure, multidimensional arrays. See Add New Port to Module. • DVT-3715 Include instances of undefined type when Tracing Port Connections. See Trace Port Connections. • DVT-3729 Support concatenations when tracing connections. See Trace Port Connections. • DVT-3751 Add a -perspective switch to the dvt_cli.sh createProject command. See Command Line Interface. • DVT-3762 Refactor connect instances support for array of instances. See Connect Instances Across the Design Hierarchy. • DVT-3788 Improve semantic checks for modules with concatenated ports when using .* notation • DVT-3796 Add external tools variable containing the path to current build file. See External Tools Integration. • DVT-3819 Trace Port Connections through concatenated port aliases. See Trace Port Connections. • DVT-3824 Support for case-insensitive directives in ius compatibility modes. See All Build Directives. • DVT-3857 Tooltip colors (mouse hover, folding, errors) can be configured from Preferences -> General -> Appearance -> Colors and Fonts • DVT-3886 Mixed Language Support: Unify "Nothing to compile" dialog with the ability to dismiss per session • DVT-3908 dvt_plugin_installer.sh for customizing the Eclipse installation works with any update site • DVT-3892 Update predefined projects. See Predefined Projects • DVT-3923 Signal error when multiple -work flags are provided for the same invocation, and only consider the first one. See Build Configurations. © AMIQ 471 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3926 Alias +dvt_setenv+ to +dvt_env+. See Build Configurations. • DVT-3927 Warn when encountering unknown +dvt_ directives in default.build. See Build Configurations. • DVT-3948 Prompt for project selection when rebuild/clean is triggered if no project is selected • DVT-3953 Keyword-set support for ius.irun -v95 compatibility. See Build Configurations. • DVT-3968 Trace Port connections across Arrays of Instances. See Trace Port Connections. • DVT-3969 Trace Port Connections across wires inside Blocks. See Trace Port Connections. • DVT-3972 Add Module Diagrams support for concatenation {signal1, signal2} in instance Port Connections. See Module Diagrams. • DVT-4003 Build configuration directives for controlling +dvt_build_log_to_console, +dvt_build_log_to_file, +dvt_build_log_file build log: • DVT-4005 Add support +dvt_reparse_duplicate_top_files+ directive in default.build. See All Build Directives. • DVT-4006 Add support for +dvt_incremental_compile_max_lines+ default.build. See All Build Directives. directive in • DVT-4007 Add support for +dvt_auto_link+ directive in default.build. See All Build Directives. • DVT-4011 Add support for comment extraction preferences in default.build. See All Build Directives. • DVT-4012 Predefined Projects wizard - add progress monitor while copying a project • DVT-4018 Mixed Language Support: Add Code Templates View to the DVT unified perspective. See Code Templates View. • DVT-4046 Detailed messages for refactor connect ports errors Bugfixes • DVT-3042 Syntax Page - Restore defaults does not work • DVT-3150 Match begin - end for "property - endproperty" does not work • DVT-3446 Prompt for Module Diagram regeneration after code changes only if it will look different or the project has been rebuilt. See Module Diagrams. • DVT-3530 Import package directive triggers an error if the package is declared in VHDL • DVT-3557 Wrong setup for uvm_ref_flow predefined project © AMIQ 472 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3706 Don't allow creating a no-nature project with dvt_cli.sh. See Command Line Interface. • DVT-3728 Unexpected token error reported on module when using -cuname • DVT-3749 Unexpected switches passed to dvt_cli.sh are treated as arguments of the last known switch. See Command Line Interface • DVT-3778 dvt_cli.sh should detect locked workspaces and die quickly and gracefully. See Command Line Interface • DVT-3846 Syntax error due to multiple declaration of signals for refactor connect ports • DVT-3922 +define+ directives in default.build should not be visible across multiple invocations • DVT-3970 Improve the Instance Tree Top Items list by looking for instances inside Blocks • DVT-4008 Tooltip doesn't show package info for classes 3.1.16 (5 October 2012) Bugfixes • DVT-4026 Optimize workingset creation via dvt_cli.sh createProject / importProject • DVT-4029 Tooltips/hyperlink not working for ports of an array of module instances 3.1.15 (3 October 2012) Enhancements • DVT-4022 Support escaped quotes in build configuration files 3.1.14 (27 September 2012) Enhancements • DVT-3046 Linter waivers include functionality • DVT-3689 Added refactoring connect ability to specify the new port type Bugfixes • DVT-3977 Limit console log filters to match max. 8 consecutive lines and 256 characters per line for each error/warning message (customizable) (more details here) • DVT-3992 Platform freeze sometime after pressing text formatting button • DVT-4000 'Insert spaces for tabs' option no longer working correctly 3.1.13 (18 September 2012) © AMIQ 473 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-3965 One key indentation not working when "Insert spaces for tabs" preference is selected • DVT-3971 Outline view selected element is not revealed (scroll view) when linked with editor 3.1.12 (13 September 2012) Enhancements • DVT-3084 An easier way to copy the full path to the file in the editor (more details here) • DVT-3920 Improve duplicate error messages and debugability Bugfixes • DVT-3644 Refactor connect generates code inside comments • DVT-3779 Refactor connect issue when instance name and module name are the same • DVT-3782 Refactor connect issue when module name is any substring of the word "module" • DVT-3783 Refactor connect issue when instance name is any substring of the instantiated module name • DVT-3784 Refactor connect issue when connecting two instances of the same module generates ports that are positioned wrong • DVT-3785 Refactor connect issue when an instance is inside an if-block that is inside a forblock • DVT-3961 Refactor connect issue when instances or modules are inside a #ifndef-block • DVT-3956 When opening an auto-linked file from a run configuration console link it is opened as outside project • DVT-3957 Updated Clearcase plugin to latest to fix a compare from history bug • DVT-3962 Fixed default radix for OVM Field Editor • DVT-3963 Fixed OVM Field Editor adding default radix for UNSIGNED fields without user's explicit action • DVT-3964 Fixed OVM Field Editor event fields registration 3.1.11 (7 September 2012) Enhancements • DVT-3701 Directives for controlling file extension to Language Syntax mapping © AMIQ 474 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-3915 Internal builder logs - missing highlighting & hyperlinks • DVT-3928 When opening an auto-linked file through dvt_cli.sh it is compiled out of any context • DVT-3929 Content assist and hyperlink issues when using 'this' followed by a local (private) member (e.g. "this.local_member.some_API") • DVT-3932 Updated Clearcase Plugin to fix diff view problem 3.1.10 (1 September 2012) Enhancements • DVT-3638 Formatting option not to indent module content • DVT-3875 Updated Terminal plugin and added terminal colors in DVT themes • DVT-3887 Added launch configuration example for Questa on Windows (in uvm-1.1_ubus predefined project) • DVT-3901 Added support for non-standard goto repeat '[->' and non-consecutive repeat '[=' operators after non-boolean expressions • DVT-3916 Added indication for 'rand' class properties in HTML documentation Bugfixes • DVT-3137 Added exit to launch configurations interactive shell example to prevent throwing DVT in background • DVT-3272 Formatting module instance declaration the same way we format instance module declaration • DVT-3290 Formatting line wrapping skips lines ending with literals • DVT-3306 Formatting should indent `ovm_field*/`uvm_field* macros • DVT-3319 Formatting issue for vertical alignment • DVT-3346 Formatting region is not kept after format • DVT-3727 Formatting issue with '{}' between '()' • DVT-3807 Logger exceptions occur when restoring project rght after platform startup • DVT-3872 Unexpected char errors due to non-ASCII chars in build files • DVT-3873 For semantic errors, the file compile index should not be reported in the console • DVT-3878 Creating waiver from hit should include a message pattern © AMIQ 475 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3894 HTML Documentation - macro comments not visible • DVT-3897 Predefined macros for compatibility modes should not trigger warnings on user redefinition • DVT-3898 Whitespace after a no-value macro definition changes macro value (redefined warning issued) • DVT-3900 DVT_SV_ENABLE_MIXED_VERILOG_MODE=false doesn't work • DVT-3905 Fixed dvt_sv_lint_gui.sh deprecated argument parsing • DVT-3906 In a mixed project, incremental build on a VHDL or e-Language file multiplies Verilog semantic errors • DVT-3914 Fixed formatter bug when double bracket is closed • DVT-3918 Invisible Trace Ports tree item on Windows 3.1.9 (13 August 2012) Removed • DVT-2957 Removed SOLARIS release Features • DVT-3090 Added Terminal plugin to Linux and MacOS distros • DVT-3441 Updated statically compiled dot and used by default in Linux distos Bugfixes • DVT-3793 Wrong syntax error on macro using defines in the argument replacement • DVT-3848 Errors/warnings on file specified through multiple symlinks are reported as out of the project • DVT-3849 File specified through multiple symlinks is incrementally recompiled as out of the project after platform restart • DVT-3856 Restore defaults on Internal builder page not consistent with the defaults at project creation time • DVT-3858 Pulse control specparam triggers syntactic error 3.1.8 (7 August 2012) Enhancements • DVT-2898 Updated viPlugin build • DVT-3841 Updated all plugins in distribution © AMIQ 476 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-3831 Hyperlink from default.build opens files specified with paths going through symlinks as gray files (outside project) • DVT-3830 File specified through multiple symlinks is incrementally recompiled as out of the project • DVT-3840 Exception thrown when using preprocessing (`ifdef, `ifndef, etc.) auto-complete • DVT-3842 Fixed argument passing in deprecated scripts 3.1.7 (2 August 2012) Performance • DVT-3818 Move resolve duplicates (RD) and resolve type declaration on assign (RNA) on extended checks Enhancements • DVT-3606 See file compilation index when inspecting errors in the build console Bugfixes • DVT-3764 Obsolete syntax errors might re-appear on reapply waivers • DVT-3805 Exception when selecting a closed project in the DVT perspective while Types View is open • DVT-3806 Exception when selecting the Types View in the DVT perspective before restore is done • DVT-3807 Logger exceptions occur when restoring a project right after platform startup • DVT-3816 'do { ... } while (...);' loop syntax breaks the formatting • DVT-3821 Move Resource Filters UI to DVT Section in project properties • DVT-3822 Macro invocation breaks compilation when provided with wrong escaped identifier not ending with whitespace (e.g `some_macro(\escaped_id,second_param)) 3.1.6 (24 July 2012) Enhancements • DVT-3568 Cannot see class declared in a package imported by an imported package • DVT-3710 HtmlDoc NaturalDocs - add support for bullet, bold & definitions lists • DVT-3711 HtmlDoc NaturalDocs - add support for headings • DVT-3712 HtmlDoc NaturalDocs - add support for code, text diagrams & images © AMIQ 477 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3787 Abort linting if ruleset file has syntactic errors. Bugfixes • DVT-3768 Resource Filters - recursive symlinks not visible in UI • DVT-3769 Wrong syntax error - init packed array of structs 3.1.5 (11 July 2012) Enhancements • DVT-3747 Add support for custom location on toolbar for Run Configuration buttons Bugfixes • DVT-3757 Fixed "Connect Ports" button • DVT-3767 Fixed linter rerunning failed checks twice 3.1.4 (10 July 2012) Enhancements • DVT-3490 Ability to avoid full build when importing a project, by restoring from a saved snapshot • DVT-3717 Performance issue on checking and auto-declaring signals connecting module instances • DVT-3718 Added support for non-standard missing timing check limits on $setuphold() syntax • DVT-3725 Ability to specify custom per-project location for the DVT database with +dvt_db_location flag in default.build • DVT-3734 Changed linter rule IDs from OVM to XVM • DVT-3736 Removed linter user_prefs and default_prefs files and flags • DVT-3737 Added linter manual_checks_status.xml to store the status of manual checks from GUI(replaces user_prefs) • DVT-3738 Added linter user_notes.xml to store the user notes form GUI (replaces user_prefs) • DVT-3739 Deprecated linter flag -ovm_prefs and replaced it with -linter_preferences Bugfixes • DVT-3716 No incremental compilation on non-default extensions even if file associations and content types are properly set © AMIQ 478 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3719 False non-existing port when using '.port(expression)' declaration syntax • DVT-3731 Waivers are not applied at project restore • DVT-3735 Fixed linter gen_rulepool_doc for UVM with -uvm flag • DVT-3746 Fixed argument testing problem in dvt_sv_lint_gui.sh • DVT-3752 Macro replacement fail when provided arguments are strings and first string contains the second argument name 3.1.3 (2 July 2012) Enhancements • DVT-572 & DVT-3328 Added a linter preference for considering NOT_APPLIED as PASSED, ERROR or NOT_APPLIED • DVT-1321 Added Reapply Failed Checks button in Linter GUI • DVT-3389 Added search icon in the generated HTML documentation • DVT-3403 Linter preferences tab will be grayed out when the preferences file is not writable • DVT-3569 Added support for non-standard syntax: "for (++count; count < 10; ++count)" • DVT-3574 Show only files with errors in Compile Order View • DVT-3584 Trace port connections - extend functionality to trace through simple assignments • DVT-3588 Added progress dialog for Directory Files Listing widget (Custom Dialogs) • DVT-3615 Customize the "u_<module name>" module instance name when using content assist (auto-instance) • DVT-3634 Added server name and license count on DVT License Info Page Bugfixes • DVT-3150 Match begin - end for "property - endproperty" does not work • DVT-3416 Hierarchy View presents implicit constructor • DVT-3505 Tooltip and proposals not working when no explicit import package directive • DVT-3579 HAL Builder - errors and warnings from the external builder are not visible in the problems view • DVT-3609 Resource Filters Dialog - ignore a directory linked to one of its parents • DVT-3616 Internal error when using +dvt_env+<var> without assigning a value • DVT-3630 Should only invoke internal builder when asking for project rebuild © AMIQ 479 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3646 Fix parameter declaration for non-ANSI header for refactoring • DVT-3647 Fix parameter declaration for ANSI header for refactoring • DVT-3648 Fix code generation for ANSI header port and port direction for refactoring • DVT-3651 Remove class property 'NON_STANDARD variable dimension in constant declaration' to avoid inconsistency • DVT-3658 Internal builder preference "Restrict '*.v' and '*.vh' files to Verilog-2001 syntax" does not work when using .vlog_top_files • DVT-3670 Mark occurrences stop working on the first cursor change when repeatedly deleting a line • DVT-3674 Fix instance list for refactor connect • DVT-3676 Path wildcard not taken into account when using only '?' • DVT-3692 Resource filters & CLI: -excluded folder doesn't show up in project, but it shows as unexcluded in resource filters • DVT-3694 Hyperlink to `included file jumps to another file with same name • DVT-3702 dvt_cli.sh documentation errata: excludes managed by DVT's Resource Filters UI are only those specified by projectRelativePath 3.1.2 (15 June 2012) Enhancements • DVT-2907 Document Compile Waivers. • DVT-3488 Support translate_on and translate_off pragmas All Build Directives. • DVT-3542 VCS.vlogan compatibility mode - add +define+VCS to list of built-in defines • DVT-3543 Warn deprecated directive usage in build config files • DVT-3393 Added event 'triggered' property • DVT-3554 DVT sanity check - check for available space in .eclipse location instead of "home" • DVT-3583 Instance Tree View - ability to dump to file the list of autodetected top modules Bugfixes • DVT-3350 Refactor rename/reference search potential match when having multiline comment right next to the element • DVT-3571 Under FC15 OS the -s option of dvt_cli.sh does not suppress all messages © AMIQ 480 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3575 dvt_cli.sh script documentation does not work • DVT-3582 Dynamic shortcuts - icon path support for environment variables • DVT-3585 Dynamic shortcuts - rename Accelerator > Shortcut • DVT-3595 Quick hierarchy on function/task doesn't shows correctly the implementation in the children classes 3.1.1 (6 June 2012) Enhancements • DVT-2550 DVT CLI - ability to specify project-relative paths with -map argument • DVT-3489 dvt_cli.sh create*Project commands should pick up existing build config files if no build config flags are specified (e.g. -f, -top, -test) • DVT-3540 Automatically refresh .dvt folder at full build • DVT-3546 dvt_cli.sh should automatically infer hostname of the running DVT instance • DVT-3553 Updated predefined projects build command • DVT-3615 Customize the "u_<module name>" module instance name when using content assist (auto-instance) Bugfixes • DVT-3460 Misc. error logs bugfixes: vcs & specman • DVT-3544 Generating HTML doc. using DVT naturaldocs - misc bugfixes • DVT-3547 dvt_cli.sh excludes are not taken into account at the initial refresh • DVT-3548 Implicit wires are not defined on incremental build if +dvt_extended_checks +auto not specified • DVT-3549 Pre DVT 3.1 backward compatibility of +dvt_init+vcs.vlogan ordering • DVT-3550 Switching from .*_top_files to default.build and back does not work (nothing is compiled) 3.1 (1 June 2012) Features • DVT-1020 Add port to module from selected field • DVT-2363 Code Templates View • DVT-2450 Create new toolbar button & keyboard shortcut from run configuration (more details here) © AMIQ 481 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2914 Trace Port Connections across the design hierarchy • DVT-3158 Module Diagrams • DVT-3221 Logging and debug functionality for Linux/Unix • DVT-3348 Connect Instances Across the Design Hierarchy • DVT-3361 Resource filters wizard (more details here) • DVT-3362 Create linked resources wizard • DVT-3401 Add a FIXME comment for the unconnected ports generated by connect ports and add port functionality • DVT-3436 Added dvt_updater.sh script for install/uninstall/update operations • DVT-3437 Ability to control the Extended Checks execution • DVT-3451 Some errors might not be reported in default.build when multiple project natures are activated • DVT-3476 Sync DVT CLI usage in script / application / user guide • DVT-3497 Add Module Diagrams to HTML documentation Enhancements • DVT-571 Changed the icon for Reapply Linting in Problems View • DVT-606 Configurable source formatter • DVT-654 Module instance connection by port name signals an error if the port name doesn't exist • DVT-1034 Signal non-existent module port in instantiation • DVT-1884 Dedicated predefined external builders for OVM/UVM/VMM • DVT-2471 UVM 1.1 predefined templates • DVT-2476 Support for design libraries and library mappings • DVT-2902 Add support for -work -libmap -top +nctop flags in project configuration • DVT-2916 Add support for implicit wires • DVT-2951 Waivers with DISABLED status can be applyed on passing hits • DVT-2952 Added wildcard support for linter waivers • DVT-2955 Added overall score in HTML Report for linter checks and hits © AMIQ 482 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2965 Project config files - multiple selection in dialog with proposals for wildcards matching multiple paths • DVT-2980 Integration with Altera Quartus II • DVT-3010 References (Shift+Ctrl+G) do not work on $time, $stime, $realtime, $printtimescale and $timeformat system tasks • DVT-3020 Add implicit net declaration for continuous assigments • DVT-3021 Detect too many positional port connections for a Verilog instance • DVT-3041 Refactoring Rename- user must be forced to review the changes when potential matches • DVT-3061 Add semantic error on continuous assigns to undeclared nets if `default nettype is none • DVT-3165 Add support for +dvt_skip_ext+.ext • DVT-3196 Check implicit port connections in instantiation • DVT-3215 Formatting preference for indenting multiline comments • DVT-3235 HTMLDoc - Get module description from file header • DVT-3254 Set "Always launch the previously launched application" as default in distro • DVT-3259 Suppress dvt.bat terminal in Windows • DVT-3263 Added right click on hit to add code waiver • DVT-3264 Added one line waiver pragmas for linter • DVT-3292 Formatting preference for line wrapping parameters : "Leave as is" • DVT-3313 Ability to use "Open with" dvt.bat in Windows • DVT-3364 Added apply-on property for waivers to define the scope on which the status is applied • DVT-3422 Formatting should be undone in case code was deleted or added during the process • DVT-3443 Added build console preference in Preference -> General -> Appearance -> Colors and Fonts -> DVT -> Console • DVT-3469 Vertical alignment using comma as a token • DVT-3484 Added support for name attribute in ruleset tag used in generated ruleset documentation • DVT-3486 Added information about the waiver path in the Verissimo linting configuration dialog © AMIQ 483 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-2833 Formatting issue for fork ... join structure • DVT-2885 Formatter issue with task...endtask • DVT-2888 Formatting issue with randsequence • DVT-2967 False recurrence detected in instance tree • DVT-3012 Formatter issue with case using arrays • DVT-3043 Formatting issue with "while... begin .. end" • DVT-3044 Formatting issue for nested case statements • DVT-3062 Waive should create a single logical AND match clause using path and message • DVT-3074 Formatting issue with "initial begin ... end" • DVT-3148 Formatting issue for "end else begin" group • DVT-3149 Formatting issue for "if ... begin ... end " group • DVT-3155 Need to double-tab to indent an end(task|function|module...) from beginning of line • DVT-3216 Autoindent after newline gives the wrong indent • DVT-3219 Line indent is decreased for words starting with "end" • DVT-3236 Autocomplete protected task => detcetorp • DVT-3255 Typing end in block selection mode behaves strangely • DVT-3268 Formatting issue for "disable fork" • DVT-3284 The entity "nbsp" was referenced, but not declared - sn 11 / sn_eref.xml • DVT-3294 Formatting issue for case with escaped id • DVT-3295 Formatting issue for multiline comment on a single line • DVT-3296 Formatting issue for "if ... else ... if ... if ..." • DVT-3297 Formatting issue for "case : {...}" • DVT-3298 Formatting issue for casez, casex, randcase • DVT-3299 Formatting issue for "always if begin end" • DVT-3303 Formatting issue for loops with label © AMIQ 484 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3304 Formatting issue for "{...}" • DVT-3320 Formatting issue for "input ... sequence" • DVT-3321 Formatting issue for line wrapping params • DVT-3336 Issue with "do while (lit.getSomething(name))" • DVT-3345 Formatting issue for if block (without begin) containing only one block • DVT-3374 DVT Auto-linked update on rebuild doesn't work when linked resources are changed • DVT-3383 Hyperlinks and autocomplete for modport tasks don't work • DVT-3385 Rules ARAI, ARMI,ARDI, and ARSI should accept more than a single factory creation call per type • DVT-3404 Rules ARAI, ARMI,ARDI, ARSI, UVM30a, UVM20, UVM15a should skip virtual classes • DVT-3405 Rules "ARAD Active Agent Has Driver", "ARAS Active Agent Has Driver Sequencer" should skip virtual classes • DVT-3406 Rules "ARAD Active Agent Has Driver", "ARAS Active Agent Has Driver Sequencer" should consider inheritance • DVT-3407 Rules "ARAS Agent has sequencer" and "ARAD Agent had driver" fail when the sequencer field is a parameterized type • DVT-3425 Rules "ARDI Driver Instantiation" and "ARSI Sequencer Instantiation" should accept both "is_active" and "get_is_active()" conditional expressions • DVT-3434 Autoindent replaces tabs with spaces • DVT-3435 Formatter fails on case block with nested begin end blocks • DVT-3450 Recompute port connection semantic errors on incremental build • DVT-3467 Formatting preference for vertical alignment tokens is greyed out • DVT-3470 Vertical alignment fails for trailing single line comment • DVT-3495 Formatting issue : Line wrapping comments should not split multi line comments • DVT-3499 Formatting region should keep starting line indent as reference • DVT-3508 Renaming a modport: "Unexpected error while checking new name" • DVT-3509 "Stop Current Rebuild Job" doesn't work when "Build Automatically" is enabled Usability © AMIQ 485 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3418 Clarify description of rule "CHSC coreboard Support" • DVT-3331 Clarify description of rule "OVM30b Virtual Interface Connection in Agent" • DVT-3333 Clarify description of rule "ARIO Active and Reactive Components" 3.0.10 (23 May 2012) Bugfixes • DVT-3322 Fixed "See all available licenses" bug when license source contains multiple servers • DVT-3428 VCS error filter matches too much text for DFLT_OPT warning message • DVT-3459 Fixed a race condition in the license client 3.0.9 (16 May 2012) Bugfixes • DVT-3249 External Builder error decorations are not updated on incremental build • DVT-3372 +systemverilogext+; +verilog1995ext+; +verilog2001ext+ should accept multiple extensions separated by + • DVT-3431 Internal builder preference "Restrict '*.v' and '*.vh' files to Verilog-2001 syntax" does not work • DVT-3435 Formatter fails on case blocks with nested begin-end blocks 3.0.8 (9 May 2012) Enhancements • DVT-2739 Enable internal builder console should be default on • DVT-3214 Disable incremental compilation of big files should be default on • DVT-3240 Memory cleanup issues on successive project rebuilds • DVT-3367 Support for 'local::id' reference inside a foreach loop • DVT-3368 Support for non-standard 'typedef enum package_name::id {...}' • DVT-3369 Support for non-standard empty 'case endcase' (no case item) • DVT-3371 Improved (fast and low memory footprint) alghorithm for searching -y and -v libraries and libraries content • DVT-3392 Refresh "dvt_build.log" file when build is done Bugfixes © AMIQ 486 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2195 Using a recursive define '`define A A' hangs the parser • DVT-2262 Misc. external tools console log filters problems • DVT-3255 Typing end in block selection mode behaves strangely • DVT-3365 "What's New" and "Report an Issue" buttons are visible in other perspectives • DVT-3366 Project Templates uppercase - lowercase conversion bug • DVT-3370 Multiline comment in macro call arguments is not taken into account • DVT-3375 HtmlDoc not generated when module instance tree throws NullPointerException • DVT-3382 Diagram wizard takes too much time to open when tens of thousands of classes are available • DVT-3386 Wrong syntax error when declaring parameterized classes without a default specialization 3.0.7.9 (29 April 2012) Enhancements • DVT-3324 Hierarchical identifier in modport port declaration support (non-standard) • DVT-3325 Optional integer vector type or identifier before packed dimension in enum base type declaration support (non-standard) Bugfixes • DVT-3155 Need to double-tab to indent an end(task|function|module...) from beginning of line • DVT-3216 Autoindent after newline gives the wrong indent • DVT-3219 Line indent is decreased for words starting with "end" • DVT-3314 Wrong syntax error reported on sequence assertion variable declaration • DVT-3315 When changing the top files sometime the auto-linked folder is not properly updated on the first build • DVT-3327 In argument files, some flags don't consider their argument: -file, -cm, cm_libs, cm_line, cm_tgl • DVT-3330 Hyperlinks, tooltips and autocomplete for local tasks don't work inside the class 3.0.7.8 (24 April 2012) Enhancements © AMIQ 487 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3112 Ignore backslashes in command files • DVT-3121 Command files: support -flag "several arguments here treated as one" or -flag 'some args' • DVT-3215 Formatting preference for indenting multiline comments • DVT-3285 Support for non-standard `ifdef, `ifndef, `elsif followed by a macro with parameters (e.g. `ifdef `macro(4)) • DVT-3287 Support for non-standard unsized dimension in a module or interface parameter assignment • DVT-3307 New argument file flag: +dvt_disable_collect_actionblocks • DVT-3308 -cuname should trigger error on invalid package name • DVT-3309 -cuname is not reset at the end of argument file • DVT-3311 Syntax error markers are not displayed at full build after reaching the marker limits Bugfixes • DVT-3280 Autoinstance preserving ports order and comments fails for multiline comments • DVT-3268 Formatting issue for "disable fork" • DVT-3291 Non-ascii characters trigger errors in argument files (.*_top_files etc.) • DVT-3294 Formatting issue for case with escaped id • DVT-3295 Formatting issue for multiline comment on a single line • DVT-3298 Formatting issue for casez, casex, randcase • DVT-3299 Formatting issue for "always if begin end" • DVT-3300 Wrong undefined class semantic error reported on usage when the class is defined using 'typedef class name' • DVT-3301 The replacement of __FILE__ macro should contain quote e.g. "NA.v" • DVT-3302 Add from Template replaces __FILE__, __LINE__ with FILE, LINE. • DVT-3305 Ctrl+H isn't updated with the text selection in the editor 3.0.7.7 (13 April 2012) Enhancements • DVT-2586 Support for mixed languages in DVT_CLI © AMIQ 488 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2852 Verilog builder doesn't go through all topfiles when it encounters too many syntax errors • DVT-2986 Add -eclipsespace flag for dvt_cli.sh, alias -eclipse_area to -eclipsespace • DVT-3109 dvt_cli.sh without -f option doesn't create the .vlog_top_files • DVT-3113 Add support for -F for dvt_cli.sh • DVT-3117 Add support for -sverilog and +v2k flags • DVT-3168 Add to default list of known extensions: .a, .o, .cc • DVT-3186 Add support for -mfcu -cuname flags (define a package from a compilation unit) • DVT-3198 Non-standard construction: using parenthesis around primitive instantiation output and inout terminals • DVT-3199 Reduce memory consumption after project close/delete • DVT-3200 Reduce time for error dispatching algorithm • DVT-3201 Added more debugging info in console • DVT-3212 Add -force flag for dvt_cli.sh importProject (replace existing project with same name) • DVT-3228 dvt_cli.sh - remove constraint that the project directory should exist apriori; create if it does not exist • DVT-3270 Add support for +systemverilogext+<ex> +verilog1995ext+<ext> flags in .vlog_top_files +verilog2001ext+<ext> • DVT-3271 Add support for -extinclude flag in .vlog_top_files Bugfixes • DVT-2851 Toggle mark occurences triggers exception when the active editor is not a DVT editor • DVT-2995 Ctrl+H doesn't remember option selection • DVT-3203 Fixed multiple NullPoinerExceptions in parser • DVT-3211 Sequence method call not recognized as property expression • DVT-3226 Incremental build not working sometime when undeclared modules are found in the design • DVT-3229 Multiple scanning of the same library file if -v <libfile_path> specified multiple times in topfiles © AMIQ 489 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3238 Duplicate module error reported when using -y directives to files that define more than one unresolved module 3.0.7.6 (30 March 2012) Enhancements • DVT-3120 Support for non-standard syntax: $fatal("string with %d and %d", one, two) misses first argument that should be a number • DVT-3122 Support for non-standard syntax @this.EVT[ hierarchical.id ] • DVT-3145 Imbricated expressions slows down or even hangs the parser Bugfixes • DVT-2814 PDF doc links from training labs are broken • DVT-3013 Multiple selection dialog on -F hyperlink in top_files although only one file specified • DVT-3072 Total number of problems reported in console view is different than total in problems view • DVT-3074 Format issue with "initial @ begin ... end" • DVT-3076 __FILE__ and __LINE__ get in the way of project templates • DVT-3110 Console log errors are not properly hyperlinked • DVT-3119 Total number of errors in console varies after successive builds • DVT-3133 When creating a linked resource to a folder, the compiled sources contained in that folder should dissapear from auto-linked on next build • DVT-3134 Removed default activation of ClearCase action set menu (use Dro.amiq.dvt.showClearcaseActionSet=true) • DVT-3142 Sometimes semantic errors might be reported before syntax errors • DVT-3143 Formatting issue for line wrapping bit values • DVT-3144 Formatting issue for assert ... else block • DVT-3147 Formatting issue for "clocking ... @ ... endclocking" • DVT-3151 Formatting issue for "case default " • DVT-3152 Formatting issue with multi line comments • DVT-3171 Copy full path on linked resource/virtual folder does not work 3.0.7.5 (16 March 2012) © AMIQ 490 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-2795 Added an option for "Direct Associations" diagrams in HTML doc extraction (as collaboration is too cluttered) • DVT-2816 HTML Doc - show module instances with generate blocks as submodules • DVT-2817 HTML Doc - show functions and tasks within modules • DVT-2896 Added Cliosoft SOS plugin to distros • DVT-2992 DVT Project selector - shortcut (CTRL+SHIFT+Z) & simple list view of open DVT Nature projects • DVT-3060 HTML Doc - support .html files for 'Overview description file' • DVT-3073 Added JDT (Java Development Tools) plugin to distros • DVT-3074 Format issue with "initial @ begin ... end" Bugfixes • DVT-3059 HTML Doc - if 'user menu' is added, 'Finish' button is disabled • DVT-3063 Diagrams errors (dot executable invocation errors) during HTML Doc generation • DVT-3067 When adding new function arguments, module ports, class parameters the autocomplete shows them in the wrong order after incremental build • DVT-3070 New project from template - import all files under .dvt folder • DVT-3071 Fixed error when generating diagrams in a path with spaces 3.0.7.4 (8 March 2012) Enhancements • DVT-2997 Added Ctrl+Shift+A as duplicated key binding for "Toggle Block Selection Mode" • DVT-3049 Added "See available licenses" button in license page Bugfixes • DVT-3045 Trimming white space characters from license variables • DVT-3050 Fixed file license multiple initialization problem 3.0.7.3 (5 March 2012) Enhancements • DVT-2958 Added open dvt_build.log file build console button © AMIQ 491 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2959 Added cancel current rebuild job build console button Bugfixes • DVT-3029 Removed UseCompressedOops from 64 bits linux distros since it can cause segmentaion fault • DVT-3030 dvt.sh on MacOS doesn't invoke the right binary • DVT-3037 +dvt_keyword_set+<kwset> not working 3.0.7.2 (1 March 2012) Enhancements • DVT-2990 Add to "Compare with" menu the generic resource compare Bugfixes • DVT-3028 Fixed local license problem affecting a small set of features 3.0.7.1 (29 February 2012) Enhancements • DVT-2333 Added Glance plugin to distribution (incremental search in any view) • DVT-2535 Update Layers when opening a type with Quick Types View • DVT-2807 Search does not locate matches in unsaved files (when no incremental is done) • DVT-2981 Option to select where to save the build log file • DVT-2996 Ability to keyboard-collapse/expand the nodes in (quick) tree views using left/ right arrows Bugfixes • DVT-2833 Formatting issue for fork ... join structure • DVT-2885 Formatter issue with task...endtask • DVT-2888 Formatting issue with randsequence • DVT-2969 Splash and license settings validation sometimes start without using DVT functionality • DVT-2972 Refactoring a function/task etc. name doesn't modify the trailing identifier • DVT-2973 Refactoring a function name doesn't rename the implicit return variable • DVT-2974 Refactoring ports can break .* instantiations since it doesn't rename the local variables referenced in the .* assignment © AMIQ 492 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-3011 Wildcards in top files don't work under Windows • DVT-3012 Formatter issue with case using arrays • DVT-3014 Run configuration filters - ${file} var doesn't recognize Windows paths • DVT-3015 Preprocessing optimization issues when the defines are unset • DVT-3026 Updated ClearCase plugin to fix the NullPointerException 3.0.7 (13 February 2012) Features • DVT-48 Hyperlinks in argument files (.vlog_top_files, -f, etc.) • DVT-533 Setting system variables in DVT for full build • DVT-2312 Go to Next/Prev Problem • DVT-2903 Ability to specify project configuration for all languages in a single file • DVT-2906 Added Show Changed Preferences Dialog in Window menu Enhancements • DVT-1652 Compile Order View shows number of unique files (include may add duplicates) and skipped from optimized compilation • DVT-2419 Ability to use system variables in waivers • DVT-2453 Option to disable incremental build for large files • DVT-2455 Underscore "CamelCase"-like autocomplete for SV • DVT-2487 Sort problems in problems view by the creation time/reporting order • DVT-2514 Support for multiple DVT_PREDEFINED_PROJECTS system variables • DVT-2540 Added Javascript search in generated HTML documentation • DVT-2623 Show if a project has multiple natures & their names as a label decorator in navigator • DVT-2726 Highlight only the word when jumping to declaration • DVT-2750 Problems view - ability to right click and "Waive problems like this" • DVT-2753 Vertical alignment option should only align equivalent characters • DVT-2805 Show argument files (.f files) tree in console • DVT-2821 Option to change javadoc tags font color © AMIQ 493 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2831 Added visual feedback when running graphviz dot (UI is locked, dot errors not reported) • DVT-2832 Diagrams - ability to specify custom arguments for graphviz dot • DVT-2848 Allow waivers with no name • DVT-2856 Option to copy full path in Navigator • DVT-2857 Problems view - show extended help from right-click on problem (only nchelp supported) • DVT-2868 Rebuild triggers should be ignored if already building the project • DVT-2889 Jump to assignment instead of declaration • DVT-2891 OVM2: accept package_name::class_name as macro argument • DVT-2920 Unexpected token on bit[5] - non-standard construct • DVT-2924 Reapply waivers after Create Problem From waiver • DVT-2930 Dump build console output on disk • DVT-2925 Refine the problem waiving message reported in the Internal Builder console (explicitly specify waiving) • DVT-2938 & DVT-2934 Select top module - if more than 10 modules open a filtered selection list • DVT-2944 Limit max number of problem markers per problem category and severity to 1000 • DVT-2948 Report only first 20 errors in DVT Build Console and the total number of errors • DVT-2950 Show the instance scope in status bar Bugfixes • DVT-1606 HtmlDoc class constraints - "extern" not visible • DVT-2421 References for system tasks do not work • DVT-2352 Add $strobe, $monitor, $fopen, $fdisplay, $fstrobe $fmonitor and $fwrite in SV auto complete • DVT-2399 Do not show DVT_PATCH in macros view • DVT-2472 Autocomplete for .triggered does not work when sequence instance has arguments • DVT-2473 Autocomplete and hover for sampled value functions ($rose, $past, etc) doesn't work © AMIQ 494 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2475 Autocomplete for $display does not work inside initial statement • DVT-2485 Autocomplete and hover for random number system functions and methods doesn't work • DVT-2486 Autocomplete should not add () to sequence methods when they have no arguments • DVT-2559 Hyperlink and hover on cast expression do not work • DVT-2576 When creating a new file point out that the empty template can be customized just like any other • DVT-2742 Instance tree misc bug fixes • DVT-2748 Formatting the source sometimes makes the cursor jump to another position • DVT-2820 Case selection on enumerated types can’t autocomplete for the case item values • DVT-2892 Hyperlink on macro defined after the place where it is used inside another macro definition is not working • DVT-2893 OVM 30b - accept "this." in front of monitor or virtual interface field • DVT-2894 Syntax error when using direction, net and data type for module port • DVT-2913 Fixed deadlock on workspace when a new project is created • DVT-2926 Hyperlinks in project configuration files should open dialog with proposals for wildcards matching multiple paths • DVT-2936 Html Documentation 'getDeclarationFilePath()' exception • DVT-2923 Updating markers for 25K files with problems hangs the UI • DVT-2939 Fail to create auto-linked files for network mapped files in Windows • DVT-2949 New file wizard - new file's name changed to "new_file" 3.0.6.6 (23 January 2012) Bugfixes • DVT-2877 Several exceptions thrown when closing a project • DVT-2881 Crash on Windows platform when outline view linked with editor is active 3.0.6.5 (17 January 2012) Enhancements • DVT-2849 Accept and signal non standard construction: inside expression in constant expression © AMIQ 495 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2854 Ignore known extensions of other languages in top files file when +disable_ext is on; +disable_ext+all disables all extension checking • DVT-2865 Enhance problem management performance on full build Bugfixes • DVT-2855 $recovery should accept notifier, timestamp_condition, timecheck_condition, delayed_reference, delayed_data optional arguments • DVT-2859 Using defines for formatted 4'd`CM_MAX_NUM_INV_PORTS) numbers triggers false error (e.g. 3.0.6.4 (10 January 2012) Enhancements • DVT-2812 Added support for mixture of `" and " in the macro text Bugfixes • DVT-1709 Project Statistics freezes the GUI and cancel doesn't work • DVT-2809 Add to top files should make sure there's a newline before the appended filename • DVT-2810 Parse error on assert property (prop_name(alfa, (posedge(beta)))); • DVT-2813 Wrong report of undeclared macro in macro strings (e.g. `"`UNDECLARED`") • DVT-2844 Too many open files exception when loading 1000s of empty files 3.0.6.3 (27 December 2011) Enhancements • DVT-2352 Added $strobe, $monitor, $fopen, $fdisplay, $fstrobe $fmonitor and $fwrite in SV auto complete • DVT-2757 Added support for -file in .vlog_top_files • DVT-2802 Chance loading message for library files in console (e.g "scanning/loading library file") • DVT-2806 Improved recovery when missing macro definitions Bugfixes • DVT-2421 References for system tasks do not work • DVT-2399 Do not show DVT_PATCH in macros view • DVT-2472 Autocomplete for '.triggered' doesn't work when sequence instance has arguments © AMIQ 496 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2473 Autocomplete and hover for sampled value functions ($rose, $past, etc.) doesn't work • DVT-2475 Autocomplete for $display doesn't work inside initial statement • DVT-2485 Autocomplete and hover for random number system functions and methods doesn't work • DVT-2486 Autocomplete should not add () to sequence methods if they have no arguments • DVT-2559 No hyperlink and hover on cast expression • DVT-2680 Autocomplete inside xxx.randomize() with {...} block doesn't take into account the xxx scope • DVT-2697 UVM53 - accept calls for uvm_config_db#(uvm_object_wrapper)::set() instead of set_config_* • DVT-2776 Autolinked resources are no longer removed if autolink flag is unset • DVT-2783 Too many potential matches in a design, hyperlinks not working (usually ports on component instantiation) • DVT-2794 Deadlock when refreshing during a refactoring operation • DVT-2797 Right-click > Add to top files breaks lines on colon ':' character • DVT-2798 NullPointerException when warnings reported outside project • DVT-2800 Defines from -v compiled file are not seen by the -v compiled files that follows 3.0.6.2 (19 December 2011) Enhancements • DVT-2778 Added a black DVT Theme • DVT-2793 DVT_PREDEFINED_PROJECTS_TARGET predefined projects environment variable for Bugfixes • DVT-2777 Fixed DVT Theme selection dialog filter 3.0.6.1 (12 December 2011) Enhancements • DVT-2727 Search for references takes too much time on big environments (e.g. 20s for 5k files) • DVT-2740 Prepacked distro performance increased due to "-Xverify:none" vmarg © AMIQ 497 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2741 "Show heap status" activated by default in prepacked distros • DVT-2749 Adjust the error/warning message prefix to reflect the +dvt_keyword_set setting • DVT-2769 Parser performance issues when files containing preprocessing (`define, `ifdef) are included multiple times over big environments (over 5K files) Bugfixes • DVT-2702 DVT CLI ListCompiledFiles should skip library topfiles • DVT-2720 Issues on collecting the comments in SV modules, programs and interfaces • DVT-2735 Autocomplete doesn't always work when extending parameterized classes • DVT-2745 OVM/UVM field editor does not open • DVT-2747 Files not included in top files are compiled as Verilog (default must be SystemVerilog) • DVT-2762 External builder exception - Variable references empty selection • DVT-2763 Exception: Attempted to beginRule that does not match outer scope rule • DVT-2768 Formatter inserts multiple newlines on Windows 3.0.6 (1 December 2011) Features • DVT-642 Add .vlog_top_files support for multiple "instructions" on a single line like -y <path> +libext+.v +libext+.sv • DVT-1179 Support for wildcards *.v, *.sv etc. in top files Enhancements • DVT-517 Vertical alignment code formatting option • DVT-1248 Autoformat for preprocessing (ifdef, else, define etc) • DVT-1344 Code Formating - Preserve spacing on signal declarations, assignments etc. • DVT-1350 Do not allow tabs in the editor (copy/paste, using templates etc.) • DVT-1640 Format keyword "begin" on a new line or not • DVT-2179 Perform out of sync check before search and ask for refresh • DVT-2311 Preferences for autoinstance format (port connections and parameters alignment) • DVT-2330 Hyperlinks for progress log in Internal Builder Console © AMIQ 498 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2335 Filter for split ncsim messages in external tools console • DVT-2338 A drop-down list to select from top modules in the Instance Tree View • DVT-2391 Format - Option to preserve comment position if starting at index 0 • DVT-2400 Formatting of parameters : leave as is, each parameter on a new line, all parameters inline • DVT-2401 Formatting preference for line wrap • DVT-2402 Formatting preference for indenting preprocessing lines • DVT-2418 Parser performance improvement (memory footprint & speed) • DVT-2412 Full build console - show start/end of the compiled file • DVT-2449 New custom dialog - drop-down with files from a directory • DVT-2488 HtmlDoc - Automatically detect and apply JavaDoc/NaturalDocs formatting • DVT-2494 Prompt to save dirty files when launching the GUI linter • DVT-2496 Updating error/compiled/ignore properties on resources takes a long time • DVT-2500 Extended help for external builder logs (for IUS filters) • DVT-2532 Overwrite MALLOC_CHECK_=1 env variable to avoid crashes • DVT-2549 Exclude resources using DVT CLI at project creation • DVT-2563 Report reapply waivers time in DVT Build Console • DVT-2565 Optimize algorithm for solving workspace resources • DVT-2582 Expand/collapse all in Compile Order View • DVT-2605 Add +dvt_keyword_set+ switch in .vlog_top_files • DVT-2617 Support custom eclipse.ini in dvt_cli.sh • DVT-2644 Edit DVT Waivers button in Problems View (easy way to start a waivers file) • DVT-2647 Library search when using -y and -v improvements • DVT-2648 Add support for +librescan / -librescan flags in .vlog_top_files • DVT-2684 Changing the location of a file outside project requires 2 builds to correctly autolink the file Bugfixes • DVT-47 Format source fails after third 'assert' © AMIQ 499 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-50 Format source → indentation issue • DVT-1093 Format source issue when formatting regions • DVT-1723 Format source indentation issue after `uvm_ (format, autoindent) • DVT-2307 Console hyperlinks get opened with wrong editor • DVT-2370 False DUPLICATE_COVERPOINT on incremental build • DVT-2404 Removed the project context menu -> Source -> Format option that breaks .project • DVT-2408 Verilog formatting fails on "covergroup with function sample" • DVT-2474 Filter library code problems for NON_STANDARD check in OVM/UVM Compliance • DVT-2501 Remove duplicate top files algorithm is non-linear (thousands of top files lock the platform) • DVT-2502 Tool bar section title for "What's new" & "Report an issue" buttons • DVT-2537 Exception thrown when canceling a DVT Custom Dialog started by an external builder • DVT-2570 EmptyStackException in scope management when using linked resources and symlinks • DVT-2580 Insert tabs for spaces does not work after format (still uses spaces) • DVT-2581 Internal builder syntax warning checkbox not taken into account • DVT-2592 Open associated type hyperlink - module recognized as field • DVT-2609 Verilog Formatter inserts spaces when "Insert tabs for spaces" is disabled • DVT-2620 Rename 'include/import tree' & 'load order' to 'compile order' • DVT-2630 Fixed parser library scan for -y, -v, +librescan / -librescan flags • DVT-2700 Missing scroll bar on predefined projects list • DVT-2704 Wrong errors/warnings reported inside inactive "`ifdef ... `endif" code blocks 3.0.5.5 (21 November 2011) Bugfixes • DVT-2583 StackOverflowError in resolveOtherParams() • DVT-2585 Preprocessing identifier starts with numeral (e.g `define 1_TEST) © AMIQ 500 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2593 Files with unknown extensions are not ignored in .vlog_top_files • DVT-2598 Cannot create new native thread (OutOfMemoryError) after full build 3.0.5.4 (8 November 2011) Enhancements • DVT-2215 Option for dvt_cli.sh to import workspace settings • DVT-2372 Option for dvt_cli.sh not to exit when starting dvt.sh • DVT-2420 Autocomplete for a macro should automatically insert newline after the macro call only when the replacement also contains newline • DVT-2547 DVT CLI createProject - possibility to specify project name • DVT-2573 Ability to specify how long DVT CLI should wait for DVT to start (-timeout flag) Bugfixes • DVT-2572 DVT Build timeout preference cannot be set by dvt.ini 3.0.5.3 (17 October 2011) Enhancements • DVT-2454 Document how to expand aliases in run configurations and change default run command to interactive mode • DVT-2458 Save all dirty editors before launching a run configuration Bugfixes • DVT-2441 DVT does not accept (* probe_point *) in module input/output declaration • DVT-2460 Could not infer project from selection when there is selection but no focus • DVT-2495 Replace all in a large file takes a very long time • DVT-2499 NullPointerException in DVTMarkerFactory 3.0.5.2 (23 September 2011) Enhancements • DVT-2290 Rename "Generic" run configuration to "DVT Generic" Bugfixes • DVT-2315 Windows - duplicate module error when opening a topfile specified with full path and lowercase device ID © AMIQ 501 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2422 Long build occurs on repeated sequence_and_expression • DVT-2425 NullPointerException when warnings reported in files outside project • DVT-2427 Lexer error on `elseif without expression 3.0.5 (10 September 2011) Features • DVT-1852 Rebuild button for internal builder only • DVT-1979 DVT color theme support for editors and GTK widgets and a predefined "Dark" theme Enhancements • DVT-183 Open the OVM/UVM Field Editor on autocomplete in registration area • DVT-1182 System variables for External Builders • DVT-1966 Improved argument parsing for dvt_cli • DVT-2177 Hyperlink for jumping to the "associated type" of an element • DVT-2309 Enhance "Nothing to build" warning message (when rebuilding a project with no sources specified) • DVT-2314 Support for shortcuts for each rebuild kind (all/internal/external) • DVT-2336 Option to automatically save editors on rebuild Bugfixes • DVT-2168 Wrong order in Layers View (ancestors should be first) • DVT-2308 Add from template does not work in Windows • DVT-2310 Build Console does not close when closing a Project • DVT-2341 Add to top files - relative path problem in Windows ("\" -> "/") 3.0.4.4 (9 September 2011) Bugfixes • DVT-2366 Support for non-standard package scope used in foreach loop variables • DVT-2384 False DUPLICATE_VARIABLE error (wrong macro expansion) • DVT-2390 Parse error on sequence expression ##delay (CRS [ *1:$ ]) 3.0.4.3 (29 August 2011) © AMIQ 502 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-2210 Duplicate semantic errors for enum literals • DVT-2337 Refactoring: option to preserve name collisions on rename • DVT-2343 Autoinstance: prepend u_ to instance name • DVT-2344 Autoinstance: The parameters name should be copied into the connector, instead of the default value • DVT-2345 Autoinstance: module parameters each have their own line Bugfixes • DVT-2226 A macro defined in a file included several times should not be duplicated in autocomplete • DVT-2280 Support for non-standard 'cell' keyword used as identifier • DVT-2297 Search for references sometimes fails in symlinked files • DVT-2327 Module connection problem - false undeclared signal error when signal is declared inside a generate block • DVT-2342 Autoinstance doesn't work for computed params 3.0.4.2 (4 August 2011) Bugfixes • DVT-2267 Text placed under an inactive preprocessing block should not trigger syntactic errors 3.0.4.1 (3 August 2011) Bugfixes • DVT-2244 References/rename not working on symbolic link files that are linked resources in Eclipse • DVT-2256 Fixed problems related to readlink usage in Solaris scripts • DVT-2257 Changed "Xmx" memory settings to 1024m for 32bit and to 2048m for 64bit distros 3.0.4 (30 July 2011) Deprecated • DVT-2239 Scripts: eclipse.sh, run_gui_mode.sh, run_batch_mode.sh are marked for deprecation; use instead: dvt.sh, dvt_sv_lint_batch.sh, dvt_sv_lint_gui.sh © AMIQ 503 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Features • DVT-1134 Option to periodically save dirty editors Enhancements • DVT-72 Refactoring scripts do not perform automatic checkout when using rev. control • DVT-81 Refactoring potential matches - quick filter/(un)check all • DVT-1823 The methodology (ovm_*, uvm_*, vmm_* etc) code templates available as file content code templates • DVT-1858 Linter right click on hit or check to waive • DVT-2012 Refactoring scripts are not performing changes inside DVT Auto-Linked folder • DVT-2048 Run Configurations dialog/Quick Run working set filtering options • DVT-2064 HtmlDoc misc enhancements • DVT-2068 Hierarchy view - quick search for members • DVT-2086 Template parameters are proposed in the order from template.config • DVT-2088 Ability to choose a project template from $PREDEFINED_PROJECTS when creating a new project from template • DVT-2105 Enable tool-tips when 'ALT' key is pressed • DVT-2107 Preconfigured HAL external builder • DVT-2152 Quick Filter code templates by name in preference pages • DVT-2178 When rename refactoring has potential matches - warn in the first page of the wizard • DVT-2207 HtmlDoc assertions in modules, interfaces and programs • DVT-2219 Multiple defines on a single line top files support (e.g '+define +DEF_1+DEF_2+DEF_3') • DVT-2159 Show workspace location in title bar • DVT-2225 Support for 'x_parameter_id_x' templates • DVT-2231 Add HINT predefined task tag • DVT-2235 Show builder errors in console with hyperlink Bugfixes • DVT-2033 Macro expand and tooltip don't work after project restore © AMIQ 504 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2047 Project delete and click macros view pops up a NullPointerException • DVT-2106 Hover shows wrong macro comment on the first define if macro is redefined • DVT-2118 DVT CLI failed to open files in the default text editor • DVT-2119 Adding multiple files to ignore list only adds the first file in the list • DVT-2128 Quick function hierarchy jumps to wrong location • DVT-2133 Inconsistency between the algorithm that reports the UNDECLARED_MODULE issue and the one that computes the files to be compiled using -y and +libext directives • DVT-2162 Help > DVT Quick Help broken links fixed • DVT-2170 A macro defined in a file included several times should not be duplicated in Macros View • DVT-2180 No tooltip on queue size() predefined method when queue's type is a type parameter • DVT-2205 Verilog Quick Import View filtering does not jump to first match • DVT-2209 Custom Dialog File/Directory choosers fail to open if no "question" is specified 3.0.3.3 (22 July 2011) Enhancements • DVT-2081 dvt_cli.sh should also look for /bin/nc and /usr/bin/nc by default • DVT-2163 "table" used as an identifier, though it is reserved (accepted by some simulators) Bugfixes • DVT-2181 Potential matches are not reported in search/refactoring • DVT-2185 A tooltip with long non-whitespace sequences (1000s of characters) freezes the GUI 3.0.3.2 (14 July 2011) Bugfixes • DVT-2145 Avoid using resources in non-accessible state • DVT-2146 Close all editors when starting DVT with run_gui_mode.sh script to avoid having empty editors • DVT-2147 Accept non-standard construction: expression_or_dist between parentheses in constraint block © AMIQ 505 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-2155 Changed default initialization of preferences to avoid startup crashes in high load CPU scenario • DVT-2156 Fixed FlexLM Exception "ArrayIndexOutOfBoundsException" when using invalid license sources 3.0.3.1 (8 July 2011) Bugfixes • DVT-2084 Automatically DVT_LICENSE_FILE=FLEXLM infer DVT_LICENSE_VERSION when • DVT-2088 Ability to chose a project template from $PREDEFINED_PROJECTS when creating a new project from template • DVT-2123 Multiline comment inside macro definition • DVT-2134 Fixed "Internal FlexLM Error" after waking up from idle 3.0.3 (1 July 2011) Enhancements • DVT-1688 Switch for turning off tooltips • DVT-2067 Support for rawtokens lib (-y, -v, +libext+) included files Bugfixes • DVT-2009 Defined value missing in `define usage tooltip • DVT-2034 Refactoring/references does not work with multiple macro define/undefs • DVT-2035 Accept non standard construct attribute (* const integer foreign = "SystemC"; *); • DVT-2041 All preprocessing directives should accept 0 or more white-spaces between '`' and text (e.g "` ifdef A {};") • DVT-2065 Error when using multiline comment after number format (e.g. 32'h/ *ffff_ffff*/1324_5678) • DVT-2063 Flag integer packed arrays as non-standard 3.0.2.1 (27 June 2011) Bugfixes • DVT-2046 References - wrong indexing on incremental build when `include in the middle of a file 3.0.2 (17 June 2011) © AMIQ 506 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Enhancements • DVT-212 Added Eclipse Marketplace Client to distribution • DVT-254 Refactoring for functions and tasks should be performed in all superclasses/ subclasses • DVT-1485 Refactoring for constraints should be performed in all superclasses/subclasses • DVT-1657 Quick Types & Import Views - independent of editor • DVT-1909 Semantic search/references performance improvement • DVT-1922 Predefined Project Wizard - notify on IOException when copying files • DVT-1946 "file content" template kind available on autocomplete • DVT-1959 External tools console links jump to resources in current working set • DVT-1998 Run Configurations should show quoted arguments when printing the executed command • DVT-2010 Predefined project wizard - option to override target directory • DVT-2021 Updated linux JRE in distribution to version 1.6.0u26 to avoid compiler crashes • DVT-2022 DVT Custom Dialogs - when checkboxOnValue or checkboxOffValue are specified, checkbox output should not contain the id • DVT-2023 Updated Clearcase plugin to the latest version in distribution Bugfixes • DVT-1942 HtmlDoc misc bugfixes • DVT-1981 Questa 'Fatal' error filter added • DVT-1987 DVT fails to find modules/interfaces located in -v library files • DVT-1993 DVT CLI importProject takes project name from project folder instead of .project • DVT-2014 Capitalization of variables like __smallBigMedium__ when using template generation 3.0.1.1 (3 June 2011) Enhancements • DVT-1403 .vlog_top_files : -y -v demote to warning • DVT-1573 Quick run documentation • DVT-1870 Custom dialogs documentation © AMIQ 507 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-1811 Fixed editor macro expansion on expanding undeclared macros if selected together with defined macros • DVT-1696 Refactoring - 'Apply a refactoring script' typo • DVT-1874 Templates - Move these are global templates at the start of the dialog • DVT-1947 UVM/OVM field editor StackOverflowError • DVT-1948 Fixed parser error on parameter p = (0:1:2); • DVT-1954 Wrong "Number of macro instance parameters 1 not equal to macro define parameters 0" error reporting when parsing IUS xbus example • DVT-1956 Custom dialogs: SWT/XML Preview does not work for files outside of any project 3.0.1 (27 May 2011) Enhancements • DVT-1290 Signal undeclared wires as errors when `default_nettype is none • DVT-1383 Added parser support for optional compiler directives: `default_decay_time, `default_trireg_strength, `delay_mode_distributed, `delay_mode_path, `delay_mode_unit, `delay_mode_zero • DVT-1762 DVT Custom Dialogs - configurable output format • DVT-1763 DVT Custom Dialogs - support for Combo and List widgets • DVT-1830 DVT Custom Dialogs - allow freeform IDs • DVT-1778 Add support for createSVProject to DVT CLI • DVT-1827 HtmlDoc - add import/export dpi/dpi-c tag to dpi functions and tasks • DVT-1828 HtmlDoc - strike-through font for deprecated methods • DVT-1886 HtmlDoc - new navbar category with references to external documentation (index.html) • DVT-1888 Macro expansion for redefined macro/defines • DVT-1923 Hyperlink for redefined macro/defines jumps to wrong (last) location instead of the most recent definition before the use • DVT-1895 HtmlDoc - optional references to external doc index.html on navbar Bugfixes © AMIQ 508 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1738 Ask for project rebuild after changing comment extraction preferences • DVT-1739 Add 0 (zero) to default values of "Skip # lines above" combo box in comment extraction preferences • DVT-1820 HtmlDoc - default values for function arguments • DVT-1825 Refactoring for clocking blocks is not permitted • DVT-1882 HtmlDoc - broken links in diagrams fixed • DVT-1915 context.xml file added to help system 3.0.0 (13 May 2011) Features • DVT-1706 Add parser and views support for checker construct Enhancements • DVT-1587 New quick help menu added (Help -> DVT Quick Help) • DVT-1829 Added assert/assume/cover/restrict property in Outline View • DVT-1841 Requesting using uvm_*_param_utils on parameterized classes in UVM2, UVM5, UVM10 linter checks and ovm_*_param_utils on parameterized classes in OVM2, OVM5, OVM10 linterchecks checks • DVT-1846 Generate list of loaded files (and their directories) from DVT using the CLI • DVT-1850 Expand `if[n]def arguments if they are defined as macros (non-standard construct) • DVT-1867 Option to set the path to Emacs executable Bugfixes • DVT-1715 Remove lint configuration when the associated project is removed • DVT-1826 Refactoring allows renaming to same name if the text field is modified; the actual rename is done with garbage • DVT-1837 Override methods - add 'virtual' keyword for virtual functions • DVT-1840 Fixed parse error: clocking event in front of a property expression • DVT-1847 DVT viPlugin starts automatically with Eclipse activating DVT • DVT-1849 Erroneous macro expansion on macro call with macros as parameters 2.9.9.2 (6 May 2011) © AMIQ 509 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Features • DVT-1756 Added OEM viPlugin in the prepacked distribution and update site Enhancements • DVT-1618 & DVT-1735 Remove duplicate files from .vlog_top_file - made optional • DVT-1766 Added FlexLM IDLE Timeout • DVT-1810 Support non-standard construction - using select inside foreach index Bugfixes • DVT-159 Rules with DISABLED status are skipped in linter • DVT-1815 +define+ in top files is broken if "remove duplicate top files" is enabled in internal builder preferences 2.9.9.1 (4 May 2011) Enhancements • DVT-1655 HtmlDoc - Hide internal signals of an interface in the HTML documentation • DVT-1813 Add .inc as default verilog extension Bugfixes • DVT-1806 HtmlDoc - Tasks overview broken links fixed 2.9.9 (30 April 2011) Enhancements • DVT-112 Autocomplete: assign to a net is illegal in always blocks, do not show irrelevant signals • DVT-676 Semantic error on package import directly in a class scope • DVT-1433 New preference for auto-instance - preserve order of ports & comments • DVT-1440 External Tools - option to link to files from Console by short name • DVT-1571 New file wizard allows changing the templates parameters • DVT-1701 Expose -user and -configuration in eclipse.sh and other utilities • DVT-1737 User-defined primitive ports were added to Outline, Hyperlink, Content Assist • DVT-1729 Autoinstance for user-defined primitives added • DVT-1751 Add CSV editor to prepacked distribution © AMIQ 510 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1779 Add support for openFile to DVT CLI • DVT-1793 HtmlDoc - Support for the JavaDoc standard tag @param (instead of @arg). • DVT-1794 HtmlDoc - Option added: generate documentation only for API under the project root • DVT-1795 HtmlDoc - Linking with external documentation sources Bugfixes • DVT-159 Disable rule from waiver (not filtering the results) • DVT-1480 Fixed wrong parser error message when named port connection in module instance ends in a comma • DVT-1593 Fixed wrong references of a function declared without parentheses • DVT-1703 Correct code template: for a from b downto c step -1 => for a from b down to c • DVT-1750 Linter progress monitor shows different names 2.9.8 (15 April 2011) Features • DVT-960 & DVT-1397 & DVT-1697 JavaDoc and NaturalDocs (HTML documentation) • DVT-1497 User-defined dialogs for Run Configurations Enhancements • DVT-1455 Skip duplicate files in .topfiles (as physical path) • DVT-1543 Better progress reporting for Html documentation • DVT-1687 Add to Html documentation some user-defined links in navigation frame • DVT-1698 Added user-defined primitives to the internal dictionary, Types View, Outline, Content Assist, Instance Tree, Hyperlink and Layers view • DVT-1705 Added support for named generate blocks in hyperlink and content assist Bugfixes • DVT-1653 Show the kind of entity in tooltips for classes, modules, programs, interfaces • DVT-1662 Removed "***INFO Parsing library ..." messages in eclipse started console • DVT-1663 Show/hide internal builder console, should not require a rebuild • DVT-1665 Internal builder console activated on incremental compilation © AMIQ 511 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1671 Unable to use non-writable spelling dictionary • DVT-1722 Fixed parse error in more than two attribute instances 2.9.7.1 (1 April 2011) Enhancements • DVT-1389 Show module references in HTML documentation • DVT-1477 Content assist port proposals when instantiating an interface Bugfixes • DVT-1596 When function/task override by autocomplete cursor jumps to another part of the file • DVT-1602 Accept and signal non-standard construction static const in declaration outside classes • DVT-1605 Accept and signal non-standard placement of signing before data type in function declaration • DVT-1609 DVT_LICENSE_VERSION=1 not always shown in license not found pop-up 2.9.7 (25 March 2011) Features • DVT-546 FlexLM support • DVT-1173 Quick access to run configurations (Quick Run) • DVT-1591 Option to show internal compilation log in console Enhancements • DVT-1085 Linter license checking in GUI mode and option to wait (queue) for licence • DVT-1132 Internal builder options serialized in .dvt folder • DVT-1288 Class constraints in HTML Documentation • DVT-1351 Rebuild project using shortcut key (Ctrl + Alt + R) • DVT-1386 Interfaces and Modports in HTML Documentation • DVT-1435 OVM/UVM Field Editor - UVM_REFERENCE flag added • DVT-1439 OVM/UVM Field Editor - UVM_UNSIGNED by default for "bit", "reg", "logic", and other unsigned types • DVT-1498 Report an Issue - persistent user data and non-modal window © AMIQ 512 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1508 Exclude API from HTML Documentation based on path filters • DVT-1520 Added "*.sva" extension to default SystemVerilog files extensions list • DVT-1535 Accept non-standard construction: identifier followed by bit-select or part-select without parentheses in delays • DVT-1568 Switch to the new license features Bugfixes • DVT-1245 Non-standard semantic errors not shown in the linter • DVT-1366 UVM library in VCS does not work with the UVM preference page • DVT-1393 Strip off asterisks and start/end of comment (/****\ ... \****/) • DVT-1418 Dictionary not working with system variables • DVT-1425 Incremental performance degradation (memory) on big environments (~3000 types) • DVT-1456 Constructors can be referenced in the override menu • DVT-1496 DVT Auto-Linked should point to symlink instead of physical path when working with SOS database • DVT-1501 HTML Doc Generator only exports public class members • DVT-1503 Add from template - attribute name update in preview panel when duplicate file error • DVT-1505 Predefined Projects - IUS filters set by default • DVT-1512 Types Wiew Filter - Show UVM Types on last UVM version • DVT-1567 Content assist infinite loop if closing bracket has no corresponding open bracket e.g "list 0].^" • DVT-1580 Refactoring/references of _name triggers false possible matches for identifiers like some_other_name 2.9.6.9 (1 March 2011) Features Enhancements • Fixed UVM15b rule for UVM 1.0 • Removed SQPT statistic from UVM 1.0 (not anymore relevant since `uvm_sequence_utils macros are deprecated) © AMIQ 513 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com Bugfixes • DVT-1426 UVM-INFO filter fixed • DVT-1488 Content Assist constructor override 'return super.new()' not alowed 2.9.6.8 (26 February 2011) Features • DVT-560 Shortcut to select identifier at cursor (Shift + Alt + Up Arrow) • DVT-1073 Signal semantic warnings for non existing instantiated components Enhancements • Adjusted UVM Compliance checking for UVM 1.0 • DVT-1144 Added semantic checks for duplicate declarations of packages, modules, programs, interfaces, covergroups, events, module and interface instances, named blocks and typedefs • DVT-1280 Project Statistics optional full build before collecting information • DVT-1292 Show the module instance tree in the HTML Documentation • DVT-1391 Preference to control new lines before doc extraction • DVT-1393 Strip off asterisks and start of / end of comment • DVT-1395 Document structure fields in HTML Doc • DVT-1396 Document enum fields in HTML Doc • DVT-1476 Check for undeclared signals also in instances declared in interfaces Bugfixes • DVT-1387 Modules and Interfaces should not be associated with package "none" in HTML Documentation • DVT-1390 Doc extraction for comments on the same line • DVT-1415 UVM11 compliance check fails on uvm_ref_flow_1.01ea • DVT-1422 Parse error on 'const A a = new;' used in classes • DVT-1431 Single "report an issue" instance • DVT-1467 Comments are extracted erroneously on enums • DVT-1481 Assert comments are not collected © AMIQ 514 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1482 Hyperlink/tooltip/refactoring is wrong on assert having same name as a function • DVT-1484 Inline comment extraction doesn't work properly for function with arguments 2.9.6.7 (31 January 2011) Features Enhancements Bugfixes • DVT-1378 UVM_INFO filter fixed • DVT-1379 IUS Stacktrace filter fixed 2.9.6.6 (27 January 2011) Features • DVT-86 Override functions GUI • DVT-1166 Support for adding Template Components Enhancements • DVT-150 Report lining alive during long-running checks • DVT-944 Jump between macro parameters using tab when macro autocomplete is invoked (similar with function arguments) • DVT-1136 Change file permission dialog for refactoring • DVT-1279 Implement/override - autocomplete contribution • DVT-1280 Project Statistics performs a full build before collecting information • DVT-1297 Pack license status application in DVT release • DVT-1377 Ability to cancel linting during long-running checks • DVT-1384 Preferences for customizing the color of TODO markers • DVT-1385 New File Wizard - More New File Types - based on templates • DVT-1401 Non-standard syntax: solve a before b hard Bugfixes • DVT-67 Show only static functions/fields when calling members of a class using "::" operator • DVT-1183 Autocomplete for module ports should show ports only © AMIQ 515 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1262 Fixed unrecognized Questa error message (external builders) • DVT-1271 Editor changes file permission on RO file to 600 instead of preserving the permission for group and other • DVT-1302 Autocomplete auto-instantiate feature gives the option to change the parameter name, not the parameter value. • DVT-1330 Keywords should not appear in autocomplete after "." or "::" • DVT-1332 Calling macro with optional parameters issues error (not using the defaults) • DVT-1337 IUS filter set fixed • DVT-1349 Context completion doesn't work for enum encoding in a tertiary statement (conditional operator) • DVT-1353 Show autocomplete after macro name (e.g `some_define.some_item) • DVT-1356 Classes in generate blocks show type redef errors even when they are not in the same generated branch • DVT-1357 Module autoinstance fixed not to include parameters declared with localparam • DVT-1360 Refactoring scripts: specifying an element with package::type.element is broken • DVT-1361 Types defined under generate blocks not shown in types view • DVT-1374 Fixed wrong CIRCULAR_INHERITANCE error when the extended class has the same name but is in another package • DVT-1375 DVT Predefined projects: files should be made writable after copying in user location • DVT-1381 Symlinks in topfiles break error markers and open file from include tree • DVT-1402 "Unexpected token ," (comma) when using bit selection for ports in module declaration • DVT-1404 NC-Verilog_Builder pre-defined external builder filters not selected by default 2.9.6.5 (7 January 2011) Features • DVT-1128 Format code using external script Enhancements • DVT-73 Link from project specific Code Templates to configure global Code Templates • DVT-947 Label matching for 'ifdef A .... `endif // ifdef A' warning © AMIQ 516 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1167 Diagrams: select/deselect type from popup menu (right click) • DVT-1178 Rename filter set: Nc-Verilog to IUS • DVT-1273 Show non-existent paths in +incdir+ as warnings instead of errors • DVT-1278 Report an Issue: hardware info and summary field added • DVT-1306 Added predefined filter in Problems View for Linting Problems • DVT-1308 Disk space sanity check (min 10 MB of free space in user's Home folder) Bugfixes • DVT-1232 HTML documentation generator: don't show predefined members • DVT-1285 Diagrams: don't show predefined members 2.9.6.4 (18 December 2010) Features • DVT-1172 Use System Variables in linked resource path • DVT-1026 Report an Issue directly from DVT (new button in the toolbar) Enhancements • DVT-71 Collect project statistics should allow selecting collected statistics • DVT-1244 Specify where the duplicate was found when reporting redeclarations • DVT-1256 Support for non-standard 'checker' and 'restrict' keywords used as identifiers • DVT-1257 Concatenation and multiple concatenations performance issue • DVT-1260 Support for non-standard attribute instance (* integer foreign = "SystemC"; *); • DVT-1276 Collect project statistics should include hardware and system information • DVT-1246 New sv Project - faster realtime directory search Bugfixes • DVT-329 GUI linter debug mode (performance dump) not working • DVT-758 Search for references by method argument leads to hits in all methods with the same argument name • DVT-1135 Using 2 different revision of the same project in a workspace collision • DVT-1216 Fixed Solaris SPARC network filesystem bug by migrating to Eclipse Platform 3.6.1 © AMIQ 517 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1259 Symlink in INCDIR causes duplicate errors when opening an imported file • DVT-1266 Parsing error in primitive declaration • DVT-1230 Questa External Builder - 'missing vlib' error on full build command 2.9.6.3 (28 November 2010) Enhancements • DVT-1203 Added refresh tab to Generic Launch Configuration • DVT-1204 Added selected_resources_loc, selected_resources_name variables for run configurations selected_resources_path, • DVT-1146 Linter performance enhancements • DVT-1212 Rebuild lazy removes auto-linked files only if they are no longer needed Bugfixes • DVT-1177 Files auto-linked although in workspace when INCDIR is a symbolic link • DVT-1185 Disable auto-build timeout when build is triggered by the linter • DVT-1192 Builder triggers duplicate errors for fields, classes, etc. when SOS database element is checked out/in • DVT-1201 Added `suppress_faults, `nosuppress_faults predefined macros `enable_portfaults, `disable_portfaults, • DVT-1209 Internal dictionary corrupted after importing a previously deleted project 2.9.6.2 (23 November 2010) Enhancements • DVT-1193 Parser performance enhancements Bugfixes • DVT-1200 Fixed wrong reporting of UNDECLARED_SIGNAL 2.9.6.0 (17 November 2010) Bugfixes • DVT-1091 Added support for pure/extern constraint syntax • DVT-1112 Fixed wrong reporting of DUPLICATE_VARIABLE • DVT-1124 Layers view jump back to the selected element when scrolling down © AMIQ 518 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1141 Jump to pair backet in editor no longer working 2.9.5.9 (12 November 2010) Enhancements • DVT-132, DVT-241 Misc. Q&A updates • DVT-1041 No index.hml when exporting the HTML Lint Report Bugfixes • DVT-600, DVT-4 Fix annotation names in Annotations Preference Page 2.9.5.8 (5 November 2010) Features • DVT-974 Warning message if exclude directives are missing from eclipse.ini Enhancements • DVT-174 Added .flt extension to default Content Types (command file) • DVT-529 Refactor rename to something that already exists should not be allowed • DVT-589 Notify user on build timeout • DVT-614 Support for -F in .vlog_top_files with simlator specific compatibility modes. • DVT-961 Support for System Variables in New Project Wizard • DVT-1052 Added .comp extension to default Content Types (command file) • DVT-1054 Restart eclipse is needed after adding a new extension to Content Types Bugfixes • DVT-126 DVT checks out license at plugin activation instead of first feature used • DVT-932 Print executed command for launch configuration and external builder: printing is sometimes executed after run start • DVT-968 Doc generator wizard has a wrong button label (Browse Workspace instead of Browse Filesystem) • DVT-1018 No editor functionality available when opening a file with different (than standard) extension • DVT-1046 Bogus connections in inheritance diagrams • DVT-1047 References for methods don't have hits in all class hierarchy for classes situated in different scopes © AMIQ 519 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-1048 Comments are collected incorrectly on full build 2.9.5.7 (29 October 2010) Features • DVT-513 DVT Predefined Projects Enhancements • DVT-133 When adding Verilog nature, .dvt and .vlog_top_files are created with default content if they don't exist • DVT-294 When project has no top files, you can open '.vlog_top_files' for editing right from the warning dialog • DVT-765 New project wizard - mention how Top Files and INCDIR can be configured after the wizard is completed • DVT-766 Update documentation for OVM to UVM Migration • DVT-942 Show line numbers in editor by default Bugfixes • DVT-735 Internal builder semantic warning disable option not working • DVT-935 Multiline comment doesn't appear in generated documentation or tooltip • DVT-923 Solaris SPARC GTK crash in Navigator • DVT-993 External tools - console hyperlinks don't jump in source files with unknown contenttype • DVT-1014 Parser slowness related to casting type support for constant primary (see DVT-914) • DVT-1017 Autocomplete should not suggest anything after a number (or after a number followed by dot) • DVT-1022 Wrong UNDECLARED_SIGNAL in module instantiation when signal is declared inside a generate block or is returned by a function and when wildcard named port connections ( .*) is used 2.9.5.6 (26 October 2010) Bugfixes • DVT-914 Cast should accept constant expression as casting type • DVT-924 Recognize inner classes defined in a parent class © AMIQ 520 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • DVT-937 Wrong syntactic error reprort for case... default:/*comment*/ • DVT-938 Wrong non-exsiting class notification for nested classes • DVT-939 Accept multiple coverpoints on different array elements 2.9.5.5 (20 October 2010) Enhancements • Misc Documentation Updates Bugfixes • DVT-178 Project statistics filters • DVT-643 Ctrl+PgUp/Ctrl+PgDn navigation between editors gets stuck at the diagram editor • DVT-762 Wrong parser error on :/* • DVT-763 Module parameters without parens 2.9.5.4 (11 October 2010) Enhancements • Linter: • OVM/UVM Rule PKLD • Rule CHEX - check only concurrent assertions and excpects • DVT-11 Print executed command for launch configuration and external builders Bugfixes • Linter misc. bug fixes • DVT-13 External builder console content not shown after changing the build command • DVT-727 External tools NC-Verilog filter patterns do not support numbers in error ID • DVT-738 Signal an error if inside expression doesn't have {}, or has a range without [] • DVT-739 Signal an error if unsized dimension [] is used as a packed dimension outside a DPI import 2.9.5.3 (4 October 2010) Enhancements • DVT distribution release includes "DVT SV Language User Guide" PDF © AMIQ 521 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • Linter: • Added ruleset kind specific icons in Linter GUI • Added Export to HTML support for different rulesets (subtitle, browser icons, descripton) Bugfixes • DVT-672 Search for macro declaration without including layers returns no results • DVT-685 UVM Compliance category "UVM-SV Specific" typo 2.9.5.2 (1 October 2010) Features • Generic Linter Framework • UVM Compliance Checking Enhancements • Linter: • Added support for simple regular expressions in waivers message pattern • Added pragma waivers (code waivers) • OVM/UVM Rule PKVD • OVM/UVM Rule PKFN • OVM/UVM Rule PKVR • OVM/UVM Rule DCDC • OVM/UVM Rule DCRN Bugfixes • DVT-640 External library (-y) search, sort candidates using +libext+ order • DVT-641 Search for the unresolved references of the modules compiled from library • DVT-652 Folding issue for export "DPI" • DVT-659 Console hyperlink detection using working directory • DVT-664 Support for `begin_keywords "1800-2005" 2.9.5.1 (27 September 2010) Enhancements © AMIQ 522 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • Added semantic checks for duplicate declarations of classes, functions, tasks, fields, parameters, function arguments, covergroup arguments, coverpoints, covercrosses, struct and union members • Added additional assertion templates • OVM Compliance Standard Checks • Rule OVM2 - exclude macros check in virtual classes • Rule OVM5 - exclude macros check in virtual sequences • Rule OVM6 - exclude the body() method check in virtual sequences • Rule OVM8 - exclude the super.pre_body() and super.post_body() calls check in virtual sequences Bugfixes • DVT-656 Autocomplete issue when parameterized classes follow • DVT-678 Accept `ifdef, `else, `endif on the same line • DVT-679 Accept the third parameter of $width() as optional • Accept timeunit and timeprecision in program construct • Fix wrong warning signaling when a parameter is used for module instance port binding • Fix for unresolved components references in library • Fix for symbolic link files pointing to SOS database 2.9.4 (14 September 2010) Features • What's new in DVT? button for quick online access to this page • Auto-linked resources • Rename refactoring • Refactoring scripts • Added run_dvt_from_rawtokens.sh script for creating and opening a DVT project from raw tokens file • OVM Compliance reports hits in the Problems View • Project statistics Enhancements © AMIQ 523 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • OVM Compliance also reports non-standard SV constructs • VMM project property page supports vmm.sv directly under $VMM_HOME • Report semantic error if a function is implemented outside a class but not declared as external • OVM2UVM migration - support for UVM-1.0ea kit • Project-level code templates • eclipse.sh script can import settings from another workspace • eclipse.sh script can import an existing DVT project • License server releases license when client disconnects • Hierarchy and Instance Tree views show instructions when content is empty • Multiple selection support for 'Add to top files' in navigator right-click menu • Generic launch configurations can infer Project & Working directory from navigator selection • Sharable settings for HTML documentation wizard • Automatic instantiation of modules sorts ports as in/out/inout • Misc parser enhancements • Misc performance enhancements Bugfixes • OVM Compliance Waivers GUI is now working properly in KDE • External builders not called when invoking OVM Compliance • .vlog_top_files supports +define+ without value specified • .vlog_top_files does not take into account anymore the order of +defines • Semantic search reports method references in all object-oriented hierarchy • HTML documentation wizard displays multi line comments 2.9.3 New features: • UVM Smart Log • UVM Field Editor © AMIQ 524 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • UVM Code Templates • OVM to UVM Migration • Misc bug fixes. 2.9.2 • Custom defines • OVM Smart Log • Misc bug fixes. 2.9.1 • Misc bug fixes. 2.9.0 • Misc bug fixes. 2.8.9 • OVM Field Editor. • Emacs Automation. • New templates for OVM and SystemVerilog constructs. • Custom Task Tags. • Misc bug fixes. 2.8.8 • Misc bug fixes. 2.8.7 • Misc bug fixes. 2.8.6 • Highlight for Inactive Preprocessing. • Semantic Warning for Undeclared Ports (modules mapping). 2.8.5 • Inline Expand/Collapse Macros. • Hot fix for Instance Tree View (infinite loop). © AMIQ 525 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com 2.8.4 New features: • Macros View. • OVM and VMM project preference pages. • Performance improvements. • Misc bug fixes. 2.8.3 • OVM Compliance Review enhancements. 2.8.2 • OVM Compliance Review automate some of the manual checks. • Misc bug fixes (support for OVM 2.0.3). 2.8.1 • Misc bug fixes. 2.8.0 • Misc bug fixes. 2.7.0 New features: • OVM Compliance Review checks list updated according with the OVM Word published list. • Misc bug fixes. 2.6.0 New features: • Class Diagrams. See Class Diagrams. • HTML Documentation diagram support. • Smart Log. See Smart Log. • VMM Smart Log. See VMM Smart Log. • Semantic checks for types. • Label mismatch warning for ifdef/ifndef ... endif directives. See Tips and Tricks. • Added history and revision control compare editors highlight. © AMIQ 526 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • Added customizable template for new "Verilog File" content. • Support to add -f files to top files on right click Add to Top Files. 2.5.0 New features: • OVM Compliance Review. See OVM Compliance. • Export HTML Documentation. See Export HTML Documentation. 2.4.0 New features: • Highlight matching begin - end, function - endfunction etc. on double click. • Console hyperlinks by filters in Generic Launch Configuration. See Run Configurations. • Support for +incdir+<path> , -incdir <path> , +define+<DEFINE> , -define <DEFINE>, -v <path>, -y <path>, +libext+<suffix> in Top Files. • Support for defines at the project level. Useful when invoking 3rd party (Project Properties -> Verilog Language -> DEFINE). • Fixed '//' comment handling in macro invocation parameters. 2.3.0 New features: • To specify Top Files, INCDIR etc. you can also directly edit the corresponding files <project_dir>.dvt/.vlog_top_files, <project_dir>.dvt/.vlog_inc_dir etc. and use: • -f <file_name> • system variables • absolute paths • comments (//,--,#) • You can browse and search 3rd party documentation directly from Eclipse. See External Documentation. • You can build a project using 3rd party compilers. See External Builders. • You can create and use project templates. See Project Templates. • Hyperlink enhancements (F3 works on imports, preference to jump to first implemented layer). © AMIQ 527 Rev. 3.5.32 DVT SystemVerilog IDE Chapter 36. What is New? www.dvteclipse.com • Semantic search enhancements (show the match line, cover groups, layers handling). • Added filter to Types View. • Added VlogDT Builder preferences. • Added context sensitive help support. See Tips and Tricks. • SystemVerilog parser and dictionary enhancements. • Misc bug fixes and performance improvements (linked resources in top files and hyperlinks, context detection). 2.0.0 New features: • SystemVerilog parser and dictionary enhancements (class templates, parameters, ports etc.). • Misc bug fixes and performance improvements (refresh, building). 1.5.0 New features: • Misc bug fixes and performance improvements. 1.4.0 • First version. © AMIQ 528 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 37. How to Report an Issue? You can send an issue report using Report an Issue tool from the toolbar or Help menu. Fill in the required data (identification data and issue description) and add screenshots or other files you consider relevant. You can send the report via e-mail (Internet connection required) or save it as .zip and send manually to [email protected] [mailto:[email protected]]. Thank you! © AMIQ 529 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 38. Legal Notices Copyright © 2005-2014 AMIQ EDA s.r.l. (AMIQ). All rights reserved. License: This product is licensed under the AMIQ's End User License Agreement (EULA). Trademarks: The trademarks, logos and service marks contained in this document are the property of AMIQ or other third parties. DVT™, eDT™, VlogDT™, VhdlDT™, Verissimo™, Specador™ are trademarks of AMIQ. Eclipse™ and Eclipse Ready™ are trademarks of Eclipse Foundation, Inc. All other trademarks are the property of their respective holders. Restricted Permission: This publication is protected by copyright law. AMIQ grants permission to print hard copy of this publication subject to the following conditions: 1. The publication may not be modified in any way. 2. Any authorized copy of the publication or portion thereof must include all original copyright, trademark, and other proprietary notices and this permission statement. Disclaimer: This publication is for information and instruction purposes. AMIQ reserves the right to make changes in specifications and other information contained in this publication without prior notice. The information in this publication is provided as is and does not represent a commitment on the part of AMIQ. AMIQ does not make, and expressly disclaims, any representations or warranties as to the completeness, accuracy, or usefulness of the information contained in this document. The terms and conditions governing the sale and licensing of AMIQ products are set forth in written agreements between AMIQ and its customers. No representation or other affirmation or fact contained in this publication shall be deemed to be a warranty or give rise to any liability of AMIQ whatsoever. © AMIQ 530 Rev. 3.5.32 DVT SystemVerilog IDE www.dvteclipse.com Chapter 39. Third Party Licenses The following software may be included in this product: • Eclipse Platform 3.8 and Eclipse Plugins ( see license [http://www.dvteclipse.com/ third_party_licenses/LICENSE_ECLIPSE.TXT]) • Java SE Runtime Environment (JRE) Version 7 ( see license [http://www.dvteclipse.com/ third_party_licenses/LICENSE_JRE.TXT]) • ANTLR v2 ( see LICENSE_ANTLR.TXT]) license [http://www.dvteclipse.com/third_party_licenses/ • FreeMarker ( see license LICENSE_FREEMARKER.TXT]) [http://www.dvteclipse.com/third_party_licenses/ • Graphviz ( see license LICENSE_GRAPHVIZ.TXT]) [http://www.dvteclipse.com/third_party_licenses/ • P4Eclipse ( see license DISCLAIMER_P4ECLIPSE.TXT]) [http://www.dvteclipse.com/third_party_licenses/ • SVNKit ( see license LICENSE_SVNKIT.TXT]) [http://www.dvteclipse.com/third_party_licenses/ • Cliosoft SOS ( see license README_CLIOSOFT_SOS.TXT]) [http://www.dvteclipse.com/third_party_licenses/ • viPlugin (DVT includes a version of Michael Bartl's viPlugin) © AMIQ 531 Rev. 3.5.32
© Copyright 2025