Commentary

This commit is contained in:
Wilson Snyder 2017-10-18 17:54:39 -04:00
parent 1372d62186
commit fbbbe4ec87

View File

@ -2466,6 +2466,13 @@ lint_restore*/. For example:
If SOME_WARNING was on before the lint_off, it will now be restored to on, If SOME_WARNING was on before the lint_off, it will now be restored to on,
and if it was off before the lint_off it will remain off. and if it was off before the lint_off it will remain off.
=item /*verilator no_inline_module*/
Specifies the module the comment appears in should not be inlined into any
modules that use this module. This is useful especially at the top level
module to reduce the size of the interface class, to aid compile time at a
small performance loss.
=item /*verilator no_inline_task*/ =item /*verilator no_inline_task*/
Used in a function or task variable definition section to specify the Used in a function or task variable definition section to specify the
@ -3899,6 +3906,12 @@ packages. ccache will skip GCC runs between identical source builds, even
across different users. You can use the OBJCACHE environment variable to across different users. You can use the OBJCACHE environment variable to
use these CC wrappers. use these CC wrappers.
To reduce the compile time of classes that use a Verilated module (e.g. a
top CPP file) you may wish to add /*verilator no_inline_module*/ to your
top level module. This will decrease the amount of code in the model's
Verilated class, improving compile times of any instantiating top level C++
code, at a relatively small cost of execution performance.
=item Why do so many files need to recompile when I add a signal? =item Why do so many files need to recompile when I add a signal?
Adding a new signal requires the symbol table to be recompiled. Verilator Adding a new signal requires the symbol table to be recompiled. Verilator