• Top
    • Documentation
    • Books
    • Boolean-reasoning
    • Projects
    • Debugging
    • Std
    • Proof-automation
    • Macro-libraries
    • ACL2
    • Interfacing-tools
    • Hardware-verification
      • Gl
      • Esim
      • Vl2014
      • Sv
      • Fgl
      • Vwsim
      • Vl
        • Syntax
        • Loader
        • Warnings
        • Getting-started
        • Utilities
        • Printer
        • Kit
          • Vl-lint
            • Vl-lintconfig-p
            • Condcheck
            • Lint-warning-suppression
            • Lucid
              • Typo-detection
              • Vl-lucid-dissect-pair
              • Vl-lucidstate
                • Vl-lucidstate-p
                • Vl-lucidctx
                • Vl-lucidstate-fix
                • Vl-lucidval
                • Vl-lucidocc
                • Vl-lucidkey
                • Vl-lucidstate-equiv
                • Make-vl-lucidstate
                • Vl-lucidstate->warnings
                • Vl-lucidstate->modportsp
                • Vl-lucidstate->generatesp
                • Vl-luciddb-count
                • Change-vl-lucidstate
                • Vl-lucidstate->paramsp
                • Vl-lucidstate->db
                • Vl-lucidocc->ctx
                • Vl-lucidocc->ss
                • Vl-luciddb
                • Vl-lucidocclist
                • Vl-lucidkeylist
              • Vl-lucid-dissect-var-main
              • Vl-lucidstate-init
              • Vl-lucid-check-uses-are-spurious-instances
              • Vl-hidslice-mark
              • Vl-namedarglist-lucidcheck
              • Vl-lucidst-mark-modport
              • Vl-lucid-multidrive-detect
              • Vl-namedarg-lucidcheck
              • Vl-lucid-filter-merges
              • Vl-hidsolo-mark
              • Vl-arguments-lucidcheck
              • Vl-lucid-dissect-database
              • Vl-design-lucid
              • Vl-maybe-delayoreventcontrol-lucidcheck
              • Vl-lucid-valid-bits-for-datatype
              • Vl-delayoreventcontrol-lucidcheck
              • Vl-repeateventcontrol-lucidcheck
              • Vl-namedparamvaluelist-lucidcheck
              • Vl-scopeexprlist-mark-solo
              • Vl-plainarg-lucidcheck
              • Vl-maybe-rhsexprlist-lucidcheck
              • Vl-maybe-paramvalue-lucidcheck
              • Vl-paramvaluelist-lucidcheck
              • Vl-namedparamvalue-lucidcheck
              • Vl-maybe-gatedelay-lucidcheck
              • Vl-plainarglist-lucidcheck
              • Vl-lucidstate-mark
              • Vl-lucid-mark-simple
              • Vl-eventcontrol-lucidcheck
              • Vl-enumitemlist-lucidcheck
              • Vl-delaycontrol-lucidcheck
              • Vl-paramvalue-lucidcheck
              • Vl-paramargs-lucidcheck
              • Vl-maybe-rhsexpr-lucidcheck
              • Vl-maybe-range-lucidcheck
              • Vl-lucid-typo-detect1
              • Vl-gatedelay-lucidcheck
              • Vl-evatomlist-lucidcheck
              • Vl-rangelist-lucidcheck
              • Vl-pps-lucidstate
              • Vl-enumitem-lucidcheck
              • Vl-custom-suppress-multidrive-p
              • Vl-evatom-lucidcheck
              • Vl-rhs-lucidcheck
              • Vl-range-lucidcheck
              • Vl-lucidocclist-drop-bad-modinsts
              • Vl-hidtrace-mark-interfaces
              • Vl-hidstep-mark-interfaces
              • Vl-add-typo-candidate
              • Vl-paramdecl-lucidcheck
              • Vl-interfaceportlist-lucidcheck
              • Vl-interfaceport-lucidcheck
              • Vl-fundecl-lucidcheck
              • Vl-design-lucidcheck-main
              • Vl-taskdecllist-lucidcheck
              • Vl-taskdecl-lucidcheck
              • Vl-portdecllist-lucidcheck
              • Vl-paramdecllist-lucidcheck
              • Vl-package-lucidcheck
              • Vl-modinst-lucidcheck
              • Vl-interfacelist-lucidcheck
              • Vl-gateinstlist-lucidcheck
              • Vl-dpiimportlist-lucidcheck
              • Vl-dpiexportlist-lucidcheck
              • Vl-vardecllist-lucidcheck
              • Vl-vardecl-lucidcheck
              • Vl-typedeflist-lucidcheck
              • Vl-portdecl-lucidcheck
              • Vl-packagelist-lucidcheck
              • Vl-modulelist-lucidcheck
              • Vl-modportlist-lucidcheck
              • Vl-modinstlist-lucidcheck
              • Vl-interface-lucidcheck
              • Vl-initiallist-lucidcheck
              • Vl-gateinst-lucidcheck
              • Vl-fundecllist-lucidcheck
              • Vl-dpiimport-lucidcheck
              • Vl-dpiexport-lucidcheck
              • Vl-assignlist-lucidcheck
              • Vl-alwayslist-lucidcheck
              • Vl-typedef-lucidcheck
              • Vl-modport-lucidcheck
              • Vl-initial-lucidcheck
              • Vl-finallist-lucidcheck
              • Vl-assign-lucidcheck
              • Vl-always-lucidcheck
              • Vl-aliaslist-lucidcheck
              • Vl-module-lucidcheck
              • Vl-lucid-typo-detect
              • Vl-final-lucidcheck
              • Vl-alias-lucidcheck
              • Vl-lucidocclist-drop-foreign-writes
              • Vl-lucid-pp-multibits
              • Vl-lucid-slices-append-bits
              • Vl-scopestack-is-portdecl-p
              • Vl-lucid-valid-bits-for-decl
              • Vl-lucid-resolved-slices->bits
              • Vl-lucid-resolved-slice->bits
              • Vl-lucid-instmod-find-port-dir
              • Vl-custom-suppress-multidrive-p-default
              • Vl-lucidmergealist-count
              • Vl-lucid-scopestack-subscope-p
              • Vl-lucid-range->bits
              • Vl-lucidocclist-drop-initials/finals
              • Vl-lucid-collect-solo-occs
              • Vl-lucid-collect-resolved-slices
              • Vl-basic-lucidctx
              • Vl-scopestack->flat-transitive-names-slow
              • Vl-lucidocclist-drop-generates
              • Vl-lucid-dissect
              • Vl-lucid-first-solo-occ
              • Vl-lucid-do-merges1
              • Vl-lucid-do-merges
              • Vl-lucidocclist-remove-tails
              • Vl-lucid-some-solo-occp
              • Vl-scopestack-top-level-name
              • Vl-normalize-scopestack
              • Vl-lucid-resolved-slice-p
              • Vl-lucid-all-slices-resolved-p
              • Vl-lucid-warning-type
              • Vl-lucid-plainarglist-nicely-resolved-p
              • Vl-lucid-multidrive-summary
              • Vl-string-expr->value
              • Vl-scopestack->topname
              • Vl-pp-lucid-multidrive-summary
              • Vl-lucid-all-slices-p
              • Vl-lucidocclist-some-transistory-p
              • Vl-lucidocc-transistory-p
              • Vl-lucid-plainarg-nicely-resolved-p
              • Vl-inside-true-generate-p
              • Vl-possible-typo-warnings
              • Vl-lucid-z-gateinst-p
              • Vl-lucid-modinst-nicely-resolved-p
              • Vl-inside-interface-p
              • Vl-inside-blockscope-p
              • Vl-typocandidates
              • Vl-lucid-z-expr-p
              • Vl-lucid-z-assign-p
              • Vl-lucidmergealist
              • Vl-lucid-summarize-bits
              • Vl-pp-merged-index-list
              • Vl-pp-merged-index
              • Vl-lucid-pp-bits
            • Lvaluecheck
            • Vl-interfacelist-alwaysstyle
            • Truncation-warnings
            • Vl-modulelist-alwaysstyle
            • Skip-detection
            • Vl-lint-report
            • Vl-lintresult
            • Vl::vl-design-sv-use-set
            • Oddexpr-check
            • Leftright-check
            • Duplicate-detect
            • Selfassigns
            • *vl-lint-help*
            • Arith-compare-check
            • Dupeinst-check
            • Qmarksize-check
            • Lint-whole-file-suppression
            • Run-vl-lint-main
            • Logicassign
            • Run-vl-lint
            • Vl-print-certain-warnings
            • Duperhs-check
            • Vl-lint-top
            • Sd-filter-problems
            • Vl-modulelist-add-svbad-warnings
            • Vl-module-add-svbad-warnings
            • Check-case
            • Vl-lint-extra-actions
            • Drop-lint-stubs
            • Vl-lint-print-warnings
            • Drop-user-submodules
            • Check-namespace
            • Vl-lintconfig-loadconfig
            • Vl-lint-design->svex-modalist-wrapper
            • Vl-delete-sd-problems-for-modnames-aux
            • Vl-collect-new-names-from-orignames
            • Vl-lint-print-all-warnings
            • Vl-design-remove-unnecessary-modules
            • Vl-delete-sd-problems-for-modnames
            • Vl-always-check-style
            • Vl-vardecllist-svbad-warnings
            • Vl-vardecl-svbad-warnings
            • Vl-reportcard-remove-suppressed
            • Vl-reportcard-keep-suppressed
            • Vl-alwayslist-check-style
            • Vl-remove-nameless-descriptions
            • Vl-lint-apply-quiet
            • Vl-warninglist-remove-suppressed
            • Vl-warninglist-keep-suppressed
            • Vl-print-eliminated-descs
            • Vl-module-alwaysstyle
            • Vl-jp-reportcard-aux
            • Vl-interface-alwaysstyle
            • Vl-design-alwaysstyle
            • Vl-jp-description-locations
            • Vl-jp-reportcard
            • Vl-pp-stringlist-lines
            • Vl-jp-design-locations
            • Vl-datatype-svbad-p
            • Unpacked-range-check
            • Sd-problem-major-p
            • Vl-alwaysstyle
          • Vl-server
          • Vl-gather
          • Vl-zip
          • Vl-main
          • Split-plusargs
          • Vl-shell
          • Vl-json
        • Mlib
        • Transforms
      • X86isa
      • Svl
      • Rtl
    • Software-verification
    • Math
    • Testing-utilities
  • Lucid

Vl-lucidstate

State for the lucid transform.

This is a product type introduced by defprod.

Fields
db — vl-luciddb
Main database mapping keys to their use/set occurrences.
modportsp — booleanp
Should we issue warnings for modports? It generally will only make sense to do this before unparameterization has taken place, because unparameterization can change the names of interfaces and our argresolve handling drops the arg.modport stuff in a way that makes this too hard to handle.
paramsp — booleanp
Should we issue warnings for parameters? It generally will only make sense to do this before unparameterization has taken place, because unparameterization should generally get rid of any sensible parameters.
generatesp — booleanp
Should we include multidrive warnings in generates? It will generally only make sense to do this after unparameterization, because until then things like
if (condition) assign foo = 1;
                   else assign foo = 0;
may appear to be multiple assignments to foo, even though they never happen at the same time.
warnings — vl-warninglist

Subtopics

Vl-lucidstate-p
Recognizer for vl-lucidstate structures.
Vl-lucidctx
Info about a usage/setting of an identifier
Vl-lucidstate-fix
Fixing function for vl-lucidstate structures.
Vl-lucidval
Use/set information about a single variable.
Vl-lucidocc
Record of an occurrence of an identifier.
Vl-lucidkey
A single key in the lucid database.
Vl-lucidstate-equiv
Basic equivalence relation for vl-lucidstate structures.
Make-vl-lucidstate
Basic constructor macro for vl-lucidstate structures.
Vl-lucidstate->warnings
Get the warnings field from a vl-lucidstate.
Vl-lucidstate->modportsp
Get the modportsp field from a vl-lucidstate.
Vl-lucidstate->generatesp
Get the generatesp field from a vl-lucidstate.
Vl-luciddb-count
Change-vl-lucidstate
Modifying constructor for vl-lucidstate structures.
Vl-lucidstate->paramsp
Get the paramsp field from a vl-lucidstate.
Vl-lucidstate->db
Get the db field from a vl-lucidstate.
Vl-lucidocc->ctx
Vl-lucidocc->ss
Vl-luciddb
The main lucid database. Binds keys (scopestack/item pairs) to information about how they have been used.
Vl-lucidocclist
A list of vl-lucidocc-p objects.
Vl-lucidkeylist
A list of vl-lucidkey-p objects.