SpyGlass AdvancedLintRules Reference
SpyGlass AdvancedLintRules Reference
Disclaimer
SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE.
Trademarks
Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth
at http://www.synopsys.com/Company/Pages/Trademarks.aspx.
All other product or company names may be trademarks of their respective owners.
Third-Party Links
Any links to third-party websites included in this document are for your convenience
only. Synopsys does not endorse and is not responsible for such websites and their
practices, including privacy practices, availability, and content.
Synopsys, Inc.
690 E. Middlefield Road
Mountain View, CA 94043
www.synopsys.com
Report an Error
The SpyGlass Technical Publications team welcomes your feedback and suggestions on
this publication. Please provide specific feedback and, if possible, attach a snapshot.
Send your feedback to spyglass_support@synopsys.com.
Contents
Preface..........................................................................................7
       About This Book ...................................................................................... 7
       Contents of This Book ............................................................................. 8
       Typographical Conventions ..................................................................... 9
                                                                                                                v
                                                   Synopsys, Inc.
        av_enable_crpt ...................................................................................28
        av_flopcount .......................................................................................28
        av_force_soft_reset .............................................................................29
        av_ignore_preformal_run_time..............................................................30
        av_msgmode ......................................................................................30
        av_run_time .......................................................................................31
        av_seqdepth .......................................................................................32
        av_violation_count...............................................................................32
        buscompress.......................................................................................33
        ieffort.................................................................................................33
        audit ..................................................................................................35
        passfail ..............................................................................................35
        dead_code_scope ................................................................................36
        detect_assign_fsm ...............................................................................37
        detect_ifelse_fsm ................................................................................38
        detect_nested_fsm ..............................................................................38
        fv_dcode_all_inst.................................................................................39
        fv_parallelfile ......................................................................................40
        fv_debug_sim_cycles ...........................................................................42
        include_construct ................................................................................43
        reset_convention .................................................................................43
        resetoff ..............................................................................................44
        show_static_latches .............................................................................44
        solvemethod .......................................................................................45
        staticnet_scope ...................................................................................45
        propfile ..............................................................................................46
        modulelist...........................................................................................46
        scope .................................................................................................47
        vcdtime ..............................................................................................48
        vcdfile ................................................................................................48
        vcdfulltrace .........................................................................................48
        verbose ..............................................................................................49
        xassign_casedefault .............................................................................49
     Functional Constraints........................................................................... 51
        Impact of Constraints on Functional Analysis ...........................................51
        Specifying Functional Constraints ...........................................................52
        Over Constraint ...................................................................................52
     Properties Specification using OVL ........................................................ 53
        OVL Assertions Format .........................................................................53
        Constant Value Control Signals in OVL Assertions/Assumptions ..................57
        OVL Assertions in Combinational Circuits.................................................58
vi
                                             Synopsys, Inc.
         Separate File OVL Support .................................................................... 59
         Restrictions in Using OVL ...................................................................... 60
         Impact of Property and Constraint Modules ............................................. 60
         Processing Property and Constraint Modules ............................................ 61
      Property and Constraint Management ................................................... 63
         Property File Format ............................................................................ 63
         Property File Example .......................................................................... 65
         Property File Processing........................................................................ 65
         Enabling and Disabling Assertions .......................................................... 65
      Schematic Highlight and Cross Probing ................................................. 67
      Waveform Display and Cross Probing.................................................... 68
      The Complexity Browser ....................................................................... 69
         Configuring the Complexity Percentage................................................... 69
      Reports and Diagnosis Files in SpyGlass Auto Verify ............................. 72
         Auto Verify Central Report .................................................................... 76
         Auto Verify-FSM Report ........................................................................ 80
         Uninitialized_Sequential_Elements Spreadsheet Report............................. 81
         Av_staticreg02 Spreadsheet Report........................................................ 85
         The Av_complexity01 Spreadsheet Report............................................... 88
         Functional Analysis Report .................................................................... 93
         Overconstrain Info File ......................................................................... 98
         Property Status Reported during Functional Analysis ................................ 99
         Register Info Report........................................................................... 101
                                                                                                            vii
                                                 Synopsys, Inc.
            Av_sanity04 : Reports over-constraining in a design ......................... 146
            Av_svasetup01 : Setup issues in SVA constraints............................. 149
       Implicit Properties Rules ..................................................................... 151
            Av_bitstuck01 : This rule is deprecated .......................................... 152
            Av_staticnet01 : Reports globally stuck-at-0 or stuck-at-1 nets in a design.
                         153
            Av_bus01 : Reports all the bus contentions in a design...................... 159
            Av_bus02 : Reports all the floating buses in the design. .................... 164
            Av_case01 : Reports reachable case items that are not specified. ....... 169
            Av_case02 : Reports overlapping case items of the case statement that
                         have the parallel_case pragma or the unique modifier attached.
                         173
            Av_case03 : Reports overlapping case items of the case statement without
                         the parallel_case pragma attached. .................................. 177
            Av_deadcode01 : Reports redundant logic in the design. .................. 180
            Av_dontcare01 : Reports sensitizable X-assignments in the design..... 190
            Av_fsm_analysis : Reports FSM related issues in the design.............. 193
            Av_divide_by_zero : Reports divide/modulo by zero violation ........... 204
            Av_negative_shift : Reports arithmetic shift by negative value violations.
                         208
            Av_fsm01 : Reports unreachable or deadlocked states of an FSM........ 212
            Av_fsm02 : Reports the dead transition of an FSM. ........................... 221
            Av_range01 : Reports array bound violation. ................................... 227
            Av_setreset01 : Reports flip-flop with simultaneous active asynchronous
                         set and asynchronous reset ............................................. 231
            Av_staticreg01 : This rule is deprecated. ........................................ 236
            Av_staticreg02 : Reports static sequential elements in a design......... 237
            Av_syncfifo01 : Checks overflow and underflow of synchronous FIFOs in a
                         design .......................................................................... 246
       Standard Properties Rules................................................................... 253
            Av_ovl01 : Reports OVL checks in a design. ..................................... 255
       Must Rules........................................................................................... 257
            Av_license01 : Reports license failure............................................. 258
            Av_init01 : Reports initial setup issues of a design. ........................... 261
            Av_initseq01 : Initialization sequences of multiple signals should be of the
                         same length. ................................................................. 265
            Av_multitop01 : Reports a violation in case of multiple top-level design
                         units ............................................................................ 267
viii
                                              Synopsys, Inc.
           Av_sanity01 : Reports an error if there is any issue in the property file. ...
                    269
           Av_sanity02 : Reports nets that have multiple drivers ...................... 272
           Av_sanity06 : Reports issues found in the distributed computing flow . 274
           SGDC_av_meta_design_hier01 : Checks the presence of constraint
                    meta_design_hier .......................................................... 282
       SGDC_fsm_setup01..............................................................................284
Appendix:
SGDC Constraints ......................................................................339
       SpyGlass Design Constraints ................................................................340
                                                                                                          ix
                                                Synopsys, Inc.
x
    Synopsys, Inc.
       Preface
                                                                            7
                               Synopsys, Inc.
Preface
    Section                                Description
    Using the Rules in the SpyGlass Auto   Usage concepts and use model features, such as
    Verify Solution                        parameters
    Rules in SpyGlass Auto Verify          Various rules of SpyGlass Auto Verify solution
    The OVL Support                        About OVL support
    Appendix: SGDC Constraints             SGDC constraints used by SpyGlass Auto Verify
8
                                              Synopsys, Inc.
                                                                                             Preface
Typographical Conventions
Typographical Conventions
                 This document uses the following typographical conventions:
                  Syntax                   Description
                  [ ] (Square brackets)    An optional entry
                  { } (Curly braces)       An entry that can be specified once or multiple
                                           times
                  | (Vertical bar)         A list of choices out of which you can choose
                                           one
                  ... (Horizontal          Other options that you can specify
                  ellipsis)
                                                                                                  9
                                            Synopsys, Inc.
Preface
Typographical Conventions
10
          Synopsys, Inc.
Using the Rules in the
SpyGlass Auto Verify
Solution
                                                                           11
                          Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
12
                                                  Synopsys, Inc.
                                                           Using the Rules in the SpyGlass Auto Verify Solution
Functional Analysis
                  Functional analysis refers to analyzing the functionality of a design as
                  opposed to analyzing the structure of a design or analyzing with regard to
                  a specific domain, such as power-related or SpyGlass DFT solution.
                  Examples of functional analysis are:
                   Search for bus contention
                   Checking exclusivity of two signals
                   Checking for gray encoding of a vector
                   Checking for leachability of states and transition from states for an FSM.
Implicit Properties
                                                                                                            13
                                                   Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
14
                                                  Synopsys, Inc.
                                                           Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                            15
                                                   Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Initial State
                  The initial state is a register-value assignment from which Functional
                  Analysis begins.
                  For example, given a 4-bit counter and a property asserting that the
                  counter will eventually reach 15, this assertion passes in 5 cycles if the
                  counter is initialized with 10, whereas it will pass in 15 cycles if the counter
                  is initialized to 0.
                  An initial state may or may not be a reset state of a design. A reset state of
                  a design is a register-value assignment obtained by resetting a design
                  using a reset signal (may be user-specified). SpyGlass Auto Verify solution
                  can obtain an initial state in four different ways:
                  1. Direct register-value assignment using the reset constraint
                  2. State value generated by an external simulation engine as a VCD file
                     and read in to SpyGlass Auto Verify solution using the vcdfile parameter
                  3. Initialization vector that can reset registers using define_tag constraint
                  4. Find an initial state automatically. If you do not provide an initial state
                     and/or do not provide an initialization vector, then SpyGlass Auto Verify
                     solution determines an initial state using the following approach:
                      Use reset port to reset registers
                      Random analysis by applying stimulus to the inputs and simulating to
                         find valid register value assignment. Although not a reset state, the
16
                                                  Synopsys, Inc.
                                                           Using the Rules in the SpyGlass Auto Verify Solution
Stuck-Net
                  Stuck-at nets (constant nets) in the design can be of three types, as
                  described in the following table:
NOTE: A signal that cannot be initialized to an initial state is, by definition, not stuck-at.
                                                                                                            17
                                                   Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
VCD Files
Property Files
18
                                                        Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
                 SpyGlass Auto Verify solution combines the design with the property and
                 explores the combined space in search for a bug. Exploration of this space
                 is conducted across register boundaries for a full sequential analysis. This
                 search can reach depth of hundreds or even thousands of clock cycles.
                 Parameters are provided to control both run-time and sequential depth of
                 analysis.
         NOTE: To run SpyGlass Auto Verify solution by selecting the required goal containing rules
               of SpyGlass Auto Verify solution.
                                                                                                      19
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Library Cells
                  You can specify library files by using the read_file       -type gateslib
                  <library-file> command in the project file.
Black Boxes
                  A design unit without functionality is considered as a black box during
                  Functional Analysis. Examples of such modules are memory blocks not
                  transformed to a register bank and library cells that are not expanded. The
                  inputs of these design units are considered as outputs of the design, the
                  outputs of these modules are considered as inputs of the design. In
                  particular, if a clock port of a register is driven from a black box output, this
                  output is considered as a primary clock and needs to be user-defined, or
                  the default clock will be attributed to it. Outputs of a black box may be
                  constrained using the functional constraints definition.
20
                                                  Synopsys, Inc.
                                                  Using the Rules in the SpyGlass Auto Verify Solution
Memory Blocks
                For simplicity, the memory blocks should be black boxes. As mentioned in
                Black Boxes, the outputs of such blocks are supposed to generate any
                combination of data, which is a reasonable assumption for a memory
                block. The data and address buses and decoders are not part of the
                memory core; therefore, they participate in the functional analysis.
Bidirectional Ports
                For functional analysis, the bidirectional ports are considered as inputs
                and/or outputs. This fact is transparent to the user.
Asynchronous Resets
                SpyGlass Auto Verify solution can automatically analyze designs with
                asynchronous resets. While it is recommended, it is not necessary for you
                to provide asynchronous reset information through the reset constraint. By
                default, the asynchronous resets are used only for an initial state search
                and they are disabled during functional analysis. To allow the asynchronous
                reset usage during functional analysis, use the reset constraints to set
                the reset signal as soft reset. The auto-detection of asynchronous resets
                can be turned off using the use_inferred_resets parameter of
                SpyGlass CDC solution. Synchronous resets in all cases must be provided
                through the reset constraint in a SpyGlass Design Constraint file.
Latches
                SpyGlass Auto Verify solution can analyze designs with level-sensitive
                latches. However, for functional analysis purposes, a transparent latch is
                modeled so that its output is evaluated at each active edge of any clock
                controlling the data or the enable of the latch. This modeling conforms to a
                simulation model for a level sensitive latch.
Tristate Buses
                                                                                                   21
                                          Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                  SpyGlass Auto Verify solution can analyze designs with tristate buses.
                  However, the assumption is made that the tristate bus is never floating nor
                  is there contention (this check is performed by SpyGlass Auto Verify
                  solution separately on each tristated bus). In fact, a tristate bus is
                  transformed into an equivalent MUX structure before the functional
                  analysis.
Gated Clocks
                  SpyGlass Auto Verify solution supports multiple asynchronous clocks and
                  gated clocks in a design as long as the source clocks are provided which
                  control the register clock pins through functionally analyzable components.
                  You can provide the source clocks using the clock constraint.
22
                                                  Synopsys, Inc.
                                                      Using the Rules in the SpyGlass Auto Verify Solution
                     State variable
               NOTE: SpyGlass Auto Verify solution requires you to specify only the simple name
                     (that is, without bit-width specification) for a state variable for the FSM to be
                     inferred.
                     Bit-select 1'b1 or 1'b0: This is used to describe a one-hot or a one-
                       cold encoding FSM only.
               NOTE: Currently, this feature is supported for Verilog designs only.
                8. Next state assignment: RHS must be a constant value. Ideally, it should
                    be one of the case labels.
                     Tasks/Functions calculating a next state are not supported
                     Logical/arithmetic operations calculating next state value are not
                       supported
                     State labels can be of type enum, but the enum literals must be of
                       type   charlit.
                                                                                                       23
                                              Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
atime
                  With atime parameter, you can set the runtime limit for the analysis of a
                  single property.
                  The default value of atime depends on the property count. If the property
                  count is high, SpyGlass internally computes and uses a lower runtime limit.
                  Similarly, if the property count is low, SpyGlass internally computes and
                  uses a higher runtime limit in the SpyGlass run.
24
                                                  Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
av_dcode_analysis
                 Specifies the approach (strict or soft) towards verification of assertions.
                 By default, the Av_deadcode01 rule uses the soft approach for verification of
                 assertions. This approach is quick, but it may impact the quality of
                 verification results.
                 Set this parameter to strict to improve the quality of verification
                 results. However, using the strict approach can increase the rule run time.
                   Used by                   Av_deadcode01
                   Options                   soft, strict
                   Default value             soft
                   Example
                   Console/Tcl-based usage   set_parameter av_dcode_analysis strict
                   Usage in goal/source      -av_dcode_analysis=strict
                   files
av_dcode_report
                 Configures the Av_deadcode01 rule to report violations for the assertions
                 present in all the nested if-else blocks. In this case, this rule groups all
                 the violations of the same if block, else-if block, or else block of a
                 nested if block (or dependency tree). Within each group, violations are
                 sorted based on the assertions depth within the if, else-if, or else
                 block.
                                                                                                      25
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Used by                        Av_deadcode01
                   Options                        minimal, all
                   Default value                   minimal
                   Example
                   Console/Tcl-based usage        set_parameter av_dcode_report all
                   Usage in goal/source           -av_dcode_report=all
                   files
av_dump_assertions
                  Generates SystemVerilog Assertions (SVA) for partially-proved assertions
                  of the rules specified in the Used by section.
                                         sva, SpyGlass generates the bind file
                  When you set this parameter to
                  sva_rules_prop_<top-module-name>_bind.sv along with
                  simulator-specific (vcs, ncsim, modelsim) assertion files
                  sva_rules_prop_<top-module-name>_<simulatorName>.sv
                  in the wdir/spyglass_reports/auto-verify/assertions
                  directory.
                  On passing av_dump_assertions with audit, the design is run in
                  audit mode, and SVA for all the assertions are generated.
26
                                                  Synopsys, Inc.
                                                       Using the Rules in the SpyGlass Auto Verify Solution
av_dump_instance_complexity
                 Generates instance-based spreadsheet (Av_complexity01_InstanceBased.csv
                 Tab) showing cyclomatic complexity of module instances.
                 This information is similar to the information displayed in the
                 module-based spreadsheet (Av_complexity01_module.csv Tab).
                 The difference between the two spreadsheets is that the instance-based
                 spreadsheet shows information for each instance instead of each module
                 and it additionally displays cumulative complexity of each instance and its
                 level with respect to the top module.
                   Used by                Av_complexity01
                   Options                yes, no
                   Default value          no
                   Example
                   Console/Tcl-based      set_parameter av_dump_instance_complexity yes
                   usage
                   Usage in goal/source   -av_dump_instance_complexity = yes
                   files
av_dump_liveness
                 Generates the SystemVerilog Assertions (SVA) in terms of assert or cover
                 for assertions of the Av_fsm02 and Av_fsm02 rules.
                 By default, SVA assert statements are generated.
         NOTE: This parameter is applicable only when the av_dump_assertions parameter is set to
               sva.
                                                                                                        27
                                               Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
av_enable_crpt
                  Configures SpyGlass Auto Verify rules to generate a spreadsheet showing
                  details of SVA constraints affecting each rule violation.
                  For information on this spreadsheet, refer to the Using SystemVerilog
                  Assertions application note.
av_flopcount
                  Specifies a maximum number of flip-flops so that an input cone of
                  SpyGlass Auto Verify properties can be abstracted by cutting the logic
                  behind the specified number of flip-flops in that cone.
                  While running SpyGlass Auto Verify analysis on full chips, the cone of
                  SpyGlass Auto Verify properties can be very complex in terms of number of
                  flip-flops. This results in significant time spent on verification.
28
                                                   Synopsys, Inc.
                                                       Using the Rules in the SpyGlass Auto Verify Solution
                 By default, this parameter is set to -1, which indicates that an input cone
                 will not be abstracted by cutting the logic behind a specific number of flip-
                 flops in the cone of SpyGlass Auto Verify properties.
av_force_soft_reset
                 Specifies if a reset or set in the design should be forced as a soft reset
                 during Functional Analysis while running the Av_setreset01 and Av_deadcode01
                 rules.
                 By default, the Av_setreset01 rule considers all resets as soft even when
                 that reset is specified as a hard reset in the SGDC file. Set this parameter
                 to no so that this rule considers the resets as hard or soft based on the
                 specifications in the SGDC file.
                 By default, the Av_deadcode01 rule uses the specifications in the SGDC file
                 to consider a reset as hard or soft. To force this rule to consider all the
                 resets as soft resets:
                  Specify Av_deadcode01 to the existing parameter specification, or
                                                                                                        29
                                               Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
av_ignore_preformal_run_time
                  Specifies if preformal runtime, such as time for synthesis should be
                  considered while calculating the total runtime for the current run of a
                  SpyGlass Auto Verify goal.
                  This parameter is used with the av_run_time parameter.
av_msgmode
                  Specifies the type of assertions (failed, partially proved, and passed) to be
30
                                                  Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
                   Used by                   Av_syncfifo01
                   Options                   fail, pp, pass, all
                   Default value             fail
                   Example
                   Console/Tcl-based usage   set_parameter av_msgmode all
                   Usage in goal/source      -av_msgmode = all
                   files
av_run_time
                 Specifies the total runtime (wall clock time) for current run of a SpyGlass
                 Auto Verify goal.
                 The current runtime includes preformal runtime, such as time for
                 synthesis. (Use Parameter av_ignore_preformal_run_time to ignore preformal
                 time)
                 By default, total runtime depends on multiple factors, such as the value of
                 the atime parameter and number of properties.
                                                                                                      31
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
av_seqdepth
                  Specifies a maximum sequential depth so that an input cone of SpyGlass
                  Auto Verify properties can be abstracted by cutting the logic behind the
                  specified depth in that cone.
                  While performing SpyGlass Auto Verify analysis on full chips, the cone of
                  SpyGlass Auto Verify properties can be very complex in terms of a
                  sequential depth. This results in significant time spent for verification.
                  To circumvent this problem, use this parameter to limit the sequential
                  depth to abstract input cones. Limiting the sequential depth also increases
                  the chances of getting properties concluded.
                  It is recommended that you use this parameter only for partially-proved
                  properties because usage of this parameter may help in concluding such
                  properties.
         NOTE: If you use this parameter for properties that are failing, such properties may be
               reported as partially proved. Therefore, it is recommended that you use this
               parameter only on partially proved properties by using the propfile parameter.
av_violation_count
                  Limits the violation count for the rules of SpyGlass Auto Verify.
                  When the number of violations specified by this parameter are reported,
                  the remaining properties are not verified formally.
32
                                                  Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
buscompress
                 Specifies whether the Av_staticnet01 rule should check single bit or all the
                 bits of a bus signal.
                 By default, the value of this parameter is set to yes, and the
                 Av_staticnet01 rule checks single bit of a bus signal.
                 Set the value of this parameter to    no to check all the bits of a bus signal.
                   Used by                   Av_staticnet01
                   Options                   yes, no
                   Default value             yes
                   Example
                   Console/Tcl-based usage   set_parameter buscompress no
                   Usage in goal/source      -buscompress=no
                   files
ieffort
                 This parameter is used to change the effort of the tool put in initial state
                 search during design simulation.
                 By default, during initial state search, the tool first applies asynchronous
                 set/resets on a design and then performs clocked simulation.
                                                                                                      33
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                  Clock Simulation
                  Clocked simulation is performed for a fixed number of cycles (that is 200
                  cycles) until any of the following occurs:
                   A non-X value reaches on all flip-flops.
                   No improvement is observed for a fixed number of consecutive cycles
                     (also referred to as waste cycles).
                  This waste cycle number is 10 for the reset simulation stage, and it is 20
                  for the data simulation stage.
                  If you set the value of the ieffort parameter to a positive integer value
                  (say N), the tool performs the following steps:
                  1. It multiplies the simulation cycle count and waste cycle count with N
                     (which in effect multiplies the time spent in initial state search by                N).
                  2. It deactivates sets/resets and performs clocked simulation for the total
                     number of cycles calculated in the above step.
                  The tool performs the above steps over and above the default behavior of
                  applying asynchronous set/resets on a design and then performing clocked
                  simulation.
                  Setting the ieffort parameter to a negative value (-1 to                     -3) produces
                  different results, as explained in the following table:
                   Value      Result
                   -1         Complete initial state search is skipped all together
                   -2         Initial state of all flip-flops to forced to 0
                   -3         Initial state of all flip-flops is forced to 1
34
                                                  Synopsys, Inc.
                                                            Using the Rules in the SpyGlass Auto Verify Solution
audit
                 Use the audit parameter to quickly explore the assertion checking
                 opportunities in a design without performing the actual formal analysis.
                 When the audit parameter is set, SpyGlass Auto Verify solution does not
                 perform functional analysis. However, the violation report is still generated.
                 The Info Rules are also run unless you explicitly disable them.
                 When the audit parameter is not set (default), SpyGlass Auto Verify
                 solution performs functional analysis.
                 On passing av_dump_assertions with audit, the design is run in the audit
                 mode and SVA for all assertions is generated for the rules specified in the
                 Used by section.
passfail
                 Specifies whether SpyGlass Auto Verify solution checks the properties for
                 proof only, for failure only, or for both.
                 The allowed values of the       passfail parameter are as follows:
                   Value             Behavior
                   pass              Enables pass-centric checking (Select if you expect more
                                     properties to pass in your design).
                                                                                                             35
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Value            Behavior
                   fail             Enables fail-centric checking (Select if you expect more properties
                                    to fail in your design)
                   both             (Default) Enables both pass-centric and fail-centric checking
dead_code_scope
                  The dead_code_scope parameter specifies the type of constructs to be
                  checked by the Av_deadcode01 rule.
                   Used by                        Av_deadcode01
                   Options                        Comma-separated list of Possible Values of the
                                                  dead_code_scope Parameter.
                   Default value                  if, case_without_default, generate, always
                   Example
                   Console/Tcl-based usage        set_parameter dead_code_scope 'if,case'
                   Usage in goal/source           -dead_code_scope='if,case'
                   files
36
                                                  Synopsys, Inc.
                                                   Using the Rules in the SpyGlass Auto Verify Solution
                  if
                     The Av_deadcode01 rule checks for the     if-else constructs only.
                  case
                     The Av_deadcode01 rule checks for the     case constructs and case
                     default blocks only.
                  case_without_default
                     The Av_deadcode01 rule checks for the     case constructs only without
                     checking the default label.
                  condasgn
                     The Av_deadcode01 rule checks for conditional assignments only for
                     Verilog and CONDSIGASGN/SELSIGASGN statements for VHDL.
                  if_case
                     The Av_deadcode01 rule checks for      if and case blocks.
                  if_case_condasgn
                     The Av_deadcode01 rule checks for      if and case blocks.
                     For Verilog, this rule also checks for conditional assignments, as shown
                     in the following example:
                     a = b ? c : d
                     For VHDL, this rule checks for   CONDSIGASGN/SELSIGASGN
                     statements.
                  generate
                     The Av_deadcode01 rule checks for the dead-if and
                     case_without_default blocks specified inside generate blocks.
                  always
                     The Av_deadcode01 rule processes the always blocks containing the             if
                     and case_without_default blocks.
detect_assign_fsm
                 Setting the   detect_assign_fsm parameter causes the Av_fsm01,
                                                                                                    37
                                           Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
detect_ifelse_fsm
                  Enables the Av_fsm01, Av_fsm02, Av_fsminf01, and Av_fsminf02 rules to detect
                  if-else style FSMs in addition to detecting case style FSMs (default).
detect_nested_fsm
                  Setting the detect_nested_fsm parameter causes the Av_fsm01,
                  Av_fsm02, Av_fsminf01, and Av_fsminf02 rules to detect nested if-else style
                  FSMs, nested case style FSMs, and assign style FSMs in addition to
                  detecting case style FSMs (default).
                  1. For assign style FSMs, state-labels are back-referenced to the line where
                     it has been compared with the current state vector. Hence, in the
                     following example, any rule-violation for the FSM1_ST3 state is
                     indicated on third line of the assign statement as highlighted and not on
38
                                                  Synopsys, Inc.
                                                       Using the Rules in the SpyGlass Auto Verify Solution
         NOTE: In case of nested FSMs specified using separate sequential and combinational
               blocks, if the next state vector is not given a default value, it might lead to
               ambiguous results as the state vector can then take any value till the FSM actually
               gets invoked leading to false or missing rule-violations.
fv_dcode_all_inst
                 By default, the Av_deadcode01 rule highlights any one instance of a
                 deadcode module. Set this parameter to "yes" to view the schematic and
                 waveform for all the instances of the deadcode module.
                   Used by                   Av_deadcode01
                   Options                   yes, no
                   Default value             no
                   Example
                   Console/Tcl-based usage   set_parameter fv_dcode_all_inst yes
                   Usage in goal/source      -fv_dcode_all_inst=yes
                   files
                                                                                                        39
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
fv_parallelfile
                  Specifies a configuration file for distributed runs of the Av_sanity06 rule
                  over several machines.
                  The configuration file is an ASCII text file that contains specific lines for
                  different methods, as discussed below:
                   The lsf method contains the following lines:
                     LOGIN_TYPE: lsf
                     MAX_PROCESSES: <num>
                     LSF_CMD: <bsub-command>
                     Details of various arguments and keywords are discussed below:
                      Specify the value of the LOGIN_TYPE keyword as lsf.
                      The <num> argument of the MAX_PROCESSES keyword specifies
                         the maximum number of processes to be spawned.
                      The <bsub-command> argument of the LSF_CMD keyword
                         specifies the LSF invocation command. (default is               bsub).
                     The following table describes the arguments and keywords of the above
                     method:
                       Argument/Keyword                Description
                       <num>                           Specifies the maximum number of processes to be
                                                       spawned.
                       <bsub-command>                  Specifies the LSF invocation command. (default is
                                                       bsub).
                                                       SpyGlass generates details of the bsub command,
                                                       which is used in parallel LSF runs, in a log file. This
                                                       information is useful while debugging.
                                                       To generate complete information of the bsub
                                                       command, set the verbose parameter to 2.
             NOTE: To know the runtime details of SpyGlass Auto Verify rules that are run on same
                   or different machines, refer to distributed_time report.
             NOTE: In a parallel file specified by the
                                                  fv_parallelfile parameter, the -I, -
                     Ip, and -Is options of the bsub command are not allowed in the LSF_CMD
40
                                                  Synopsys, Inc.
                                                      Using the Rules in the SpyGlass Auto Verify Solution
                     MACHINES:
                     <machine1-name>[:<num-processes>]
                     <machine2-name>[:<num-processes>]
                     ...
                     Details of various arguments and keywords are discussed below:
                      Specify the value of the LOGIN_TYPE keyword as rsh or ssh as
                        per your requirement.
                      The <num> argument for the MAX_PROCESSES keyword specifies
                        the maximum number of processes to be spawned.
                      The <machine1-name>, <machine2-name>,... arguments refer
                        to the machine names.
                                                                                                       41
                                              Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Used by                        Av_sanity06
                   Options                        File name
                   Default value                   ""
                   Example
                   Console/Tcl-based usage        set_parameter fv_parallelfile
                                                  'machinelist.txt'
                   Usage in goal/source           -fv_parallelfile='machinelist.txt'
                   files
fv_debug_sim_cycles
                  Specifies the number of cycles of the slowest clock in property pack for
                  which waveform should be displayed from initial state for failed properties
                  of the Av_deadcode01 and Av_staticnet01 rules.
         NOTE: High value of fv_debug_sim_cycles will lead to high runtime for waveform
               generation.
42
                                                  Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
include_construct
                 Specifies if the generate_block and always_comb constructs should
                 be checked by the Av_deadcode01, Av_dontcare01, and Av_range01 rules, and
                 if dead code should be checked in the include files by the Av_deadcode01
                 rule.
                 You can set this parameter to the following values:
                  generate
                     Enables the Av_deadcode01, Av_dontcare01, and Av_range01 rules to
                     consider the generate_blocks constructs for rule-checking.
                  always_comb
                     Enables the Av_deadcode01, Av_dontcare01, and Av_range01 rules to
                     consider the always_comb constructs for rule-checking.
                  included_file
                     Enables the Av_deadcode01 rule to check for dead code in the functions
                     in the include files specified by the 'include directive.
                     By default, only the functions in the included file are not checked for
                     dead code
reset_convention
                 Specifies the resets to be reported by the Av_rstinf01 rule.
                                                                                                      43
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Used by                        Av_rstinf01
                   Options                        Comma or space-separated list of reset names (or
                                                  Perl regular expressions)
                   Default value                   ""
                   Example
                   Console/Tcl-based usage        set_parameter reset_convention "*rst*,*set*"
                   Usage in goal/source           -reset_convention="*rst*,*set*"
                   files
resetoff
                  The   resetoff parameter disables all user-supplied reset constraints.
         NOTE: By default, all user-supplied reset constraints are applied.
show_static_latches
                  The   show_static_latches parameter specifies whether the
                  Av_staticreg02 rule should report static latches in a design.
                  By default, the static latches are reported in the Av_staticreg02 rule
                  spreadsheet.
                  Set this parameter to      no to stop reporting static latches in the
                  spreadsheet.
                   Used by                        Av_staticreg02
                   Options                        yes, no
44
                                                  Synopsys, Inc.
                                                        Using the Rules in the SpyGlass Auto Verify Solution
solvemethod
                 Specifies the effort level for property checking.
                 You can set the     solvemethod parameter to the following values:
                   Value             Description
                   1 (default)       • Property verification as per the passfail parameter
                                     • Cut-based verification is off unless overridden by atime
                                       parameter
                   2                 • Property verification as per the passfail parameter
                                     • Automatic cut-based verification
                                     • Different internal engine invocation sequence (from the other
                                       two solvemethod settings) to improve coverage based on the
                                       property type (proof-dominant or witness-dominant)
                   3                 • Property verification as per the passfail parameter
                                     • Automatic cut-based verification
                                     • Different internal engine invocation sequence (from the other
                                       two solvemethod settings) to improve coverage based on the
                                       property type (proof-dominant or witness-dominant)
staticnet_scope
                                                                                                         45
                                                Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Used by                        Av_staticnet01
                   Options                        Comma-separated list of any of the following values:
                                                  • flop: Specifies that rule-checking is done on flip-
                                                    flops only.
                                                  • lhs: Specifies that rule-checking is done on LHS
                                                    assignment nets only.
                                                  • rhs: Specifies that rule-checking is done on RHS
                                                    assignment nets only.
                                                  • all: Specifies that rule-checking is done on flip-
                                                    flops, latches, and nets
                   Default value                  flop
                   Example
                   Console/Tcl-based usage        set_parameter staticnet_scope lhs,rhs
                   Usage in goal/source           -staticnet_scope=lhs,rhs
                   files
propfile
                  The propfile parameter specifies the property file containing properties
                  to be checked.
         NOTE: By default, all properties in the design are checked.
modulelist
46
                                                  Synopsys, Inc.
                                                     Using the Rules in the SpyGlass Auto Verify Solution
                 The modulelist parameter specifies the design units for which the
                 functional analysis is to be performed.
                 By default, SpyGlass Auto Verify solution analyzes the user-defined
                 properties and implicit properties for all design units in the user design. If
                 you specify some particular design units with the modulelist parameter,
                 SpyGlass Auto Verify solution analyzes only the specified design units at
                 the highest level. Properties at lower levels of the specified design units or
                 in the remaining design units of the user design are not analyzed. However,
                 the complete design is considered while determining the fan-in/fan-out of
                 signals being checked.
scope
                 The   scope parameter defines the scope of functional analysis.
                 By default, the scope parameter is set to chip and the complete fan-in
                 cone of the assertion is taken into account.
                 Set the scope parameter to block to have SpyGlass Auto Verify solution
                 cuts all signals in the fan-in cone (except clocks and resets) at the sub-
                 module boundary in which the assertion is formed. All those signals at the
                 boundary of the sub-module are then treated as primary inputs for
                 functional analysis.
                                                                                                      47
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Example
                   Console/Tcl-based usage        set_parameter scope block
                   Usage in goal/source           -scope=block
                   files
vcdtime
                  This parameter is deprecated. Use the simulation_data constraint instead of
                  this parameter.
vcdfile
                  This parameter is deprecated. Use the simulation_data constraint instead of
                  this parameter.
vcdfulltrace
                  The vcdfulltrace parameter specifies whether all signals or only user
                  signals in the fan-in cone of an assertion are dumped in the VCD file. The
                  default value of the vcdfulltrace parameter is usernets.
                  You can set the     vcdfulltrace rule parameter to the following values:
                   Value           Description
                   no              Only the flip-flop output signals and primary inputs in the fan-in
                                   cone of an assertion are written to the VCD file
                   usernets        All the user nets in the fan-in cone of an assertion are written to
                                   the VCD file
                   allnets         All internally generated nets along with the user-defined signals in
                                   the fan-in cone of an assertion are written to the VCD file
48
                                                  Synopsys, Inc.
                                                       Using the Rules in the SpyGlass Auto Verify Solution
                   Example
                   Console/Tcl-based usage   set_parameter vcdfulltrace allnets
                   Usage in goal/source      -vcdfulltrace=allnets
                   files
verbose
                 The verbose parameter specifies the verbosity level of the messages
                 printed at the standard output.
                 You can set the verbose parameter to values 0 (default), 1, 2, and 3.
                 Higher the value, more messages are printed.
xassign_casedefault
                 The xassign_casedefault parameter specifies whether the
                 Av_dontcare01 rule should check the X-assignment inside the
                                                                     default
                 clause of a case statement.
                 By default, this parameter is set to no, and the Av_dontcare01 rule does
                 not check the X-assignment inside the default clause of a case
                 statement. Set this parameter to yes to check all the clauses of case
                 statement.
                   Used by                   Av_dontcare01
                   Options                   yes, no
                   Default value             no
                                                                                                        49
                                             Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Example
                   Console/Tcl-based usage        set_parameter xassign_casedefault yes
                   Usage in goal/source           -xassign_casedefault=yes
                   files
50
                                                  Synopsys, Inc.
                                                      Using the Rules in the SpyGlass Auto Verify Solution
Functional Constraints
Functional Constraints
                  The functional constraints are complex constraints restricting the search
                  space for functional analysis and are defined using assertions. For instance,
                  if you know that an input vector of a sub-block of a design is one hot
                  encoded, you can provide this information as a functional constraint to
                  SpyGlass Auto Verify solution.
                         a
                         b
                                                                                                       51
                                              Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Functional Constraints
Over Constraint
                  Functional constraints are used to model the environment or help SpyGlass
                  Auto Verify solution in concluding the analysis; in doing so you may
                  introduce constraints that are conflicting between them or with the design
                  itself. This conflict is happening because the design is over-constrained.
                  SpyGlass Auto Verify solution reports such scenarios in the Av_sanity04
                  rule. Using this rule, you would be able to identify conflicting constraints.
52
                                                  Synopsys, Inc.
                                                       Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                        53
                                               Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
54
                                                  Synopsys, Inc.
                                                  Using the Rules in the SpyGlass Auto Verify Solution
                  VHDL Example
                  The following VHDL example represents an FSM:
                  library accellera;
                   USE accellera.ovl_assert.ALL;
                  LIBRARY ieee;
                  USE ieee.std_logic_1164.ALL;
                  USE ieee.Numeric_Std.ALL;
                  entity top is
                    port(clk : in bit;
                         rst   : in bit;
                         rdReq   : in bit;
                         wrReq   : in bit;
                         status1 : out unsigned(2 downto 0));
                  end top;
                                                                                                   55
                                          Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
56
                                                  Synopsys, Inc.
                                                    Using the Rules in the SpyGlass Auto Verify Solution
                         end if;
                       end if;
                     end process;
                   te <= true when wrReq='1' and ptr < SIZE and status =
                  WRITE_REFUSED else false;
                    Inst : assert_never generic map(failure,0) port map (clk =>
                  To_StdULogic(clk),
                   reset_n => To_StdULogic(rst),
                   test_expr => te);
                  end str;
                  In the above example, refer to the assertion instantiated at the end of the
                  example, that is:
                  te <= true when wrReq='1' and ptr < SIZE and status
                  =WRITE_REFUSED else false;
                  Inst : assert_never generic map(failure,0) port map (clk
                  =>To_StdULogic(clk),reset_n => To_StdULogic(rst),test_expr
                  => te);
                                                                                                     57
                                            Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                  Normally, you are expected to specify an actual clock signal as the first port
                  of the assertion/assumption (except the assert_proposition
                  assertion which is a purely combinational check). In case, the specified
                  clock signal is forced to a constant value in the design or you specify a
                  constant value (0 or 1) instead of a clock signal in the assertion, the
                  corresponding assertion will never reach an error condition and will always
                  be proved.
                  By definition, all resets in the OVL modules are active low. Therefore,
                  constraints resets all OVL instances to high value (that is, deactivate the
                  reset) for proper functioning of OVL instances. In case, the specified reset
                  signal is forced to a constant low value in the design or you specify a
                  constant value 0 instead of a reset signal in the assertion, SpyGlass Auto
                  Verify solution reports the constraint to be unsatisfied as the reset is being
                  constrained in two different values. Thus, the corresponding assertion will
                  not be checked for pass or fail. In case, the specified reset signal is forced
                  to a constant high value in the design or you specify a constant value 1
                  instead of a reset signal in the assertion, SpyGlass Auto Verify solution
                  checks the assertion in the normal way.
                  In case of the assumptions, a constant value clock signal or constant 0
                  reset will result in the corresponding constraint being ignored/not applied.
58
                                                  Synopsys, Inc.
                                                   Using the Rules in the SpyGlass Auto Verify Solution
                     wire    clk;
                     reg ena1, ena2;
                                                                                                    59
                                           Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                  <ovl_assertions_instance>;
                  <ovl_assertions_instance>;
                  end_ovl
                  Where <module-name> is the module into which the OVL assertions are
                  instantiated/bound.
                  Signal names specified in the assertions instantiations should be
                  hierarchical names with respect to the binding module <module-name>
                  as in the following example:
                  attach_properties test
                  begin_ovl
                  assert_always assrtn4 (clk, 1'b1, ( mid1.w2 == 1'b0 ));
                  end_ovl
                  Here,   w2 is a signal in the instance mid1 under the binding module test.
                  Mixed-language is supported which means that OVL file may use Verilog
                  format while the design is a VHDL design and vice-versa.
                  To read an OVL Verilog file in Atrenta Console, specify the following
                  command in a project file:
                  set_option ovl_verilog { OVL-file> }
                  Similarly, to read an OVL VHDL file, specify the following command in a
                  project file:
                  set_option ovl_vhdl { OVL-file> }
60
                                                  Synopsys, Inc.
                                                      Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                       61
                                              Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
62
                                                  Synopsys, Inc.
                                                   Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                    63
                                           Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                  RuleName: <rule-name>
                  ...
                  Where:
                   <rule-name> is the name of the rule of SpyGlass Auto Verify solution.
                   <selection> is on when the assertion/constraint is enabled or is off
                     when the assertion/constraint is disabled.
                   <type> is the property type — Assertion or Constraint.
                   <status> indicates the assertion status:
64
                                                  Synopsys, Inc.
                                                    Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                     65
                                            Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
66
                                                  Synopsys, Inc.
                                                  Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                   67
                                          Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
68
                                                  Synopsys, Inc.
                                                  Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                   69
                                          Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
70
                                                  Synopsys, Inc.
                                                   Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                    71
                                           Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
72
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          73
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
############################################################
                  ignore_latches                        :          yes
                  use_inferred_resets                   :          yes
                  verbose                               :          4
############################################################
----------------------------
############################################################
74
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
############################################################
                  -----------------------------------------------------------
                  RuleName Passed Failed Partially Proved Not Analyzed Others Total
                                                  (Average Depth)
                  ------------------------------------------------------------
                  Av_        1      1        0            0         0      2
                  negative
                  _shift
                  ------------------------------------------------------------
                  Total                          1                1                 0
                  0                         0                         2
                  ------------------------------------------------------------
############################################################
---------------------------------------
############################################################
                  RuleName: Av_negative_shift
                  -----------------------
                  1. (Hier:top) (b >>> (~d)), test.v, 9,
                  (Av_negative_shift.1.1.vcd) : FAILED through depth 1(1)
                  2. (Hier:top) (b <<< (^ d)), test.v, 9, : PROVED
                                                                                                          75
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
###########################################################
76
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          77
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
      ieffort                                                                                  :   0
      propfile                                                                                 :   av.prp
      use_inferred_resets                                                                      :   yes
      use_inferred_clocks                                                                      :   yes
      dead_code_scope                                                                          :   generate
      staticnet_scope                                                                          :   flop
Run Information:
----------------------------------------------------------------------
    Total Time (in sec)                                       : 9
    Total Memory (in KB)                                      : 45847
    Peak Memory (in KB)                                       : 205440
Design Statistics:
----------------------------------------------------------------------
    Total Flat Instances                                      : 4399
    Total Flop                                                : 807
    Total Latches                                             : 15
    Total Sequential Library Cell                             : 0
    Number of Modules                                         : 22
    Maximum Cyclomatic complexity                             : 376
    Average Cyclomatic complexity                             : 47
Design Setup:
----------------------------------------------------------------------
     Clocks:
     ---------------------------------------
       Number of user-defined clocks                          : 1
       Number of Black-box clocks                              : 0
        Resets:
        ---------------------------------------
78
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
        Initialization
        ---------------------------------------
         Number and percentage of flops uninitialized                                 : 807(100.00 %)
         Number and percentage of latches uninitialized                               : 15(100.00 %)
        FSMs
        ------------------------------------------------------------------
          Number of FSMs detected                                   : 6
          Number of interacting FSMs detected                       : 2
=======================================================================
B. Analysis and Verification: To be reviewed for verification signoff.
======================================================================
Analysis and Verification                            : Current Cumulative
----------------------------------------------------------------------
Multiple Overlapping Parallel Case Items (Av_case02) :    1         1
Bus Contention violation (Av_bus01)                  :    2         2
Floating Bus (Av_bus02)                              :    2         3
                                                                                                          79
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Custom-Style Encoding
                  If the Fsm encoding style field in the Auto Verify-FSM Report is CUSTOM, the
                  following three types values appear adjacent to the text CUSTOM in this
                  report:
                   Number of states in FSM
                   Number of bits representing state values
80
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          81
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
82
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          83
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
84
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
         NOTE: The value U instead of X is used for hanging pins in the spreadsheet. The X value is
               a default value for simulation through a design is initialized for simulation in the
               Av_initstate01 rule.
                                                                                                          85
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
86
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          87
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Av_complexity01_module.csv Tab
                  Under this tab, information of all modules is displayed. The following figure
                  shows the sample data under this tab:
                  To cross-probe to the first line in the RTL defining a particular module, click
                  the corresponding cell in the ID column of the above spreadsheet.
                  The following table describes each column of the above spreadsheet:
88
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                   Column                       Description
                   ID                           Specifies a unique tag number for a module. Click this
                                                cell to cross-probe to the first line of module definition
                                                in the RTL.
                   Module name                  Specifies RTL design unit name:
                                                • For Verilog: module name
                                                • For VHDL: Entity. Architecture name
                   Elaborated name              Specifies an elaborated module name.
                                                It is relevant for parameterized module.
                   #Instances of the            Specifies the number of times a given module is
                   module                       instantiated anywhere in a design.
                   File                         Specifies the name of a file in which a module is
                                                defined.
                   Line                         Specifies the starting line number of a module.
                   #Inputs                      Specifies the number of input ports of a module.
                   #Outputs                     Specifies the number of output ports of a module.
                   #Inouts                      Specifies the number of inout ports of a module.
                   #Param                       Specifies the number of parameters in a parameterized
                                                module.
                   #Lines of code               Specifies the number of code lines inside a module.
                   #Lines of comments           Specifies the number of comment lines inside a
                                                module.
                   User defined instances       Specifies the number of other user-defined modules
                   inside the module            that are instantiated/present inside a module.
                   #BB Instances                Specifies the number of pure black box instances
                                                present in a module.
                   #FSMs                        Specifies the number of FSMs detected in a module.
                   #Condition var               Specifies the number of variables involved in
                                                conditional statements.
                   #User nets                   Specifies the number of signals (excluding ports)
                                                defined by a user.
                   #Always/Process              Specifies the number of always and process blocks in a
                                                module.
                                                                                                          89
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Column                       Description
                   Cyclomatic complexity        Specifies the number of decision points inside a
                                                module plus one.
                   Max of if-else/case          Specifies the maximum depth of nested if-else and
                   depth                        case conditions.
Av_complexity01_InstanceBased.csv Tab
                  Under this tab, details of module instances are displayed. The following
                  figure shows the sample data under this tab:
90
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                   Column                       Description
                   ID                           Specifies a unique tag number for a module. Click this
                                                cell to cross-probe to the first line of module definition
                                                in the RTL.
                   Instance name                Specifies the instance name
                   Module Name                  Specifies the module of the instance
                   Elaborated name              Specifies an elaborated module name.
                                                It is relevant for parameterized module.
                   #Instances of the            Specifies the number of times a given module is
                   module                       instantiated anywhere in a design.
                   File                         Specifies the name of a file in which a module is
                                                defined.
                   Line                         Specifies the starting line number of a module.
                   #Inputs                      Specifies the number of input ports of a module.
                   #Outputs                     Specifies the number of output ports of a module.
                   #Inouts                      Specifies the number of inout ports of a module.
                   #Param                       Specifies the number of parameters in a parameterized
                                                module.
                   #Lines of code               Specifies the number of code lines inside a module.
                   #Lines of comments           Specifies the number of comment lines inside a
                                                module.
                   User defined instances       Specifies the number of other user-defined modules
                   inside the module            that are instantiated/present inside a module.
                   #BB Instances                Specifies the number of pure black box instances
                                                present in a module.
                   #FSMs                        Specifies the number of FSMs detected in a module.
                   #Condition var               Specifies the number of variables involved in
                                                conditional statements.
                   #User nets                   Specifies the number of signals (excluding ports)
                                                defined by a user.
                   #Always/Process              Specifies the number of always and process blocks in a
                                                module.
                   Cyclomatic complexity        Specifies the number of decision points inside a
                                                module plus one.
                   Max of if-else/case          Specifies the maximum depth of nested if-else and
                   depth                        case conditions.
                                                                                                          91
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
                   Column                       Description
                   Cumulative Complexity        Specifies the cumulative complexity of the instance
                   Instance Level               Specifies the hierarchical level of the instance
Av_complexity01_fsm.csv Tab
                  Under this tab, details of FSMs in a design are displayed. The following
                  figure shows the sample data under this tab:
                  To view the FSM details in the FSM Viewer window, click a cell in the ID
                  column of the above spreadsheet and then click the FSM button (                   ) in the
                  main Atrenta Console window.
                  The following table describes each column of the above spreadsheet:
92
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                   Column                       Description
                   FSM ID                       Specifies a unique tag number for FSM. When you click
                                                this cell and then click the FSM button, the FSM Viewer
                                                window appears.
                   FSM                          Specifies the de-compiled current state node.
                   File                         Specifies the name of the file containing FSM.
                   Line                         Specifies the line number of an if/case block containing
                                                the current state expression.
                   #States                      Specifies the number of states for the FSM.
                   #Transitions                 Specifies the number of transitions in the FSM.
                   #Input                       Specifies the number of inputs to the FSM.
                   #Output                      Specifies the number of outputs from the FSM.
                   Encoding                     Specifies the encoding style, such as:
                                                • One-Cold
                                                • One-Hot
                                                • Grey
                                                • Minimum
                                                • Custom (See Custom-Style Encoding)
                   Style                        Specifies the type of machine (mealy, moore, or
                                                unknown).
                   Next state                   Specifies the type of next state assignment (Simple or
                                                Non-static.
                   Initial state                Specifies initial state of FSM.
                   Depth                        Specifies FSM depth (longest state path in the FSM)
                   Cyclomatic complexity        Specifies the number of decision points in FSM plus
                                                one.
                                                                                                          93
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Report Header
                  The report header provides a brief overview of the report and a brief
                  summary of all sections in this report.
                  Following is the content of the header section of this report:
                  ############################################################
                  Purpose:
                  # This report contains the functional analysis statistics
                    of a design.
                  #
                  # Format:
                  # It contains the following sections:
                  # Section A: Run Parameters
                  #   Lists the parameters specified in the current run
                  # Section B: Clock Information
                  #   Lists the clock information of the design
                  # Section C: Reset Information
                  #   Lists the reset information of the design
                  # Section D: Set-Case Analysis Settings
                  #   Lists the set case analysis settings used in the design
                  # Section E: Initial State of the Design
                  #   Lists the initial-state statistics of the design along
                  #   with the reset percentage. The initial state of each
                  #   register can be seen in auto_verify.reg file.
                  # Section F: Results Summary (Current)
                  #   Lists the statistics of the assertions formed for each
                  #   rule
                  # Section G: Results Summary (Cumulative)
                  #   Lists the summary of cumulative set of assertions formed
                  #   in the current run and the information of earlier runs in
                  #   the property file. This section is printed when you
                  #   specify a property file using the propfile parameter.
                  # Section H: Assertion Details
                  #   Lists the assertion details.
###########################################################
94
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          95
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
96
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          97
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
98
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
                                                                                                          99
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
Passed
                  A property is considered as passed when SpyGlass is able to generate a
                  property file for that property.
                  For example, for a property to pass, at least one design state should be
                  reachable in which the property is valid. In all such cases, a sequence of
                  input vectors can be generated (known as witness), which will lead to that
                  particular design state. If it is possible to generate a witness for a property,
                  the property or assertion holds true (or in other words it passes).
Failed
                  A property is considered as failed when the property file for that property
                  cannot be generated under any circumstances.
                  Witness
                  A witness is the input sequence that eventually makes Assertions true
                  while satisfying the given constraints throughout the path.
                  For example, for a property to pass, at least one design state should be
                  reachable in which the property is valid. In all such cases, a sequence of
                  input vectors can be generated, which will lead to that particular design
                  state. This sequence is known as “Witness”. Therefore, if it is possible to
                  generate a witness for a property, the property or assertion holds true, that
                  it is passed.
                  However, if it is not possible to generate a single witness under the given
                  constraints, the property or the assertion fails.
Partially Proved
                  A property is considered as partially-proved when SpyGlass cannot find the
                  property file for that property and also cannot guarantee that generating a
                  property file is not possible.
Others (Internal-Error)
                  A property is considered as Others (Internal-Error) when the value of the
                  design cycle for the clocks in that property cone exceeds the threshold
                  value of 65535.
100
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
Others (Constraints-Conflict)
                  A property is reported as Others (Constraints-Conflict) when constraints in
                  the property cone are not satisfiable.
Not-Analyzed
                  A property is reported as Not-Analyzed when it is switched off in the
                  property file and not analyzed during functional verification.
                                                                                                         101
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
102
                                                  Synopsys, Inc.
                                                         Using the Rules in the SpyGlass Auto Verify Solution
FIGURE 14. Design for which the register info report is generated
                                                                                                         103
                                                 Synopsys, Inc.
Using the Rules in the SpyGlass Auto Verify Solution
104
                                                  Synopsys, Inc.
Rules in SpyGlass Auto
Verify
This chapter describes the functional analysis rules in the SpyGlass Auto
Verify solution.
The rules of the SpyGlass Auto Verify solution belong to any one of the
following categories:
                                                                           105
                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Info Rules
                  The Info rules report information about the design and its attributes.
                  While these rules do not report any design problem, they report
                  assumptions under which SpyGlass validates the other rules.
                  For example, the clock network information provides all clocks in a design
                  along with their frequencies and edges. If the clock definition is incorrect,
                  the other rules may report false violations or some rules may not report
                  certain design problems.
                  The following table describes the rules under this category:
                   Rule                      Reports
                   Av_clkinf01               Information about clocks in the design
                   Av_complexity01           Complexity of a design in terms of characteristics
                                             and complexity of RTL modules and FSMs in the
                                             design
                   Av_fsminf01               FSM statistics for the design
                   Av_fsminf02               Interacting FSMs in the design
                   Av_Info_Case_Analysis     Case analysis settings
                   Av_initstate01            A valid state of the design from which the formal
                                             analysis would actually start
                   Av_report01               Total number of properties analyzed and number of
                                             functional constraints set on the design
                   Av_rstinf01               Information about resets in the design
106
                                            Synopsys, Inc.
                                                                     Rules in SpyGlass Auto Verify
Info Rules
Av_clkinf01
                Reports all the clocks in the design.
When to Use
                Use this rule to check if the clock definitions are as per the design intent.
Description
                The Av_clkinf01 rule reports the following details of clocks in a design:
                 Clock name
                 Clock frequency
                 Rising and falling edges
                 Number of flip-flops working on each edge of the clock.
Parameter(s)
                use_inferred_clocks: The default value is no. Set this parameter to
                yes to use the automatically-generated clock information.
         NOTE: This is the parameter of SpyGlass CDC solution.
Constraint(s)
                clock (Optional): Use this constraint to specify clocks signals in a design.
                                                                                              107
                                           Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                   Argument         Description
                   <clk-type>       Specifies the clock type as any of the following:
                                    • User defined if the clock is specified by using the clock
                                      constraint.
                                    • Default if the clock is inferred by SpyGlass after you have
                                      set the use_inferred_clocks parameter to yes.
                   <clk-name>       Specifies the clock name.
                   <period>         Specifies the clock period in nano seconds (rounded to nearest
                                    0.5)
                   <num1>           Specifies the number of flip-flops triggered at the posedge of the
                                    clock.
                   <num2>           Specifies the number of flip-flops triggered at the posedge of the
                                    clock.
                   <rise-time>      Specifies the rise time of the clock.
                   <fall-time>      Specifies the fall time of the clock.
                  Potential Issues
                  This violation appears if your design contains any of the following types of
                  clocks:
                   The clocks defined by using the clock constraint.
                   The clocks inferred after you set the use_inferred_clocks
                     parameter to   yes.
108
                                               Synopsys, Inc.
                                                                 Rules in SpyGlass Auto Verify
Info Rules
             In the above example, clk1 is defined by using the clock constraint and
             clk2 is automatically detected by SpyGlass.
             Now when you run the Av_clkinf01 rule, the following messages appear
             showing the details of the clk1 and clk2 clocks:
             'Default' Clock 'top.clk2': Period '10.000', '1' flop(s) on
             posedge at '5.000', '0' flop(s) on negedge at '10.000'
                                                                                          109
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
110
                                               Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Info Rules
Av_complexity01
              Reports design characteristics and complexity for all the RTL
              modules and FSMs in the design
When to Use
              Use this rule to understand the complexity of a design for:
               Modularizing or partitioning an RTL.
               Estimating effort needed for block verification and selecting IPs.
Description
              The Av_complexity01 rule reports the complexity of a design in terms of
              characteristics and complexity of RTL modules and FSMs in a design.
              This rule shows the complexity information in The Av_complexity01
              Spreadsheet Report and The Complexity Browser.
              Understanding the complexity of a design is important for the following
              reasons:
               For modularizing/partitioning RTL
               For estimating effort required for block verification and IP selection.
Parameter(s)
              av_dump_instance_complexity: Default value is    no. Set this parameter to
              yes to generate instance-based spreadsheet
              (Av_complexity01_InstanceBased.csv Tab).
Constraint(s)
              None
                                                                                             111
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  Potential Issues
                  Not applicable
112
                                             Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
Info Rules
Av_fsminf01
                 Reports all the FSMs in a design.
When to Use
                 Use this rule to view the FSM statistics of a design.
                 Prerequisites
                 Use the clock constraint to specify clock signals in a design.
Description
                 The Av_fsminf01 rule reports the following information for each FSM in a
                 design:
                  Number of states
                  Number of transitions
                  Number of inputs and outputs to the FSM
                  The encoding style, such as One-Cold, One-Hot, Gray, Minimum, or
                    Custom (See Custom-Style Encoding)
             NOTE: Two-state FSMs with state labels 01 and 10 are reported as one-hot encoded
                   FSMs.
                  The encoding bit information, such as the number of states, number of
                    bits used, and number of extra bits
                  The type of machine, such as mealy, moore, or unknown
                    When the SpyGlass Auto Verify solution is unable to detect the FSM
                    output, the machine type is reported as unknown.
                  The type of next state assignment. For example, simple or non static,
                    such as function calls and arithmetic operations.
             NOTE: In case of non-static next state assignments, the number of states and number
                   of transitions reported may not be the same as those in the actual FSM.
                  FSM depth. For details, see FSM Depth.
                  FSM initial states
                  Cyclomatic complexity of FSM
                                                                                                113
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  FSM Depth
                  The minimum length of a path through which a state can be reached from
                  the initial state of an FSM is known as the state depth from that initial
                  state.
                  FSM depth refers to the maximum of all the state depths from all initial
                  states.
                  Consider the FSM shown in the following figure:
                  In the above FSM,   S1 is the initial state. Different state depths in this case
                  are as follows:
                   State Depth (S2) = 1
                   State Depth (S3) = 1
                   State Depth (S4) = 1
                   State Depth (S5) = 2
                  In this case, FSM depth is the maximum of all state depths, that is 2.
Parameter(s)
                   detect_ifelse_fsm: The default value is no. Set this parameter to yes to
                     detect the   if-else style FSMs in addition to the case style FSMs.
                   detect_nested_fsm: The default value is no. Set this parameter to yes to
                     detect the nested if-else style FSMs, the nested case style FSMs,
                     and the assign style FSMs in addition to detecting the case style
                     FSMs.
114
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Info Rules
Constraint(s)
              clock (Mandatory): Use this constraint to specify clock signals in a
                 design.
              fsm (Optional): Use this constraint to specify FSM details in a design.
                Argument                  Description
                <fsm-name>                Specifies the FSM name
                <num-fsm-states>          Specifies the number of FSM states
                <num-fsm-transitions>     Specifies the number of FSM transitions
                <file-name>               Specifies the location of the Auto Verify FSM
                                          report
                <encoding-type>           Specifies the FSM encoding style, such as s ONE-
                                          HOT, ONE-COLD, GRAY, MINIMUM, or CUSTOM (See
                                          Custom-Style Encoding)
             Potential Issues
             Not applicable
                                                                                             115
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Not applicable
                  `define       S0   2'b00
                  `define       S1   2'b01
                  `define       S2   2'b10
                  `define       S3   2'b11
116
                                             Synopsys, Inc.
                                                              Rules in SpyGlass Auto Verify
Info Rules
             // SGDC File
             current_design Fsm
             clock -name Fsm.clk
             reset -name Fsm.rst -value 0
             For the above example, the Av_fsminf01 rule reports the following
             violation:
             FSM 'Fsm.state' has '4' states and '5' transitions. Encoding
             used is 'MINIMUMENCODED'.Refer file: 'res_av/spyglass_reports/
             auto-verify/Fsm.Info' for details
The following figure shows the FSM Viewer generated in this case:
                                                                                       117
                                      Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
118
                                             Synopsys, Inc.
                                                                  Rules in SpyGlass Auto Verify
Info Rules
Av_fsminf02
              Reports all the interacting FSMs in a design.
When to Use
              Use this rule view the dependency between FSMs in a design.
              Prerequisites
              Specify clocks in a design by using the clock constraint.
Description
              The Av_fsminf02 rule reports the interacting FSMs in the design.
Parameter(s)
               detect_ifelse_fsm: The default value is no. Set this parameter to yes to
                detect the if-else style FSMs in addition to the case style FSMs.
               detect_nested_fsm: The default value is no. Set this parameter to yes to
                detect the nested if-else style FSMs, the nested case style FSMs,
                and the assign style FSMs in addition to detecting the case style
                FSMs.
               detect_assign_fsm: The default value is no. Set this parameter to yes to
                detect the   assign style FSMs in addition to detecting the case style
                FSMs.
Constraint(s)
               clock (Mandatory): Use this constraint to specify clock signals in a
                design.
               fsm (Optional): Use this constraint to specify FSM details in a design.
                                                                                           119
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                   Argument               Description
                   <fsm1-name>            Preceding FSM state variable name
                   <out-net-name>         Name of the output net of the preceding FSM
                   <fsm2-name>            Succeeding FSM state variable name
                   <in-net-name>          Name of the input net of the succeeding FSM
                  Potential Issues
                  This violation appears if your design contains interacting FSMs.
120
                                               Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
Info Rules
               begin
               if(!rst)
                   state <= `S1_0;
               else
                 case(state) // synopsys full_case parallel_case
                 `S1_0 : state <= `S1_1;
                 `S1_1 : begin
                         state <= `S1_2;
                         outp <= 1'b1;
                       end
                 `S1_2 : if (ctl)
                        state <= `S1_3;
                 `S1_3 : if (ctl & !ctl)
                          state <= `S1_1;
                   else
                       state <= `S1_3;
                endcase
               end
               always@(posedge clk or negedge rst)
               begin
               if(!rst)
                   state2 <= `S2_0;
               else
                 case(state2)
                 `S2_0 : state2 <= `S2_2;
                 `S2_1 : state2 <= `S2_0;
                 `S2_2 : if (outp)
                         begin
                              state2 <= `S2_1;
                              outp2 <= 1'b1;
                         end
                endcase
               end
             endmodule
             In the above example contains two FSMs, state and outp, which are
             interacting with each other such that the output of one FSM is used as an
                                                                                        121
                                      Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  input by the other FSM. The following figure shows the FSM viewer that
                  displays the interacting FSMs:
                  For the above example, Av_fsminf02 rule reports the following violation:
                  FSM 'Fsm.state' output 'Fsm.outp' interacts with FSM
                  'Fsm.state2' through input 'Fsm.outp'
122
                                           Synopsys, Inc.
                                                                  Rules in SpyGlass Auto Verify
Info Rules
                                                                                           123
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Av_Info_Case_Analysis
                  Highlights case-analysis settings
When to Use
                  Use this rule to view constant values, such as values set by using the
                  set_case_analysis SGDC constraint on a terminal/net, supply values, or
                  ground values propagating through a design.
                  Prerequisites
                  Specify case analysis signals by using the set_case_analysis constraint.
                  Based on this information, SpyGlass simulates a design and annotates the
                  simulation value (0 or 1) for each accessible net.
Description
                  The Av_Info_Case_Analysis rule generates information to highlight case
                  analysis values and power/ground information in a schematic. This power/
                  ground information is inferred from the design.
                  Information generated by this rule is useful for observing value
                  propagation in a design.
                  It is recommended to run this rule with other rules as this rule provides
                  valuable debug aid to see how case values are propagating through the
                  design.
124
                                            Synopsys, Inc.
                                                                 Rules in SpyGlass Auto Verify
Info Rules
Parameter(s)
             None
Constraint(s)
             None
             Potential Issues
             None
             Consequences of Not Fixing
             None
             How to Debug and Fix
             This rule provides debugging aid to analyze case analysis settings in a
             design.
                                                                                          125
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  Now, select the Edit > Show Info Case Analysis Data menu option in the
                  schematic window.
                  The schematic now changes to the following:
                  In the above figure, constant values appear in the schematic. This enables
                  you to check the path of constant value propagation.
126
                                            Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
Info Rules
             Schematic Details
             The Av_Info_Case_Analysis rule highlights power ground simulation values
             and set_case_analysis constraints propagated through combinational logic.
Rule Group
             INFORMATION
                                                                                        127
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Av_initstate01
                  Reports the initial state of a design
When to Use
                  Use this rule to check the initial state of a design from which formal
                  analysis starts.
         NOTE: The initial state may not be the reset state of the design.
                  Prerequisites
                  Specify clock signals in a design by using the clock constraint.
Description
                  The Av_initstate01 rule reports the initial state of a design from which
                  formal analysis should start.
                  Identifying an Initial State of a Design
                  The Av_initstate01 rule identifies the initial state of a design in the
                  following ways (in the given order of priority):
                   User-defined initial state where the register value assignment is
                     provided using the define_tag constraint.
                   State value generated by external simulation engine as a VCD/TCl/FSDB
                     file (use the simulation_data constraint to provide the file name)
                   Initial state detected by applying a user-defined simulation vector using
                     the define_tag constraint in a SpyGlass Design Constraints file.
                   Initial state determined by SpyGlass Advanced-Lint solution.
                     This search uses the user-specified reset ports (using the reset
                     constraint) or auto-detected reset ports and/or may apply proprietary
                     techniques to identify a reachable state of a design.
         NOTE: If no reset is present in a design, this rule reports a clock as X for uninitialized
               sequential elements.
Parameter(s)
                  ieffort: The default value is   yes. Set this parameter to no to check all the
                  bits of a bus signal.
128
                                               Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Info Rules
Constraint(s)
              clock (Mandatory): Use this constraints to specify clocks in a design.
              define_tag (Mandatory): Use this constraint to define a named condition
                 for the application of certain stimulus at the top port or an internal
                 node.
              reset (Optional): Use this constraint to specify resets in a design.
              simulation_data (Optional): Use this constraint to specify the initial state
                 sequence for a design.
                Argument       Description
                <num1>         Specifies the percentage of sequential outputs initialized
                               with set/reset
                <num2>         Specifies the percentage of sequential outputs initialized with
                               data path
                <file-name>    Specifies the path of the auto_verify.reg file.
             Potential Issues
             Not applicable.
                                                                                                 129
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Rule Group
                  Info
130
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Info Rules
Av_report01
                Reports statistics of properties and functional constraints set on a
                design.
When to Use
                Use this rule to view details of analyzed properties and functional
                constraints set on a design. It provides summarized views of number and
                status of properties in the design.
                Prerequisites
                Specify clock signals in a design by using the clock constraint.
Description
                The Av_report01 rule reports total number of properties analyzed and the
                number of functional constraints set on a design.
         NOTE: The Av_report01 rule is automatically run when you run any rule of SpyGlass Auto
               Verify solution.
                 audit parameter set to yes          The rule reports the number of different
                                                     types of properties in a design.
                                                     The property file specified by the propfile
                                                     parameter is ignored in this case.
                 audit parameter set to no           The rule performs functional analysis and
                                                     reports the number of properties analyzed,
                                                     failed, passed, and partially analyzed.
                                                     The property file specified by the propfile
                                                     parameter is considered in this case.
Parameter(s)
                 audit: The default value is no. Set this parameter to yes to not perform
                   functional analysis.
                 propfile: The default value is NULL. Set this parameter to the name of
                   the property file containing the properties to be checked.
                                                                                                   131
                                           Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Constraints
                  clock (Mandatory): Use this constraint to specify clock signals in a design.
                  The details of the arguments of the above message are described in the
                  following table:
                   Argument         Description
                   <num>            Specifies the total number of properties in the design
                   <imp-num>        Specifies the total number of implicit properties
                   <ovl-num>        Specifies the total number of OVL properties
                   <constr-num>     Specifies the total number of functional constraints
                   <du-name>        Specifies the top-level design name
                   <file-name>      Specifies the name of the generated property file
                  Potential Issues
                  Not applicable.
132
                                            Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
Info Rules
             Message 2
             The following message appears to report the number of properties
             analyzed and number of functional constraints set on a design when the
             audit parameter is not specified:
             [INFO] Implicit: ‘<imp-analyzed-num>’ implicit properties
             analyzed, ‘<imp-failed-num>’ failed, ‘<imp-passed-num>’ passed,
             ‘<imp-partial-num>’ partially analyzed, <imp-not-analyzed-num>
             not analyzed for top design unit ‘<du-name>’. Refer file:
             '<file-name>' for details
             Constraints: ‘<constr-num>’ Functional Constraints for top
             design unit ‘<du-name>’. Refer file: '<file-name>' for details
              Argument                    Description
              <imp-analyzed-num>          Specifies the number of implicit properties
                                          analyzed
              <imp-failed-num>            Specifies the number of implicit properties
                                          failed
              <imp-passed-num>            Specifies the number of implicit properties
                                          passed
              <imp-partial-num>           Specifies the number of implicit properties
                                          partially analyzed
              <imp-not-analyzed-num>      Specifies the number of implicit properties
                                          not analyzed
              <constr-num>                Specifies the total number of functional
                                          constraints
              <du-name>                   Specifies the top-level design name
              <file-name>                 Specifies the generated property file name
             Potential Issues
             Not applicable
                                                                                        133
                                     Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
Rule Group
                  Info
134
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Info Rules
Av_rstinf01
              Reports all the resets in a design.
When to Use
              Run this rule to find resets in a design.
Description
              The Av_rstinf01 rule reports synchronous and asynchronous resets in a
              design.
              This rule tries to trace the connected nets to find reset information and
              accordingly categorize the detected resets, as shown in the following table:
              The rules of SpyGlass Auto Verify solution do not directly use the reset
              information generated by the Av_rstinf01 rule. The recommended
              methodology is to use the Av_rstinf01 rule to generate autoresets.sgdc and
              the generated file should then be reviewed and edited by the user for
              future runs of SpyGlass Auto Verify solution.
                                                                                                 135
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                   If the name of the reset does not match with the pattern specified by
                     the reset_convention parameter, where the reset pin is driven by multiple
                     sources
                     If a reset pin is driven by a single source, the naming convention check
                     is not done and the net is considered as a valid reset.
                  Rule Exceptions
                  The Av_rstinf01 rule has the following exceptions:
                   It does not report presets/clears tied to supply/ground or a constant
                     value due to the set_case_analysis constraint.
                   It uses a heuristic-based approach based on the RTL structure to
                     determine the synchronous resets. The synchronous resets become a
                     part of the data-line path after synthesis. Therefore, they cannot be
                     detected post-synthesis.
                     As a result, this rule might not detect synchronous resets in complex
                     RTL structures, as shown in the following example:
                     always@(posedge clk2)
                       if(rst1 & enable) // Expressions are not detected
                                         //as synchronous resets
                         q <= 1'b0;
                       else
                         q <= d;
Parameter(s)
                   use_inferred_resets: The default value is no. Set this parameter
                     to   yes to use automatically-generated reset information.
            NOTE: This is the parameter of SpyGlass CDC solution.
                   reset_convention: The default value is " ". Set this parameter to a comma
                     or space-separated list of reset names. You may also specify Perl regular
                     expressions.
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clocks in a design.
                   reset (Optional): Use this constraint to specify resets in a design.
136
                                             Synopsys, Inc.
                                                              Rules in SpyGlass Auto Verify
Info Rules
             Potential Issues
             Not applicable
             Message 2
             The following message appears to specify the asynchronous reset detected
             in a design:
             [RSTASYNC] [INFO] Asynchronous <Set | Clear> candidate: <rst-
             name> of type <rst-type>
             The details of the arguments of the above message are as follows:
                                                                                       137
                                     Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  Potential Issues
                  Not applicable
138
                                          Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Info Rules
             For the above example, the Av_rstinf01 rule detects the rst1 reset of the
             type primary clear. The following message appears in this case:
             Asynchronous clear candidate: top.rst1 of type Primary clear
             In addition, this rule generates the   autoresets.sgdc file containing the
             following constraint:
             reset -name "top.rst1" -value 0
             Example 2
             Consider the following example when the reset_convention parameter is set
             to rst*:
             assign syncRst = rst1 & enable;
             always@(posedge clk2)
               if(syncRst)
                 q <= 1'b0;
               else
                 q <= d;
                                                                                             139
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Info Rules
                  For the above example, the Av_rstinf01 rule detects the rst1 reset of the
                  type primary clear. The following message appears in this case:
                  Synchronous clear candidate: top.rst1 of type Primary clear
                  In addition, this rule generates the   autoresets.sgdc file containing the
                  following constraint:
                  reset -name "top.rst1" -value 1 -sync
Rule Group
                  Info
140
                                             Synopsys, Inc.
                                                         Rules in SpyGlass Auto Verify
Info Rules
                                                                                  141
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   Rule                Reports
                   Av_sanity03         Loops in the design
                   Av_sanity04         Over-constraining in a design
                   Av_svasetup01       Issues in SVA constraints
142
                                            Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
Av_sanity03
                 Reports loops in a design
When to Use
                 Use this rule during functional analysis to detect loops in a design.
Description
                 The Av_sanity03 rule reports the following loops in a design:
                  All combinational loops
                  Loops involving clock to Q, preset to Q, or clear to Q paths of a flip-flop
                 If you want to check over constraining due to unstable combinational
                 loops, run the Av_sanity04 rule.
        NOTE: By default, this rule is not run.
Parameter(s)
                 None
Constraint(s)
                  set_case_analysis (Optional): Use this constraint to specify case analysis
                     conditions.
                  clock (Optional): Use this constraint to specify clock signals in a design.
                  reset (Optional): Use this constraint to specify reset signals in a design.
Potential Issues
                                                                                               143
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  Sanity
144
                                            Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
                                                                                        145
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_sanity04
                  Reports over-constraining in a design
When to Use
                  Use this rule in the pre-layout phase of a design to detect over-constraining
                  in the design.
Description
                  The Av_sanity04 rule reports over-constraining in a design.
                  SpyGlass Auto Verify consolidates all the user-specified and generated
                  constraints and applies them together. The Av_sanity04 rule reports
                  conflicting constraints in the Overconstrain Info File in the current working
                  directory.
         NOTE: By default, this rule is not run.
                  Potential Issues
                  Not applicable
146
                                              Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
                 For the above example, the Av_sanity04 rule reports a violation because
                 the active value specified by the reset and the set_case_analysis constraint is
                 same for the same net.
                 Example 2
                 Consider the following constraints specified for a design:
                 clock -name clk1 -period 5
                 reset -name clk1 -value 0
                 For the above example, the Av_sanity04 rule reports a violation because of
                 the conflicting reset and clock constraints on the same net.
                 Example 3
                 Consider the following figure:
clkfast clkslow
For the above example, the Av_sanity04 rule reports a violation because of
                                                                                                147
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Example 4
                  Consider the following files specified during SpyGlass analysis:
                  For the above example, the Av_sanity04 rule reports a violation because of
                  conflicting OVL constraints.
Rule Group
                  Sanity
148
                                              Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Av_svasetup01
                 Setup issues in SVA constraints
When to Use
                 Use this rule to parse SVA constraints and report issues related with these
                 constraints.
                 Prerequisites
                 Specify the following project-file command:
                 set_option enableSVA yes
Description
                 The Av_svasetup01 rule parses SVA constraints and reports issues related
                 with these constraints.
                 For details, refer to the Using SystemVerilog Assertions application note.
Parameter(s)
                 None
Constraint(s)
                 None
                                                                                             149
                                           Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  SETUP
150
                                              Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                    Rule             Reports...
                    Av_bitstuck01    Nets that are stuck at a constant value after functional
                                     analysis
                    Av_staticnet01   Globally stuck-at-0 or stuck-at-1 nets in a design
                    Av_bus01         Cases where multiple drivers (more than one) are writing
                                     into a bus line simultaneously
                    Av_bus02         Un-driven bus lines
                    Av_case01        case constructs with a fullcase pragma attribute
                                     attached and the case items are not complete (not all items
                                     are present)
                    Av_case02        Overlapping items of a case construct when the case
                                     construct is associated with a parallel case pragma
                    Av_deadcode01    Dead code caused by a condition never triggered
                    Av_dontcare01    X assignments that are found to be reachable
                    Av_fsm01         Unreachable or deadlocked FSM States
                    Av_fsm02         Edges between two states of an FSM that cannot be
                                     sensitized
                    Av_range01       (Verilog) Arrays that can potentially be accessed with an
                                     index outside the range of the array
                    Av_setreset01    Flop with simultaneous active asynchronous set and
                                     asynchronous reset
                    Av_staticreg01   All the static registers in the design which do not change its
                                     value after attaining it once.
                    Av_staticreg02   Static sequential elements in the design
                    Av_syncfifo01    Overflow or underflow for synchronous FIFOs in a design
                                                                                                  151
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_bitstuck01
                  This rule is deprecated
152
                                             Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
Av_staticnet01
                  Reports globally stuck-at-0 or stuck-at-1 nets in a design.
When to Use
                  Use this rule to detect nets that are stuck to a constant value.
                  Prerequisites
                  Specify clocks in a design by using the clock constraint.
Description
                  The Av_staticnet01 rule reports globally stuck-at-0 nets (s-a-0) or
                  stuck-at-1 nets (s-a-1) for the following statements:
                   LHS of variable assign statement
                      In this case, this rule checks if the register (flip-flop or latch) that is
                      generated by the LHS of a variable assignment is s-a-0 or s-a-1.
                   LHS of explicit assign statement
                      In this case, this rule checks if the assigned net in the LHS of an explicit
                      assignment is s-a-0 or s-a-1.
                   RHS of explicit assign statement
                      In this case, this rule checks if the read net in the RHS of an explicit
                      assignment is s-a-0 or s-a-1.
                  Rule Exceptions
                  The Av_staticnet01 rule has the following exceptions:
                   It does not check for the variable assignment in the combinational
                      always block.
                   It does not report a violation for the signals that cannot be initialized to
                      an initial state.
                      For example, consider the following figure:
                                                                                                    153
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Parameter(s)
                   staticnet_scope: The default value is flop. Set this parameter to lhs to
                     perform rule-checking only on the LHS assignment nets. The other possible
                     values are rhs and all.
                   buscompress: The default value is yes. Set this parameter to no to check
                     all the bits of a bus signal.
                   use_inferred_clocks: The default value is no. Set this parameter
                     to   yes to use automatically-generated clock information.
            NOTE: This is the parameter of SpyGlass CDC solution.
                   use_inferred_resets: The default value is no. Set this parameter
                     to   yes to use automatically-generated reset information.
            NOTE: This is the parameter of SpyGlass CDC solution.
                   fv_debug_sim_cycles: The default value is 0. Set this parameter to any
                     positive integer to display waveform from the initial state for the failed
                     properties of the Av_staticnet01 rule.
154
                                             Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                      internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                      design.
                   meta_design_hier (Optional): Use this constraint to specify the top-level
                      design name and the hierarchical name of the design with respect to the
                      simulation test bench to be used during SVA dumping of Partially Proved
                      Properties.
                                                                                                155
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   Argument       Description
                   <expr-type>    Specifies the expression type, such as RHS net, LHS net, or
                                  LHS reg variable.
                   <net-name>     Specifies the net name.
                   <reason>       Specifies the following text:
                                  reason: static nets in fanin cone)
                  Potential Issues
                  This violation appears if your design contains nets that are stuck to a
                  constant value.
156
                                             Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
                  For the above example, the Av_staticnet01 rule checks for the following
                  nets:
                   rseq1 in the LHS of variable assign statement
                   w1 and w4 in the LHS of explicit assign statement. This is checked when
                      staticnet_scope parameter is set to   lhs.
                   in1, w2, and w3[0] in the RHS of the explicit assign statement. This
                      is checked when staticnet_scope parameter is set to   rhs.
                  Now consider that w2 is stuck-at-1 in the above example. This case results
                  in a chain of stuck-at-1,that is, w2=>w1=>w4, and the Av_staticnet01
                  rule reports all the nets in the chain.
                  Example 2
                  Consider the example shown in the following figure:
                                                                                               157
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Flop1Rst
                  For the above example, the Av_staticnet01 rule reports the        and_out
                  signal that is stuck-at-0.
Rule Group
                  Implicit-Properties
158
                                             Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
Av_bus01
                  Reports all the bus contentions in a design.
When to Use
                  Use this rule to detect cases resulting in bus contention.
                  Prerequisites
                  Specify clocks in the design by using the clock constraint.
Description
                  The Av_bus01 rule reports a violation when multiple drivers write to a
                  bus-line simultaneously.
Parameter(s)
                  av_dump_assertions: The default value is “”. Set this parameter to    sva to
                  generate SystemVerilog Assertions (SVA).
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                      internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                      design.
                                                                                                159
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design contains drivers that write to a
                  bus-line simultaneously.
160
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
//test.v
                  Project File:
                  set_parameter use_inferred_clocks yes
                                                                                             161
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
162
                                            Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
                  The above waveform shows the enables that are active at the same time,
                  resulting in the contention on output.
                  To fix this violation, ensure that tri-state drivers are not active in the
                  design simultaneously.
Rule Group
                  Implicit-Properties
                                                                                                   163
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_bus02
                  Reports all the floating buses in the design.
When to Use
                  Use this rule to ensure that all the enables driving a bus are not inactive
                  simultaneously.
                  Prerequisites
                  Specify clocks in a design by using the clock constraint.
Description
                  The Av_bus02 rule reports undriven bus lines.
Parameter(s)
                  av_dump_assertions: The default value is “”. Set this parameter to       sva to
                  generate SystemVerilog Assertions (SVA).
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
164
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design contains undriven bus lines.
                  A bus line is undriven when all the enables driving the bus line are inactive
                  simultaneously.
                                                                                                 165
                                                Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  // test.v
                  `define       STATE1   4'b1000
                  `define       STATE2   4'b0100
                  `define       STATE3   4'b0010
                  `define       STATE4   4'b0000
166
                                              Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Project File:
                  set_parameter use_inferred_clocks yes
                                                                                                 167
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  To fix this violation, ensure that at least one driver is always active for the
                  reported bus.
         NOTE: This rule does not require user specified properties.
Rule Group
                  Implicit-Properties
168
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Av_case01
                  Reports reachable case items that are not specified.
When to Use
                  Use this rule to check for coding issues related to   case statements.
                  Prerequisites
                  Specify clock signals in the design by using the clock constraint.
Description
                  The Av_case01 rule reports reachable case items that are missing in the
                  case statement on which the full_case pragma or the priority
                  modifier is attached.
                  Points to be Noted
                  Please note the following points:
                   Note that when a function containing a case statement is called multiple
                      times, this rule reports a violation at the line containing the case
                      expression for each violating function call. Such violations may appear
                      duplicate.
                      In such cases, use the schematic of a violation to analyze the
                      corresponding function call.
                   In case of the unique case without a default label, both the
                      Av_case01 and Av_case02 rules are checked.
                  Rule Exceptions
                  The Av_case01 rule has the following exceptions:
                   It does not report violation for the case statements that have a default
                      branch.
                   It does not report a violation if the missing (uncovered) case item can
                      never be executed. Such items are known as unreachable case items.
                                                                                                 169
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   It does not check functions that are without a begin-end block and
                     contain a case statement in which the expression is a case-select
                     expression, containing an operator, over the inputs of the function.
Parameter(s)
                  av_dump_assertions: The default value is “”. Set this parameter to     sva to
                  generate SystemVerilog Assertions (SVA).
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
                   Argument                Description
                   <sig-name-list>         Specifies the case statement sensitivity signals
                   <case-item-name>        Specifies the case item that is not covered
170
                                            Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design file contains a case statement with
                  the full_case pragma or a priority modifier, and one of the case
                  items to be executed is missing.
                                                                                                  171
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  Implicit Properties
172
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Av_case02
                  Reports overlapping case items of the case statement that have the
                  parallel_case pragma or the unique modifier attached.
When to Use
                  Use this rule to check for coding issues related to   case statements.
                  Prerequisites
                  Specify clock signals in the design by using the clock constraint.
Description
                  The Av_case02 rule reports Overlapping Case Items of the case statement
                  that have the parallel_case pragma or the unique modifier
                  attached.
                  Note that when a function containing a case statement is called multiple
                  times, this rule reports a violation at the line containing the case
                  expression for each violating function call. Such violations may appear
                  duplicate. In such cases, use the schematic of a violation to analyze the
                  corresponding function call.
                                                                                                 173
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                       endcase
                  Rule Exception
                  The Av_case02 rule does not check functions that are without a
                  begin-end block and contain a case statement in which the expression
                  is a case-select expression, containing an operator, over the inputs of
                  the function.
Parameter(s)
                  av_dump_assertions: The default value is “”. Set this parameter to     sva to
                  generate SystemVerilog Assertions (SVA).
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
174
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                    Argument           Description
                    <case-item-list>   Specifies the overlapping items for each overlapping
                                       pair
                    <label>            Specifies the expanded label.
                  Potential Issues
                  This violation appears if the design file contains Overlapping Case Items in
                  the case statement on which the parallel_case pragma or the
                  unique modifier is attached.
                                                                                                 175
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  In the above example, 2'bx1 and 2'b11 are overlapping case items.
                  Therefore, the Av_case02 rule reports the following violation:
                  Case statement has overlapping items x1, 11 (Expanded Label:
                  '11')
Rule Group
                  Implicit Properties
176
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Av_case03
                  Reports overlapping case items of the case statement without the
                  parallel_case pragma attached.
When to Use
                  Use this rule to check for coding issues related to   case statements.
                  Prerequisites
                  Specify clock signals in the design by using the clock constraint.
Description
                  The Av_case03 rule reports a violation when the case statement does not
                  have the parallel_case pragma attached, and there are Overlapping
                  Case Items in the case statement.
Parameter(s)
                  None
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                      internal signal.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                                                                                                 177
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   Argument           Description
                   <case-item-list>   Specifies the overlapping items for each overlapping
                                      pair
                   <label>            Specifies the expanded label resulting from the overlap
                                      between the case labels
                  Potential Issues
                  This violation appears if your design file contains Overlapping Case Items in
                  the case statement on which no parallel_case pragma is attached.
178
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
                  In the above example, x0 and 10 are overlapping case items. In both the
                  states, the value of out at one place is 0 and it is 1 at the other place.
Rule Group
                  Implicit Properties
                                                                                             179
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_deadcode01
                  Reports redundant logic in the design.
When to Use
                  Use this rule to detect redundant logic in a design due to the presence of
                  dead code.
                  Prerequisites
                  Specify clock signals by using the clock constraint.
Description
                  The Av_deadcode01 rule reports dead codes caused by a condition that is
                  never triggered.
                  This rule does not report redundancies due to re-convergent paths. It only
                  detects the RTL code that can never be exercised due to a branching that is
                  stuck at a false value.
180
                                            Synopsys, Inc.
                                                                     Rules in SpyGlass Auto Verify
                                w2 = w4;
                              end
                            end
                          end
                        end
                      end
                      else
                        w2 = 1'b0;
                      end
                  For the above example, the Av_deadcode01 rule reports violation for the
                  assertions in the top-level if block. The following figure shows the
                  violation in this case:
FIGURE 17.
                                                                                              181
                                           Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  sorted based on the assertions depth within the   if, else-if, or else
                  block.
                  The following figure shows the grouped violations of the Av_deadcode01
                  rule:
Parameter(s)
                   av_dcode_analysis: The default value is soft. Set this parameter to
                    strict to use the strict approach for verification of assertions.
                   av_dcode_report: The default value is minimal. Set this parameter to
                    all to group violations of the same if block, else-if block, or else
                    block of a nested if block.
                   av_force_soft_reset: The default value is Av_setreset01. Set this
                    parameter to no to consider a reset as a hard reset.
                   dead_code_scope: The default values are if,
                    case_without_default, generate, and always. Set the value
                     of this parameter to specify the constructs to be checked. Other possible
                     values are case, if_case, condasgn, and if_case_condasgn.
182
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                      internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                      design.
                   meta_design_hier (Optional): Use this constraint to specify the top-level
                      design name and the hierarchical name of the design with respect to the
                      simulation test bench to be used during SVA dumping of Partially Proved
                      Properties (under the av_dump_assertions parameter).
                                                                                                 183
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design file contains dead code.
                  Message 2
                  The following message appears if constant value propagation has trivially
                  resulted in the dead code:
                  [DEADCODE] [WARNING] Dead code exists as condition is always
                  false (reason: static nets in fanin cone) [Hier:<hier-name>]
                  In addition, if a set of conflicting constraints are specified for the design,
184
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design file contains dead code.
                  Message 3
                  The following message appears if optimization due to synthesis results in
                  the dead code:
                  [DEADCODE] [WARNING] Dead code exists as condition is always
                  false (reason: synthesis optimized logic) [Hier:<hier-name>]
                  Potential Issues
                  This violation appears if your design file contains dead code due to
                  optimization done by synthesis.
                                                                                                 185
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Message 4
                  The following message appears if a function is declared but not instantiated
                  in any module:
                  [DEADFUNC] [WARNING] Function <function-name> declared but not
                  used in module <module-name>
                  Potential Issues
                  Not applicable.
186
                                            Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  In the above example,    sel is assigned the value 2'b00 before the case
                  construct is executed.
                  Now, during the execution of the case construct, the conditions in which
                  the value of sel is 2'b01 and 2'b10 are never reached as sel is
                  already assigned the value 2'b00.
                  As a result, the lines highlighted in red in the above code are never
                  executed. These lines are therefore considered as dead code and such
                  situation is reported by the Av_deadcode01 rule.
         NOTE: For a particular select pin, this rule reports only one message.
                  Consider another example. If the dead code is due to non-static nets,
                  schematic from enabling condition of the dead code block until the first RTL
                  net in the fan-in cone is displayed as shown below:
                                                                                                  187
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Example 2
                  Consider the following example:
                  module top(in1, in2, cond, q);
                    input in1, in2, cond;
                    output reg q;
                    always
                      if(cond == cond) // Always true
                        q = in1;
                      else
                        q = in2 ;      // dead code
                  endmodule
188
                                           Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Example 3
                  Consider the following example:
                  always@(posedge clk or posedge rst or posedge set)
                       if(rst)
                                 out <= 1'b0;
                      else if(set)
                                out <= 1'b1;
                      else
                               out <= in;
Rule Group
                  Implicit Properties
                                                                                                 189
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_dontcare01
                  Reports sensitizable X-assignments in the design.
When to Use
                  Use this rule to understand the conditions under which X-assignments are
                  reachable.
                  Prerequisites
                  Specify clock signals by using the clock constraint.
Description
                  The Av_dontcare01 rule reports X assignments that are reachable.
Parameter(s)
                   xassign_casedefault: The default value is no. Set this parameter to yes to
                     check for X-assignments inside the      default clause of the case
                     statement.
                   include_construct: The default value is none. Set this parameter to
                    generate to check the generate_block constructs. Other possible
                    values are always_comb and none.
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                     generate SystemVerilog Assertions (SVA).
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
190
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears when the RHS of an assignment that has a static
                  value containing X gets executed.
                                                                                                 191
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  In the above example, the user may assume that the X assignment in the
                  above code is not reachable. As a result, the user may consider that the
                  sel1 signal can attain the values 1 and 2 only.
                  However, since the X assignment is reachable in this case, sel1 can also
                  toggle to the values 0, 1, 2, and 3. Therefore, this rule reports a violation
                  at the X assignment.
Rule Group
                  Implicit-Properties
192
                                             Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
Av_fsm_analysis
                  Reports FSM related issues in the design
When to Use
                  Use this rule to detect FSM issues in a design.
Description
                  The Av_fsm_analysis rule reports the following FSM issues in a design:
                   Unreachable State of an FSM
                   Deadlocked State of an FSM
                   Dead Transition of an FSM
                   Live Locks in an FSM
                                                                                               193
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  cannot be exercised.
                  Dead transitions may result in Unreachable State of an FSM or Deadlocked
                  State of an FSM.
Parameter(s)
                  av_dump_liveness: The default value is     assert. Set this parameter to
                  cover to generate the SystemVerilog Assertions (SVA) in terms of cover.
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   fsm (Optional): Use this constraint to specify FSM details in a design.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
194
                                            Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if the design contains the following issues:
                   Unreachable State of an FSM
                   Deadlocked State of an FSM
                   Dead Transition of an FSM
                   Live Locks in an FSM
                                                                                                  195
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
                           transition.
                  If the FSM that is unreachable or deadlocked is present in an IP and you do
                  not want to report within the IP, specify the ip_block constraint for the IP.
                  Message 2
                  This rule reports the following message:
                  [WARNING] FSM '<FSM-name>' not analyzed (Reason:
                  Constraint-Conflict).
                  Potential Issues
                  Not applicable
196
                                                Synopsys, Inc.
                                                            Rules in SpyGlass Auto Verify
                  `define S9 5'b01001
                  module Fsm(input rst, clk, in, en1, en2, en3, en4, output reg
                  out);
                  reg [15:0] counter ;
                  reg [4:0] state;
                  always @(posedge clk or posedge rst) begin
                      if(rst) begin
                          counter <= 0;
                          out <= 1'b0;
                      end
                      else begin
                          counter <= counter + 1;
                          out<= state[3] & in;
                      end
                  end
                  always @(posedge clk or posedge rst) begin
                      if(rst) begin
                          state <= `S0 ;
                      end
                      else begin
                          case(state)
                              `S0:
                                   if(en1) begin
                                       state <= `S1;
                                   end
                                   else if(en2) begin
                                       state <= `S2;
                                   end
                                   else begin
                                       state <= `S3;
                                   end
                              `S1:
                                   if(counter >=16'b0011111111111111) begin
                                       state <= `S4;
                                   end
                              `S2:
                                       state<=`S5;
                              `S3:
                                                                                     197
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
                                          if(en3) begin
                                              state<=`S5;
                                          end
                                   `S5:
                                          if(en3 == 0) begin
                                              state<=`S6;
                                          end
                                          else if(en3 == 1) begin
                                              state <= `S9;
                                          end
                                          else begin
                                              state<=`S0;
                                          end
                                   `S6:
                                          state<=`S7;
                                   `S7:
                                          state<=`S8;
                                   `S8:
                                          if(en3) begin
                                              state<=`S6;
                                          end
                                   `S9:
                                          if(en1 || en2) begin
                                          state <=`S4;
                                          end
                                endcase
                        end
                  end
                  //assume property(@(posedge clk) (state == `S5 |-> (en3 |->
                  en4)));
                  endmodule
                  constr.sgdc
                  current_design Fsm
                  clock -name Fsm.clk -period 10
                  reset -name Fsm.rst -value 1
                  set_case_analysis -name Fsm.en1 -value 0
198
                                              Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
                  After running SpyGlass with the test.v and constr.sgdc files, the following
                  FSM Viewer is generated by the Av_fsm_analysis rule:
                                                                                                199
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  Implicit-Properties
                  In the above spreadsheet, the state with the minimal depth from the initial
                  state is displayed first. The states with the same depth can appear in any
200
                                              Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  order.
                  For example, based on the FSM Viewer in Figure 21, S1 and S2 can appear
                  in any order as they are at the same depth. However, S1 or S2 should
                  come before S4.
                  On clicking an unreachable state in the above spreadsheet:
                   The corresponding state is highlighted in the FSM Viewer.
                   The corresponding FSM state net is highlighted in the schematic.
         NOTE: A state that is reported as unreachable is not reported as a deadLock state.
                  Deadlock_States Tab
                  Each row under this tab shows the name of one dead state.
                  For example, based on the FSM Viewer shown in Figure 21, the following
                  figure shows the contents under this tab:
                                                                                                 201
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
FIGURE 24.
202
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                                                                                                 203
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_divide_by_zero
                  Reports divide/modulo by zero violation
When to Use
                  Use this rule to detect cases where a non-constant signal is used as a
                  divisor.
Description
                  The Av_divide_by_zero rule reports the division operator (/) or modulo
                  operator (%) used in an expression in which a divisor can become zero.
         NOTE: This rule is applicable for Verilog designs only.
                  Language
                  Verilog
Parameter(s)
                   include_construct: The default value is none. Set this parameter to
                    generate to check the generate_block constructs. Other possible
                    values are always_comb and none.
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                     generate SystemVerilog Assertions (SVA).
Constraints
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
204
                                              Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
                  Potential Issues
                  A non-constant signal is used as a divisor.
                                                                                               205
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
          // test.v                                         constr.sgdc
          module top(clk, a, b, c, d, e);                   current_design top
           input clk, a, b, c, d;                           clock -name clk -period 10
           output reg e;
           always @ (posedge clk) begin
               e <= c + 1/b;
           end
           always @ (posedge clk) begin
               e = c + 1/b;
           end
          endmodule
FIGURE 26.
                  To debug the violation, open the waveform. The following figure shows the
                  waveform generated for the first violation:
206
                                           Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
FIGURE 27.
                  The waveform shows the direct fan-in of the violating net and the fan-in
                  RTL net. It will have pop-up help and consistency of colors with schematic.
Rule Group
                  Implicit Property
                                                                                                   207
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_negative_shift
                  Reports arithmetic shift by negative value violations
When to Use
                  Use this rule check for the presence of a negative value in the RHS of all
                  the arithmetic shift operators.
Description
                  The Av_negative_shift rule checks for a negative RHS value in the right-
                  hand side of all the arithmetic shift operators. If a negative value is found,
                  the Av_negative_shift rule reports a violation message for the shift
                  operator.
         NOTE: This rule is applicable for Verilog designs only.
                  Language
                  Verilog
Parameter(s)
                   include_construct: The default value is none. Set this parameter to
                    generate to check the generate_block constructs. Other possible
                    values are always_comb and none.
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                     generate SystemVerilog Assertions (SVA).
Constraints
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
208
                                              Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Arguments
                   Left or Right, to denote the right arithmetic shift or left arithmetic shift,
                      <operator_position>
                   Value of the net at the failing point or failing sequence, <value>
                   expression, <expression>
                  Potential Issues
                  A negative value exists in the RHS of the arithmetic shift operator
                                                                                                 209
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  operator does not have a negative value. If multiple drivers that are active
                  simultaneously are in an IP and you do not want to report within the IP,
                  specify the ip_block constraint for the IP.
 input clk;
 input [7:0] a, b;
 output reg signed [7:0] c, d;
 output reg [7:0] e;
endmodule
                  To debug the violation, open the Auto Verify Report. This report displays the
                  functional analysis statistics of a design.
Rule Group
                  Implicit Property
210
                                            Synopsys, Inc.
                                                        Rules in SpyGlass Auto Verify
                                                                                 211
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_fsm01
                  Reports unreachable or deadlocked states of an FSM.
When to Use
                  Use this rule to verify the functionality of an FSM in a design.
                  Prerequisites
                  Specify clock signals by using the clock constraint.
Description
         NOTE: This rule will be deprecated in a future SpyGlass release. Use the Av_fsm_analysis
               rule instead of this rule.
                  The Av_fsm01 rule reports a violation in the following cases:
                   Unreachable State of an FSM
                   Deadlocked State of an FSM
                  The Av_fsm01 rule works only on the Finite-State Machines (FSMs) that
                  identified by SpyGlass Auto Verify solution.
212
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Parameter(s)
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                      generate SystemVerilog Assertions (SVA).
                   av_dump_liveness: The default value is assert. Set this parameter to
                      cover to generate the SystemVerilog Assertions (SVA) in terms of
                      cover.
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                      internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                      design.
Potential Issues
                                                                                                 213
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
214
                                             Synopsys, Inc.
                                                             Rules in SpyGlass Auto Verify
                      // FSM1
                      always @(posedge clk1) begin
                        if(reset)
                          fsm1s <= `FSM1S1;
                        else
                          case(fsm1s) // synopsys full_case
                                       // synthesis parallel_case
                            `FSM1S1: fsm1s <= `FSM1S2;
                            `FSM1S2: fsm1s <= `FSM1S3;
                            `FSM1S3: fsm1s <= `FSM1S4;
                            `FSM1S4:
                               if(ctl) fsm1s <= `FSM1S1;
                          endcase
                      end
                      // FSM2
                      always @(posedge clk2) begin
                        if(fsm1s == `FSM1S4) // FSM1 initializes FSM2
                          fsm2s <= `FSM2S1;
                        else
                          case(fsm2s) // synopsys full_case
                                       // synthesis parallel_case
                            `FSM2S1:
                              if(fsm1s == 4'b1100)
                                                                                      215
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
216
                                           Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  To fix this violation, modify the RTL to introduce a transition to the reported
                  unreachable state.
                  See also Viewing Conditional Expression of a Transition in the FSM Viewer.
                                                                                                  217
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  `define S2 2'b10
                  `define S3 2'b11
218
                                           Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  In the above example, analyze the RTL to determine the cause of the
                  deadlocked state and modify the RTL accordingly.
                  See also Viewing Conditional Expression of a Transition in the FSM Viewer.
Rule Group
                  Implicit-Properties
                                                                                                      219
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
220
                                             Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
Av_fsm02
                  Reports the dead transition of an FSM.
When to Use
                  Use this rule to verify the functionality of FSM in the design.
                  Prerequisites
                  Specify clock signals by using the clock constraint.
Description
         NOTE: This rule will be deprecated in a future SpyGlass release. Use the Av_fsm_analysis
               rule instead of this rule.
                  The Av_fsm02 rule reports the Dead Transition of an FSM.
                                                                                                  221
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Rule Exceptions
                  In case of multiple transitions, SpyGlass first merges the transitions before
                  running this rule. Consequently, this rule does not report an inactive
                  transition from state A to state B if there are other active transitions from
                  the same state A into state B.
Parameter(s)
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                     generate SystemVerilog Assertions (SVA).
                   av_dump_liveness: The default value is assert. Set this parameter to
                     cover to generate the SystemVerilog Assertions (SVA) in terms of
                     cover.
Constraints
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
222
                                            Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design contains an FSM that is in a dead
                  transition state. For details, see Dead Transition of an FSM.
                                                                                                 223
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  `define       S0   2'b00
                  `define       S1   2'b01
                  `define       S2   2'b10
                  `define       S3   2'b11
224
                                               Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                  To fix the above violation, correct the fan-in cone nets in the condition
                  expression or the expression itself to fix the dead state transition.
                  See also Viewing Conditional Expression of a Transition in the FSM Viewer.
                                                                                                     225
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  Implicit-Properties
226
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
Av_range01
                  Reports array bound violation.
When to Use
                  Use this rule to detect the arrays in the RTL that are accessed out of the
                  range assigned to them.
                  Prerequisites
                  Specify clock signals in a design by using the clock constraint.
Description
                  The Av_range01 rule reports arrays that can be accessed with an index
                  that is outside the range of the array.
         NOTE: The Av_range01 rule is applicable for Verilog designs only.
Parameter(s)
                   include_construct: The default value is none. Set this parameter to
                    generate to check the generate_block constructs. Other possible
                    values are always_comb and none.
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                      generate SystemVerilog Assertions (SVA).
Constraints
                   clock (Mandatory): Use this constraint to specify clock signals in a
                      design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                      conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                      design where functional analysis should stop.
                                                                                                 227
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   Argument        Description
                   <sig-name>      Specifies the name of the signal
                   <value>         Specifies the value of the signal <sig-name> for which the array
                                   bound violation occurs
                   <dimension>     Specifies the dimension of the variable
                   <var-name>      Specifies the variable name
                   <allowed-       Specified the allowed range of the variable
                   range>
                   <hier>          Specifies the hierarchical name of the module in which the
                                   violation occurred.
                  Potential Issues
                  This violation appears if your design file contains an array that is accessed
                  with an index outside the range of the array.
228
                                             Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
endmodule
                                                                                               229
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
Rule Group
                  Implicit-Properties
230
                                             Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
Av_setreset01
                  Reports flip-flop with simultaneous active asynchronous set and
                  asynchronous reset
When to Use
                  Use this rule to check if your design contains flip-flops with both reset and
                  set.
                  Prerequisites
                  Specify clock signals in the design by using the clock constraint.
Description
                  The Av_setreset01 rule reports a violation when flip-flops with both
                  asynchronous set and asynchronous reset are asserted at the same time.
                  For example, consider the following figure:
rst
set
                  During optimization, some tools assume that reset takes priority over set in
                  the above flip-flop resulting in possible active reset and set simultaneously.
                  This may result in the following situations in the design:
                   When the reset is asserted on a positive edge, the reset or preset may
                      reach first. If the preset reaches first, a glitch may be generated at the
                      output of the above flip-flop.
                   When reset is de-asserted followed by set de-asserted, the reset or set
                      may reach first. In this case, the flip-flop will come out of the reset in
                      state "1" (instead of "0") since preset is deasserted last.
                  The following figure shows the waveform pertaining to the above cases:
                                                                                                  231
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
rst
set
out
Parameter(s)
                  av_force_soft_reset: The default value is  Av_setreset01. Set this
                  parameter to     no to consider a reset as a hard reset.
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                   ip_block (Optional): Use this constraint to specify IP blocks in your
                     design.
232
                                             Synopsys, Inc.
                                                                        Rules in SpyGlass Auto Verify
                  Potential Issues
                  This violation appears if your design contains flip-flops that are asserted
                  with a set and reset simultaneously.
                                                                                                 233
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
                        else
                          out <=      D;
                       end
                  endmodule
                  Project File:
                  set_parameter user_inferred_clocks yes
                  In the above example, if rst and prst become active at the same time
                  and prst appears first then the out flip-flop will be high first and then it
                  will be driven low as soon as rst goes high. This will create a glitch at the
                  output of the flop.
                  The following figure shows the schematic of the out flip-flop in this case:
                  The waveform of the above violation displays the condition when set and
                  reset of the out flip-flop are active simultaneously. See the following
                  figure:
234
                                            Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
Rule Group
                  Implicit-Properties
                                                                                                   235
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_staticreg01
                  This rule is deprecated.
236
                                           Synopsys, Inc.
                                                                           Rules in SpyGlass Auto Verify
Av_staticreg02
                  Reports static sequential elements in a design.
When to Use
                  Use this rule to check if sequential elements have any input tied to a
                  constant value.
                  Prerequisites
                  Specify clock signals by using the clock constraint.
Description
                  The Av_staticreg02 rule reports a summary of Static Sequential Elements in a
                  design.
                  This rule identifies sequential elements as static when any of the following
                  conditions hold true after applying case-analysis (by using the
                  set_case_analysis constraint) and VDD/VSS (power/ground) propagation in
                  a design:
                   Always active reset/clear
                   Constant clock
                   Inactive load
                   Constant data
                  For library cells, this rule reports an instance as static if any of the data
                  input is static. For multiple clocks, this rule reports an instance as static if
                  any of the clocks is static.
         NOTE: This rule does not initialize flip-flops by using resets.
Parameter(s)
                  show_static_latches: The default value isyes. Set this parameter to          no to
                  stop reporting static latches in the spreadsheet.
                                                                                                    237
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
Constraint(s)
                   clock (Mandatory): Use this constraint to specify clock signals in a
                     design.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                     modules or hierarchies on which formal analysis should be ignored or
                     performed.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                     conditions.
                   breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                   watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                  Potential Issues
                  This violation appears if your design does not contain any static sequential
                  element.
238
                                            Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
                  Message 2
                  The following warning message appears to report the percentage of
                  sequential elements that have at least one of the inputs tied to a constant:
                  [SR2WRN] [WARNING] Top design unit <top-du-name> :
                  <seq-elements-percentage> percent of sequential elements have
                  at least one of the inputs tied to constant
                  Potential Issues
                  This violation appears if your design contains sequential elements that
                  have at least one of the inputs tied to a constant value.
                                                                                               239
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
      //test.v                                               //constraints.sgdc
      module D_ff(q,d,clk,reset,preset);                     current_design D_ff
      output q;
      input d,clk,reset,preset;                              clock -name D_ff.clk -period 10
      reg q;                                                 reset -name D_ff.preset -value 1
      wire w1, w2;
      assign w1 = 1 'b1;
      assign w2 = d & w1;
       always@(posedge clk or posedge reset or posedge preset)
      if(reset)
        q <= 1 'b0;
      else if(preset)
        q <= 1 'b1;
      else
        q <= w2;
      endmodule
                  For the above example, the Av_staticreg02 rule generates the following
                  schematic:
240
                                            Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
                  Example 2
                  Consider the following Verilog and SGDC files:
// test.v // Constraints.sgdc
                  In the above example, the pins of the sequential element     q are static.
                  Therefore, the Av_staticreg02 rule reports a violation.
                  When you double-click on the violation of this rule, the following
                  spreadsheet appears:
                                                                                               241
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  In the above spreadsheet, click 1 in the ID column, and open the Modular
                  Schematic window. The following schematic appears:
242
                                            Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
                  Example 3
                  Consider the following Verilog and SGDC files:
    // test.v
    module lssd_multi_clk(clk, master_clk, slave_clk, d1, scan_d1, out, scan_out);
        input clk, master_clk, slave_clk, d1, scan_d1;
        output out, scan_out;
       FC3S2AQHV33
       lssd1(.D(d1),.CK(clk),.SDI(scan_d1),.SCK1(master_clk),.SCK2(slave_clk),
       .Q(out),.SDON(scan_out));
    endmodule
     // Constraints.sgdc
     current_design lssd_multi_clk
     clock -name lssd_multi_clk.slave_clk -period 10
     set_case_analysis -name lssd_multi_clk.master_clk -value 0
     set_case_analysis -name lssd_multi_clk.clk -value 0
                  In the above example, the Av_staticreg02 rule reports a violation for the
                  lssd1 instance as multiple clocks (CK, SCK1, SCK2, CK, and SCK1) of
                  this instance are tied to a constant value.
                  When you double-click on the violation of this rule, the following
                  spreadsheet appears:
                                                                                                   243
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Multiple clocks
                  In the above spreadsheet, click   1 in the ID column and open the Modular
                  Schematic window.
                  The following figure shows the schematic of this example:
244
                                            Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
                  To fix the above violation, remove the set_case_analysis constraint from the
                  SGDC file.
Rule Group
                  Implicit-Properties
                                                                                                245
                                             Synopsys, Inc.
Rules in SpyGlass Auto Verify
Av_syncfifo01
                  Checks overflow and underflow of synchronous FIFOs in a design
When to Use
                  Use this rule to check overflow and underflow of synchronous FIFOs in a
                  design.
Description
                  The Av_syncfifo01 rule performs overflow and underflow checks for
                  synchronous FIFOs. These checks are performed by using read/write
                  pointers of FIFO.
                  Note that if a FIFO is implemented with a library memory cell, overflow and
                  underflow checks are not performed and such checks are reported as
                  DISABLED.
246
                                            Synopsys, Inc.
                                                                         Rules in SpyGlass Auto Verify
                      If this assumption is violated, that is, the FIFO can be cleared after
                      reset, a false violation about overflow and underflow may get reported.
                      You can avoid this issue by specifying a FIFO reset signal in an SGDC
                      file, as shown in the following example:
                      reset -name fifo_flush -value 1
                      In the above example, the FIFO reset signal fifo_flush is specified
                      to be active high. Therefore, SpyGlass -Auto Verify solution controls the
                      FIFO flush function accordingly.
Parameter(s)
                   audit: Default value is no. Set this parameter to yes to not perform
                      functional analysis.
                   av_msgmode: Default value is fail. Set this parameter to all to report
                      all types of assertions (pass, fail, partially proved). Other possible
                      values are pass and pp.
                   distributed_fifo: Default value is no. Set this parameter to yes
                      to detect FIFOs with distributed memories.
             NOTE: This is a SpyGlass CDC parameter.
                   delayed_ptr_fifo: Default value is no. Set this parameter to yes
                      when the read/write pointers are delayed and the multiplexer inside the
                      memory is one-hot or implemented using gates.
             NOTE: This is a SpyGlass CDC parameter.
                   filter_named_resets: Default value is clk, clock, scan.
                      Specify a list of strings to auto-infer asynchronous resets that do not
                      match the specified strings.
             NOTE: This is a SpyGlass CDC parameter.
Constraint(s)
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                      conditions.
                   formal_analysis_filter (Optional): Use this constraint to specify the
                      modules or hierarchies on which formal analysis should be ignored or
                      performed.
                   clock (Optional): Use this constraint to specify clocks signals in a design.
                                                                                                  247
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
                   Argument                  Description
                   <memory-name>             FIFO memory name
                   <read-pointer-name>       FIFO read pointer name
                   <write-pointer-name>      FIFO write pointer name
                   <type>                    The problem type as overflows or underflows
                  Potential Issues
                  This violation appears if your design contains completely recognized FIFOs.
248
                                             Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
                    Argument                  Description
                    <memory-name>             FIFO memory name
                    <read-pointer-name>       FIFO read pointer name
                    <write-pointer-name>      FIFO write pointer name
                    <type>                    The problem type as overflows or underflows
                  Potential Issues
                  This violation appears if your design contains completely recognized FIFOs.
                                                                                                   249
                                              Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  Message 3
                  The following message appears when FIFOs are identified:
                  [FIFOINF] [INFO] FIFO with memory '<memory-name>', read pointer
                  '<read-pointer-name>' and write pointer '<write-pointer-name>'
                  detected. '<type>' check: PASSED
                  The arguments of the above message are explained below:
                   Argument                Description
                   <memory-name>           FIFO memory name
                   <read-pointer-name>     FIFO read pointer name
                   <write-pointer-name>    FIFO write pointer name
                   <type>                  The problem type as overflows or underflows
                  Potential Issues
                  Not applicable
                  Message 4
                  The following message is reported when FIFOs with library memory cells
                  are identified:
                  [FIFOLIBMEM] [INFO] FIFO with library memory '<memory-name>',
                  read pointer '<read-pointer-name>' and write pointer '<write-
                  pointer-name>' detected. '<type>' check:<status>
                  The arguments of the above message are explained below:
250
                                           Synopsys, Inc.
                                                                          Rules in SpyGlass Auto Verify
                    Argument                Description
                    <memory-name>           FIFO memory name
                    <read-pointer-name>     FIFO read pointer name
                    <write-pointer-name>    FIFO write pointer name
                    <type>                  The problem type as overflows or underflows
                    <status>                Assertion status - DISABLED
                  Potential Issues
                  This violation appears if your design contains library memory cell based
                  FIFOs.
                  Consequences of Not Fixing
                  None
                  How to Debug and Fix
                  If FIFO memory is a library cell, no functional check is performed. It is an
                  informational message.
                                                                                                   251
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  MEM memory is a part of the synchronous FIFO where the raddr read
                  pointer and the waddr write pointer are from the same clock domain.
                  Schematic Highlight
                  The Av_syncfifo01 rule highlights the following information in a schematic:
                   Read pointers
                   Write pointers
                   Memory
                  For the FIFOs implemented with library memories, only memory is
                  highlighted.
Rule Group
                  Implicit-Properties
252
                                            Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
                                                                                               253
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  signals at the boundary of the OVL module (for example, test expressions).
                  Other signals in the fan-in cone can be loaded gradually through the
                  Waveform Viewer user interface.
                  The following table describes the rules under this category:
                   Rule                     Reports
                   Av_ovl01                 OVL checks in the design.
254
                                           Synopsys, Inc.
                                                                      Rules in SpyGlass Auto Verify
Av_ovl01
                 Reports OVL checks in a design.
When to Use
                 Use this rule to validate design functionality that is specified by using OVL
                 assertions.
                 Prerequisites
                 Specify clock signals in a design by using the clock constraint.
Description
                 The Av_ovl01 rule validates OVL assertions and assumptions in a design.
                 OVL assertion represents the expected functionality of the design.
                 For the list of OVL assertions checked by this rule, see The OVL Support.
                 To understand how OVL assertions are asserted in a design, see Properties
                 Specification using OVL.
Parameter(s)
                 None
Constraint(s)
                  breakpoint (Optional): Use this constraint to specify breakpoints in a
                     design where functional analysis should stop.
                  watchpoint (Optional): Use this constraint to generate a waveform for an
                     internal signal.
                  special_module (Optional): Use this constraint to define property and
                     constraint modules.
                  clock (Mandatory): Use this constraint to specify clocks in a design.
                  reset (Optional): Use this constraint to specify resets in a design.
                  set_case_analysis (Optional): Use this constraint to specify case-analysis
                     conditions in a design.
                                                                                               255
                                               Synopsys, Inc.
Rules in SpyGlass Auto Verify
                  fails:
                  [WARNING] OVL check failed for '<OVL-property'
                  In addition, if a set of conflicting constraints are specified for the design,
                  additional message is appended to the above message string. For details
                  on the message and how to debug and fix this conflict, see the
                  Overconstrain Info File section.
                  Potential Issues
                  This violation appears if an OVL property defined for your design fails.
Rule Group
                  Standard-Properties
256
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Must Rules
Must Rules
             These rules are always run.
             The following table describes the rules under this category:
              Rule               Flags
              Av_license01       For license failure
              Av_init01          When all clocks in the design are not specified using the
                                 clock constraint and the use_inferred_clocks
                                 parameter is also not set.
              Av_initseq01       When alldefine_tag constraints with the
                                 -tag initSeq argument specified do not have the
                                 same length sequence specified with the -value
                                 argument
              Av_multitop01      When the design has multiple top-level design units
              Av_sanity01        Issues with the user-specified property files
              Av_sanity02        Non-tristated nets that have multiple drivers
                                                                                             257
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
Av_license01
                  Reports license failure
When to Use
                  This rule is run automatically.
Description
                  The Av_license01 rule reports a violation in the following cases:
                   If the Auto_Verify license key is unavailable when the Auto Verify
                     rules are run.
                     Message 1 is reported in this case.
                   If the SVA_GEN license key is unavailable when the av_dump_assertions
                     parameter is used.
                     Message 2 is reported in this case.
                   If the sva license key is unavailable when the set_option enableSVA yes
                     project file command is specified.
                     Message 3 is reported in this case.
Parameter(s)
                  None
Constraint(s)
                  None
258
                                            Synopsys, Inc.
                                                                  Rules in SpyGlass Auto Verify
Must Rules
             Potential Issues
             Not applicable
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             Specify the   Auto_Verify license.
             Message 2
             The following message appears when the     Auto_Verify license is
             unavailable:
             [ERROR] SVA generation feature not run due to unavailability of
             SVA_GEN license feature
             Potential Issues
             Not applicable
             Consequences of Not Fixing
             If you do not fix this violation, the feature on generating SVA is disabled.
             How to Debug and Fix
             Specify the   SVA_GEN license.
             Message 3
             The following message appears when the     sva license is unavailable:
             [ERROR] SVA constraints not read due to unavailability of sva
             license feature
             Potential Issues
             Not applicable
             Consequences of Not Fixing
             If you do not fix this violation, the SVA assume properties are not honored
             for functional verification.
                                                                                           259
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
260
                                               Synopsys, Inc.
                                                                       Rules in SpyGlass Auto Verify
Must Rules
Av_init01
                 Reports initial setup issues of a design.
When to Use
                 Use this rule to detect incorrect initial inputs to a design.
Description
                 The Av_init01 rule reports a violation in the following cases:
                  If no clock is specified for the design
                    For details on fixing this violation, see How to Debug and Fix.
                  If the OVL constraint specified in a property is invalid
                  If SpyGlass is unable to locate or open the VCD file specified by the
                    vcdfile parameter.
                    This VCD file contains the details of the initial state of a design for
                    functional analysis.
Parameter(s)
                  use_inferred_clocks of SpyGlass CDC solution: The default value
                    is no. Set this parameter to   yes to use the automatically-generated
                    clock information.
             NOTE: This is the parameter of SpyGlass CDC solution.
                  vcdfile: The default value is NULL. Specify a VCD file name that
                    SpyGlass can use to extract an initial state for functional analysis.
Constraint(s)
                 clock (Optional): Use this constraint to specify clock signals in a design.
                                                                                                261
                                            Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  Potential Issues
                  This violation appears if no clocks are detected in the design.
                  Message 2
                  The following message appears if the constraints defined in the property
                  file are missing in the design:
                  [FATAL] Some constraints specified in property file not found
                  in design. Refer '<file-name>' for more details
                  Potential Issues
                  This violation appears if your design is not constrained by the constraints
                  specified in the property file.
262
                                             Synopsys, Inc.
                                                                   Rules in SpyGlass Auto Verify
Must Rules
             Message 3
             The following message appears if SpyGlass is not able to open the VCD file
             specified by the vcdfile parameter:
             [FATAL] Unable to open vcd file for initial state
             Potential Issues
             This violation will appear when VCD file specified by the vcdfile parameter is
             not present in the specified location.
             Message 4
             The following message appears if you use the av_run_time parameter when
             the audit parameter is set to yes:
             [WARNING] Parameter "av_run_time" ignored in "audit" mode
             Potential Issues
             This violation appears if you use the av_run_time parameter when the audit
             parameter is set to yes.
                                                                                            263
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  When you specify the above file to SpyGlass and run any rule of the
                  SpyGlass Auto Verify solution, the Av_init01 rule reports Message 1.
Rule Group
                  Setup
264
                                               Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Must Rules
Av_initseq01
              Initialization sequences of multiple signals should be of the same
              length.
When to Use
              Use this rule to detect setup issues due to different initialization sequences
              specified by the define_tag constraint.
              Prerequisites
              Specify signals by using the define_tag constraint.
Description
              The Av_initseq01 rule reports a violation if the initialization sequences
              specified by the -value argument of the define_tag constraints (specified
              with the -tag initSeq argument) are not of the same length.
Parameter(s)
              None
Constraint(s)
              define_tag (Mandatory): Use this constraint to define a named condition for
              the application of certain stimulus at the top port or an internal node.
              Potential Issues
              This violation appears if your design contains signals that have initialization
              sequence of different lengths.
                                                                                             265
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  For the first define_tag constraint specification, the length of sequence is six
                  and it is four for the second specification. Therefore, the Av_initseq01 rule
                  reports a violation.
                  To fix this violation, modify the second specification as below:
                  define_tag -tag initSeq -name top.reset2 -value x x 1 1 1 1
Rule Group
                  Must rule
266
                                               Synopsys, Inc.
                                                                   Rules in SpyGlass Auto Verify
Must Rules
Av_multitop01
              Reports a violation in case of multiple top-level design units
When to Use
              Use this rule to check if your design contains multiple top-level design
              units.
Description
              The Av_multitop01 rule reports a violation if your design contains multiple
              top-level design units.
              For details on these design units, refer to the violation of the
              DetectTopDesignUnits Built-In rule.
Parameter(s)
              None
Constraint(s)
              None
                                                                                            267
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  To fix this violation, specify a single top-level design unit by using the
                  following command in the project file:
                  set_option top <du-name>
                  In the above example, both the modules        seq_block and flop are
                  considered as the top-level design units.
                  Specify one of these modules as a top-level design unit by using the
                  set_option top <du-name> project file command.
Rule Group
                  Sanity
268
                                               Synopsys, Inc.
                                                                   Rules in SpyGlass Auto Verify
Must Rules
Av_sanity01
              Reports an error if there is any issue in the property file.
When to Use
              Use this rule to detect setup issues due to incorrect property file.
              Prerequisites
              Specify a property file by using the propfile parameter.
Description
              The Av_sanity01 rule reports issues in the property files specified using the
              propfile parameter.
Parameter(s)
              propfile: Specify the name of the property file containing properties to be
              checked.
Constraint(s)
              clock (Optional): Use this constraint to specify clock signals in a design.
              Potential Issues
              This violation appears if your design does not contain assertions that are
              mentioned in the property file specified by the propfile parameter.
              This may happen if the design or the design view has changed due to
              changes in the commands of SpyGlass Auto Verify solution. As a result, the
              assertions specified in the property file become invalid in the context of the
              changed design.
                                                                                            269
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  Property file:
                  RuleName: Av_bus01
                  off Assertion    FAILED                        test.v 16 "fsm" [out]
                  off Assertion    FAILED                       test.v 16 "fsm" [out1]
RuleName: Av_bus02
270
                                            Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Must Rules
             In the above example, assertions are specified in the property file for the
             out1 and out2 nets for the Av_bus01 and Av_bus02 rules, respectively.
             However out1 and out2 do not exist in the design. Therefore, the
             Av_sanity01 rule reports a violation corresponding to each rule.
             To fix this violation, review the propfile_Assertion_<rule-name>.errorlog file
             corresponding to each rule and update the assertions to avoid any
             mismatch with the design.
Rule Group
             Sanity
                                                                                             271
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
Av_sanity02
                  Reports nets that have multiple drivers
When to Use
                  Use this rule during functional analysis to detect nets with multiple drivers.
Description
                  The Av_sanity02 rule reports non-tristate nets that have multiple drivers.
                  Such nets are considered as primary inputs for functional analysis.
Parameter(s)
                  None
Constraint(s)
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                     conditions.
                   clock (Optional): Use this constraint to specify clock signals in a design.
                   reset (Optional): Use this constraint to specify reset signals in a design.
                  Potential Issues
                  This violation appears if your design contains a non-tristate net with
                  multiple drivers.
272
                                            Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Must Rules
             For the above example, the Av_sanity02 rule reports a violation because of
             the presence of a non-tristate net with multiple drivers D1 and D2.
             Schematic Details
             The Av_sanity02 rule highlights the non-tristate net that has multiple
             drivers.
Rule Group
             Sanity
                                                                                             273
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
Av_sanity06
                  Reports issues found in the distributed computing flow
When to Use
                  Use this rule to detect issues in the distributed computing flow.
Description
                  The Av_sanity06 rule reports a violation in the following cases:
                   If parse errors are found in the parallel file specified by the fv_parallelfile
                     parameter.
                   If an error occurs while accessing any of the machines specified in the
                     parallel file.
                   If there are insufficient number of licenses for the SpyGlass Auto Verify
                     solution.
Parameter(s)
                  fv_parallelfile: By default, this parameter is not set to any value. Specify a
                  configuration file to this parameter. This file is used for distributed runs
                  over several machines.
Constraint(s)
                   set_case_analysis (Optional): Use this constraint to specify case analysis
                     conditions.
                   clock (Optional): Use this constraint to specify clock signals in a design.
                   reset (Optional): Use this constraint to specify reset signals in a design.
Message Details
                  Message 1
                  The following message appears if parse errors are found in the parallel file:
                  [SW01] [FATAL] Could not open parallel run file '<file-name>'
                  Potential Issues
                  This violation appears if there is any error in the parallel run file.
                  Consequences of Not Fixing
274
                                             Synopsys, Inc.
                                                                     Rules in SpyGlass Auto Verify
Must Rules
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, specify a correct parallel run file.
             Message 2
             The following message appears for an invalid login type:
             [SW02] [FATAL] <type> is not a supported login type
             Potential Issues
             This violation appears if you specify an invalid login type in the parallel file.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, specify a correct login type.
             Message 3
             The following message appears if the value of the MAX_PROCESSES
             keyword is equal to or less than 1 or if it is equal to or greater than 500:
             [SW03] [FATAL] Value of MAX_PROCESSES should be between 1 and
             500
             Potential Issues
             This violation appears if you specify an incorrect value for the
             MAX_PROCESSES keyword in the parallel file.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, specify a value between 1 and 500 for the
             MAX_PROCESSES keyword.
             Message 4
             The following message appears for the unsuccessful LSF run because of
                                                                                              275
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  Message 5
                  The following message appears if process count is not a positive integer
                  value in the parallel file:
                  [SW05] [FATAL] Process count in parallel file must be a
                  positive integer
                  Potential Issues
                  This violation appears if you specify an invalid integer value to the process
                  count in the parallel file. The process count accepts only a positive integer
                  value.
                  Consequences of Not Fixing
                  If you do not fix this violation, SpyGlass run does not proceed further.
                  How to Debug and Fix
                  To fix this violation, specify a positive integer value for the process count in
                  the parallel file.
                  Message 6
                  The following message appears if none of the specified machines in the
                  parallel file is accessible:
                  [SW06] [FATAL] None of the machines specified in parallel file
                  is accessible
                  Potential Issues
276
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
Must Rules
             Message 7
             The following message appears to report the machines that are not
             accessible:
             [SW07] [FATAL] Machines '<machines>' are not accessible
             Potential Issues
             This violation appears if none of the machines specified in a parallel file is
             accessible.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, specify the names of accessible machines in the
             parallel file.
             Message 8
             The following message appears if the        LOGIN_TYPE keyword is not
             specified in the parallel file:
             [SW08] [FATAL] 'LOGIN_TYPE' is not specified in parallel file
             Potential Issues
             This violation appears if you do not specify the   LOGIN_TYPE keyword in
             the parallel file.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
                                                                                             277
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
To fix this violation, specify the LOGIN_TYPE keyword in the parallel file.
                  Message 9
                  The following message appears if the         MAX_PROCESSES keyword is not
                  specified in the parallel file:
                  [SW09] [FATAL] 'MAX_PROCESSES' is not specified in parallel
                  file
                  Potential Issues
                  This violation appears if you do not specify the    MAX_PROCESSES keyword
                  in the parallel file.
                  Consequences of Not Fixing
                  If you do not fix this violation, SpyGlass run does not proceed further.
                  How to Debug and Fix
                  To fix this violation, specify the   MAX_PROCESSES keyword in the parallel
                  file.
                  Message 10
                  The following message appears if the MACHINES keyword is not specified
                  for the rsh/ssh login type in the parallel file:
                  [SW10] [FATAL] 'MACHINES' not specified for login type rsh/ssh
                  in parallel file
                  Potential Issues
                  This violation appears if you do not specify the    MACHINES keyword for the
                  rsh/ssh login type in the parallel file.
                  Consequences of Not Fixing
                  If you do not fix this violation, SpyGlass run does not proceed further.
                  How to Debug and Fix
                  To fix this violation, specify the   MACHINES keyword for the rsh/ssh login
                  type in the parallel file.
278
                                              Synopsys, Inc.
                                                                   Rules in SpyGlass Auto Verify
Must Rules
             Message 11
             The following message appears if an error occurs while running the        lsf
             bsub command:
             [SW11] [FATAL] Error executing lsf bsub command
             Potential Issues
             This violation appears if you specify invalid options, such as -I, -Ip, and
             -Is with the bsub command. These options are not allowed with the
             LSF_CMD keyword in the parallel file.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, specify valid the options with the   bsub command.
             Message 12
             The following message appears to indicate a missing solver executable:
             [SW12] [FATAL] Solver executable '<executable>' not found
             Potential Issues
             This violation appears if the solver executable file is not found in the
             SPYGLASS_HOME/lib/ path of SpyGlass release area. The name of this file is
             of the format solver.<platform>. For example, solver.SunOS5.
             Consequences of Not Fixing
             If you do not fix this violation, SpyGlass run does not proceed further.
             How to Debug and Fix
             To fix this violation, add the missing solver executable file in the
             SPYGLASS_HOME/lib/ path of SpyGlass release area.
             Message 13
             The following message appears to indicate missing licenses of SpyGlass
             Auto Verify solution for distributed computing flow:
             [SW13] [FATAL] No Advanced Lint licenses available for
                                                                                            279
                                        Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
                  Message 14
                  The following message appears to indicate inadequate SpyGlass Auto
                  Verify licenses available for distributed computing flow:
                  [SW14] [WARNING] Only '<num>' Advanced Lint licenses available
                  for Distributed Computing
                  Potential Issues
                  This violation appears if you specify insufficient number of licenses for
                  SpyGlass Auto Verify solution.
                  Consequences of Not Fixing
                  If n licenses for SpyGlass Auto Verify solution are available, only n-1
                  licenses are used for distributed computing as one of the license is used by
                  the main process.
                  Message 15
                  The following message appears if you specify an invalid option
                  <option-name> in the LSF_CMD keyword in a parallel file:
                  [SW15] [WARNING] Unsupported option '<option-name>' specified
                  in LSF_CMD field is ignored for Distributed Computing Flow
280
                                            Synopsys, Inc.
                                                                  Rules in SpyGlass Auto Verify
Must Rules
             Potential Issues
             This violation appears if you specify an invalid option   <option-name> in
             the LSF_CMD keyword in a parallel file.
             Consequences of Not Fixing
             If you do not fix this violation, distributed computing does not run.
             How to Debug and Fix
             To fix this violation, specify supported options with the   LSF_CMD keyword
             in a parallel file.
Rule Group
             Sanity
                                                                                           281
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
Must Rules
SGDC_av_meta_design_hier01
                  Checks the presence of constraint meta_design_hier
When to Use
                  Use this rule to check if the meta_design_hier constraint is specified
                  in a VHDL or mixed design that has the av_dump_assertions parameter set
                  to sva.
Description
                  The SGDC_av_meta_design_hier01 rule reports the absence of the
                  meta_design_hier constraint when the av_dump_assertions parameter
                  is set to sva in a VHDL or mixed design.
                  If the meta_design_hier constraint is not specified for a top module,
                  the rule uses the default name TB.DESIGN_INST for <testbench
                  name>.<top-module-name>.
Parameter(s)
                   av_dump_assertions: The default value is “”. Set this parameter to sva to
                     generate SystemVerilog Assertions (SVA) for partially-proved assertions
                     of rule Av_staticnet01 and Av_deadcode01.
Constraint(s)
                   meta_design_hier: Use this constraint to specify a top-level design and a
                     hierarchical design for VHDL and mixed designs.
Potential Issues
282
                                           Synopsys, Inc.
                                                                     Rules in SpyGlass Auto Verify
Must Rules
Rule Group
             Non-fatal must rule
                                                                                              283
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
SGDC_fsm_setup01
When to Use
                  Use this rule to perform sanity checks on the fsm constraint.
                  Prerequisites
                  Specify the fsm constraint.
Description
                  The SGDC_fsm_setup01 rule reports different types of issues in the fsm
                  constraint. For information on the types of issues reported, see Messages
                  and Suggested Fix.
Parameter(s)
                  None
Constraint(s)
                  fsm (Mandatory): Use this constraint to specify FSM details in a design.
284
                                             Synopsys, Inc.
                                                                     Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
              Message 2
              The following message appears:
              [WARNING] Fsm constraint with logical name '<fsm-name>' mapped
              to state variable '<state-variable>' of module '<module-name>'
              (All previous specifications of Fsm constraints with same
              logical name ignored)
              Potential Issues
              This violation appears if the same logical name (-name) is specified to
              multiple fsm constraints of different module names (-module) or state
              variables (-state_variables).
              See Example 2 - Same Logical Name for Multiple FSMs.
              Consequences of Not Fixing
              If you do not fix this violation, all the fsm constraints for which both the
              following conditions hold true are ignored from SpyGlass analysis:
               fsm constraints that have the same logical name as that of the reported
                   constraint.
               fsm constraints that are declared before the reported constraint
              How to Debug and Fix
              To fix this violation, use a unique combination of logical name (-name),
              module name (-module), and state variables (-state_variables) to
              uniquely identify an FSM.
              Message 3
              The following message appears:
              [WARNING] State value '<state-value>' specified in
              -state_values field of Fsm constraint with state variable
              '<state-variable>' (Module: <module-name>) ignored (Reason:
              Invalid state value)
                                                                                              285
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                  Potential Issues
                  This violation appears if an invalid state value is specified to the
                  -state_values argument of the fsm constraint.
                  See Example 3 - Invalid State Value of an FSM.
                  Consequences of Not Fixing
                  If you do not fix this violation, the reported constraint is ignored from
                  SpyGlass analysis.
                  How to Debug and Fix
                  Specify a valid state to the   -state_values argument of the reported
                  fsm constraint.
                  Message 4
                  The following message appears:
                  [WARNING] State value '<state-value>' specified in
                  -state_values field of Fsm constraint with state variable
                  '<state-variable>' (Module: <module-name>) is to be
                  <appended|removed> (All previous specification for same state
                  value ignored)
                  Potential Issues
                  This violation appears if a state value specified by the -state_values
                  argument of the fsm constraint is already specified to be removed (-
                  remove) or appended (-append) by a previous fsm constraint.
                  See Example 4 - FSMs with Duplicate State Values.
                  Consequences of Not Fixing
                  If you do not fix this violation then other than the reported fsm constraint,
                  all the fsm constraints declared before the reported constraint with the
                  same state value are ignored from SpyGlass analysis.
                  How to Debug and Fix
                  Remove the fsm constraint with duplicate state value.
                  Message 5
                  The following message appears:
286
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
              Message 6
              The following message appears:
              [WARNING] Transition specified with state value '<state-value>'
              in -to_state_value field of Fsm constraint with state variable
              '<state-variable>' (Module: <module-name>) ignored (Reason:
              Invalid state value)
              Potential Issues
              This violation appears if an invalid state value is specified to the   -
              to_state_value argument of the fsm constraint.
              See Example 6 - Invalid State Value To the -to_state_value Argument.
              Consequences of Not Fixing
              If you do not fix this violation, the reported constraint is ignored from
              SpyGlass analysis.
              How to Debug and Fix
              Specify a valid state to the   -to_state_value argument of the reported
              fsm constraint.
                                                                                             287
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                  Message 7
                  The following message appears:
                  [WARNING] Transition specified from state value '<state-
                  value1>' to state value '<state-value2>' for Fsm constraint
                  with state variable '<state-variable>' (Module: <module-name>)
                  is to be <removed|appended> (All previous specification for
                  same transition ignored)
                  Potential Issues
                  This violation appears if a state value specified by the -state_values
                  argument of the fsm constraint is already specified to be removed (-
                  remove) or appended (-append) by a previous fsm constraint.
                  See Example 7 - FSMs with Duplicate State Values.
                  Consequences of Not Fixing
                  If you do not fix this violation then other than the reported fsm constraint,
                  all the fsm constraints declared before the reported constraint with the
                  same state value are ignored from SpyGlass analysis.
                  How to Debug and Fix
                  Remove the fsm constraint with duplicate state value.
                  Message 8
                  The following message appears:
                  [WARNING] Fsm constraint with state variable '<state-variable>'
                  (Module: <module-name>) completely ignored (Reason: State
                  variable not found in the module)
                  Potential Issues
                  This violation appears if the state variable specified by the
                  -state_variables argument of the fsm constraint is missing in the
                  design.
                  See Example 8 - Missing State Variable.
                  Consequences of Not Fixing
                  The reported constraint is ignored from SpyGlass analysis.
                  How to Debug and Fix
288
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
              Message 9
              The following message appears:
              [WARNING] Fsm constraint with state variable '<state-variable>'
              (Module: <module-name>) partially ignored (Reason: State Value
              '<state-value>' specified to be appended is SpyGlass auto-
              detected or duplicate user-specification)
              Potential Issues
              This violation appears if the FSM state value to be added is automatically
              detected by SpyGlass or different width state values evaluating to the
              same logical value are specified by the user.
              See Example 9 - State Variable Automatically Detected By SpyGlass.
              Consequences of Not Fixing
              The reported constraint is partially ignored from SpyGlass analysis.
              -state_values can take multiple inputs, but this violation is reported
              only for individual input. Therefore, the constraint is partially ignored for a
              particular state value.
              How to Debug and Fix
              Remove the reported state variable from the FSM.
              Message 10
              The following message appears:
              [WARNING] Fsm constraint with state variable '<state-variable>'
              (Module: <module-name>) partially ignored (Reason: State Value
              '<state-value>' specified to be removed is not SpyGlass auto-
              detected or duplicate user-specification)
              Potential Issues
              This violation appears if the FSM state value to be removed is not
              automatically detected by SpyGlass or different width state values
              evaluating to the same logical value are specified by the user.
              See Example 10 - State Variable Not Detected Automatically By SpyGlass.
                                                                                             289
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                  Message 11
                  The following message appears:
                  [WARNING] Fsm constraint with state variable '<state-variable>'
                  (Module: <module-name>) partially ignored (Reason: Transition
                  from state value '<state-value1>' to state value '<state-
                  value2>' specified to be appended is SpyGlass auto-detected or
                  duplicate user-specification)
                  Potential Issues
                  This violation appears if the FSM transition to be added is automatically
                  detected by SpyGlass or different width state values of transition
                  evaluating to the same logical transition are specified by the user.
                  See Example 11 - FSM Transition Automatically Detected By SpyGlass.
                  Consequences of Not Fixing
                  The reported constraint is partially ignored from SpyGlass analysis.
                  There can be multiple transitions, but this violation is reported only for
                  individual transition. Therefore, the constraint is partially ignored for a
                  particular transition.
290
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
              Message 12
              The following message appears:
              [WARNING] Fsm constraint with state variable '<state-variable>'
              (Module: <module-name>) partially ignored (Reason: Transition
              from state value '<state-value1>' to state value '<state-
              value2>' specified to be removed is not SpyGlass auto-detected
              or duplicate user-specification)
              Potential Issues
              This violation appears if the FSM transition to be removed is not
              automatically detected by SpyGlass or different width state values of
              transition evaluating to the same logical transition are specified by the
              user.
              See Example 12 - FSM Transition Not Automatically Detected By spyGlass.
              Consequences of Not Fixing
              The reported constraint is partially ignored from SpyGlass analysis.
              There can be multiple transitions, but this violation is reported only for
              individual transition. Therefore, the constraint is partially ignored for a
              particular transition.
              How to Debug and Fix
              Remove the reported FSM transition from the fsm constraint.
              Message 13
              The following message appears:
              [WARNING] Fsm constraint with logical name '<fsm-name>' mapped
              to state variable '<state-variable>' of module '<module-name>'
              (All previous specifications of Fsm constraints with same state
              variable and module name ignored)
              Potential Issues
              This violation appears if duplicate fsm constraint specifications with the
              same state variable and module.
              See Example 13 - FSM Logical Name Mapped to a State Variable.
              Consequences of Not Fixing
              The last specification is considered and all the remaining duplicate
                                                                                             291
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                  Message 15
                  The following message appears:
                  [WARNING] Fsm constraint with state variable '<state-variable>'
                  (Module: <module-name>) completely ignored (Reason: All state
                  variables specified in constraint are not outputs of sequential
                  element)
                  Potential Issues
                  This violation appears if all the state variables specified to an fsm constraint
                  are not the output of any sequential element.
                  See Example 15 - FSM State Variable is Not the Output of a Sequential Element.
                  Consequences of Not Fixing
                  The reported constraints are ignored from SpyGlass analysis.
292
                                             Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
              Message 16
              The following message appears:
              [WARNING] Fsm constraint with state variable '<state-variable>'
              (Module: <module-name>) completely ignored (Reason: FSM
              specified to be removed is not auto-detected by SpyGlass)
              Potential Issues
              This violation appears if the fsm constraint is ignored from SpyGlass
              analysis because the specified FSM is not automatically detected by
              SpyGlass.
              Message 17
              The following message appears:
              [WARNING] Fsm constraint with state variable '<state-variable>'
              (Module: <module-name>) completely ignored (Reason: FSM
              specified to be added has no valid state or transition
              specification)
              Potential Issues
              This violation appears if all the state variables specified to an fsm constraint
              is ignored from SpyGlass analysis because the specified fsm constraint does
              not have a valid state/transition specification.
                                                                                             293
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
294
                                             Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
constraint specification.
                                                                                        295
                                          Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
296
                                           Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                                                                                        297
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
298
                                           Synopsys, Inc.
                                                                    Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
 input_RTL.v                                 SGDC
                                             ....
                                             ...
 `define S0 3'b001                           fsm -name myFsm_1 -module Fsm -state_variables
 `define S1 3'b010                           state1[2] state1[1] state1[0]
 `define S2 3'b100                           -state_values 010 1010
 `define S3 3'b000
 module Fsm(clk1, clk2,ctl, rst, state,      fsm -name myFsm_1 -module Fsm -state_variables
             state1, out);                    state1[2] state1[1] state1[0] -state_values111
   input clk1, clk2,ctl, rst;
   output [3:0] state, state1;               fsm -name myFsm_1 -module Fsm -state_variables
   output out;                                state1[2] state1[1] state1[0] -state_values001
   reg [3:0] state, state1;                   -remove
   reg a, b, out ;
   always@(posedge clk1)
       b <= 0;
   always@(posedge clk2)
       a <= 1;
   always@(posedge clk2 or negedge rst)
   if(!rst)
      begin
       state1 <= `S0;
       out <= 0;
      end
   else begin
     case({state1[2],state1[1],state1[0]})
     `S0 : state1 <= `S1;
     `S1 : out <= 1;
     `S2 : if (ctl)
             state1 <= `S1;
     `S3 : begin
            if (ctl)
                state1 <= `S2;
   else
       state1 <= `S0;
   end
      default      : ;     // Do nothing
    endcase
   end
   endmodule
               For the above example, the SGDC_fsm_setup01 rule reports the following
               message (Message 9):
               Fsm constraint with state variable 'state1[2] state1[1]
               state1[0]' (Module: Fsm) partially ignored (Reason: State Value
               '010' specified to be appended is auto-detected by SpyGlass)
                                                                                             299
                                         Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
300
                                           Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                                                                                        301
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
302
                                           Synopsys, Inc.
                                                               Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
                                                                                        303
                                       Synopsys, Inc.
Rules in SpyGlass Auto Verify
SGDC_fsm_setup01
304
                                Synopsys, Inc.
The OVL Support
This section describes the OVL assertions as checked by the Av_ovl01 rule.
It covers the following topics:
 Common Assertion Arguments
 OVL Assertions
                                                                       305
                          Synopsys, Inc.
The OVL Support
                   Parameters       Purpose
                   severity_level   Severity of the failure with default value of 0.
                   options          Vendor options. Currently, the only supported option is
                                    options=1, which defines the assertion as a constraint on
                                    formal tools. The default value is options=0, or no options
                                    specified.
                                    Note: In OVL 2.0, the options parameter has been renamed
                                    to property_type.
                   msg              Error message that will be printed if the assertion fires.
                   Ports            Purpose
                   clk              Triggering or clocking event that monitors the assertion.
                   reset_n          Signal indicating completed initialization (for example, a
                                    local copy of reset_n of a global reference to reset_n).
                   test_expr        Expression being verified at the positive edge of clk.
306
                                           Synopsys, Inc.
                                                                           The OVL Support
OVL Assertions
OVL Assertions
                 This section describes the following commands:
                  assert_always            assert_always_on_edge   assert_change
                  assert_cycle_sequence    assert_decrement        assert_delta
                  assert_even_parity       assert_fifo_index       assert_frame
                  assert_handshake         assert_implication      assert_increment
                  assert_never             assert_next             assert_no_overflow
                  assert_no_transition     assert_no_underflow     assert_odd_parity
                  assert_one_cold          assert_one_hot          assert_proposition
                  assert_quiescent_state   assert_range            assert_time
                  assert_transition        assert_unchange         assert_width
                  assert_win_change        assert_win_unchange     assert_window
                  assert_zero_one_hot
                                                                                        307
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_always
Declaration
                  assert_always
                    [#(severity_level, options, msg)]
                    inst_name(clk, reset_n, test_expr);
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that are not always
                  evaluated TRUE at every positive edge of the triggering event or clock clk.
308
                                           Synopsys, Inc.
                                                                             The OVL Support
OVL Assertions
assert_always_on_edge
Declaration
                 assert_always_on_edge
                   [#(severity_level, edge_type, options, msg)]
                   inst_name (clk, reset_n, sampling_event, test_expr);
                 Where:
                  edge_type:
                    0: no edge
                    1: positive edge
                    2: negative edge
                    3: any edge
                  sampling_event: Expression that defines when to evaluate test_expr.
                   Transition of sampling_event must match transition selected by
                   edge_type in order for test_expr to be evaluated.
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that are not always
                 evaluated TRUE at the edge of an event.
                                                                                        309
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_change
Declaration
                  assert_change
                     [#(severity_level, width, num_cks, flag, options, msg)]
                    inst_name(clk, reset_n, start_event, test_expr);
                  Where:
                   width: width of test expression test_expr
                   num_cks: is the number of cycles, from a start signal activation, within
                    which the test expression is supposed to change value
                   flag:
                     0: Ignore any subsequent start while monitoring the test signal
                       starting from a first start signal (default).
                     1: Each start signal occurrence will cause the monitoring to restart.
                     2: The property fails when a start occurs while monitoring a test
                       signal due to a previous activation of the start signal.
                   start_event: Event that triggers monitoring of the test_expr.
SpyGlass Handling
                  The Av_ovl01 rule reports those test expressions, test_expr, that do not
                  change value (0 to 1 or 1 to 0) within specified number of cycles, num_cks,
                  of a starting event.
                  Check the width within which the test expression has changed value for
                  correctness.
310
                                            Synopsys, Inc.
                                                                                  The OVL Support
OVL Assertions
assert_cycle_sequence
Declaration
                 assert_cycle_sequence
                    [#(severity_level, num_cks, necessary_condition, options,
                 msg)]
                   inst_name (clk, reset_n, event_sequence);
                 Where:
                  num_cks: The number of cycles the analysis is covering.
                   The maximum number supported clock cycles is 64.
                  necessary_condition: 2'b00, 2'b01, 2'b10, or 2'b11. The default is
                   2'b00.
                  event_sequence: A Verilog or VHDL concatenation expression, where
                   each bit represents an event.
SpyGlass Handling
                 The Av_ovl01 rule reports user-defined sequencing of events
                 event_sequence that are not followed correctly during functional checking.
                 The   assert_cycle_sequence assertion checks the following:
                  If necessary_condition is 2'b00 or 2'b10:
                   This assertion checks to ensure that if all num_cks-1 first events of
                   event_sequence are true, then the last one (event_sequence[0])
                   must occur. The check is done in pipe-lined mode.
                  If necessary_condition is 2'b01:
                   This assertion checks to ensure that once the first event
                   (event_sequence[num_cks-1]) occurs, all the remaining events
                   occur. The check is done in pipe-lined mode.
                  If necessary_condition is 2'b11:
                   This assertion checks to ensure that once the first event
                   (event_sequence[num_cks-1]) occurs, all the remaining events
                   occur. The check is done in non pipe-lined mode.
        NOTE: In pipe-lined mode, the first events are checked repeatedly for a match. If a new
              match is found, a check is started again.
                                                                                             311
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_decrement
Declaration
                  assert_decrement
                    [#(severity_level, width, value, options, msg)]
                    inst_name(clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
                   value: The value by which the test_expr is supposed to decrease.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr whose actual value is
                  decreased by any number other than the specified decrement value.
312
                                           Synopsys, Inc.
                                                                             The OVL Support
OVL Assertions
assert_delta
Declaration
                 assert_delta
                   [#(severity_level, width, min, max, options, msg)]
                   inst_name(clk, reset_n, test_expr);
                 Where:
                  width: width of test expression test_expr
                  min: Minimum change in value
                  max: Maximum change in value
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr whose actual value
                 changes by a number outside the specified range.
                                                                                        313
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_even_parity
Declaration
                  assert_even_parity
                    [#(severity_level, width, options, msg)]
                    inst_name (clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr where odd number of
                  bits are asserted at any time.
314
                                           Synopsys, Inc.
                                                                               The OVL Support
OVL Assertions
assert_fifo_index
Declaration
                 assert_fifo_index
                   [#(severity_level, depth, push_width, pop_width, options,
                 msg)]
                   inst_name(clk, reset_n, push, pop);
                 Where:
                  depth: Depth of the FIFO, which is the maximum number of pushes
                   allowed
                  push_width: The width of the push signal. Maybe greater than one if
                   multiple pushes are allowed in one cycle
                  pop_width: The width of the pop signal. Maybe greater than one if
                   multiple pops are allowed in one cycle
                  push: The value of push indicates the number of writes that are
                   occurring on that particular clock cycle. The push_width defines the
                   width of the push expression. By default, only a single write can be
                   performed on a particular clock cycle.
                  pop: The value of pop indicates the number of reads that are occurring
                   on that particular clock cycle. The pop_width defines the width of the
                   pop expression. By default, only a single read can be performed on a
                   particular clock cycle.
SpyGlass Handling
                 The Av_ovl01 rule reports FIFOs that either overflow or underflow.
                 The Av_ovl01 rule is not validating a FIFO but rather the environment of
                 FIFO for compliance with FIFO’s attributes. The Av_ovl01 rule is violated in
                 both cases when there is a write into a FIFO which is already full, or when
                 a read from an empty FIFO is requested.
                                                                                          315
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_frame
Declaration
                  assert_frame
                    [#(severity_level, min_cks, max_cks, flag, options, msg)]
                    inst_name(clk, reset_n, start_event, test_expr);
                  Where:
                   min_cks: the test signal must occur after min_cks cycles. If min_cks is 0
                    then the check ensures that test signal is occurring before max_cks,
                    however it may happen at the same time as start.
                   max_cks: the test signal must occur before max_clk cycles. If 0 then
                    test signal must occur at the same time as the start signal. max_cks
                    must be greater than or equal to min_cks.
                   flag: if 0 then ignore any subsequent start while monitoring the test
                    signal starting from a first start signal (default). If 1 then each start
                    signal occurrence will cause the monitoring to restart. If 2 then the
                    assertion fails when a start occurs while monitoring a test signals due to
                    a previous activation of the start signal.
                   start_event: Starting event that triggers monitoring of the test_expr.
                    The start_event is a cycle transition from 0 to 1.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that are not activated
                  within a minimum min_cks and maximum max_cks number of cycles when
                  the start signal is high (start_event).
316
                                           Synopsys, Inc.
                                                                                The OVL Support
OVL Assertions
assert_handshake
Declaration
                 assert_handshake
                   [#(severity_level, min_ack_cycle, max_ack_cycle,
                       req_drop, deassert_count, max_ack_length, options,
                 msg)]
                   inst_name(clk, reset_n, req, ack);
                 Where:
                  min_ack_cycle: ack is expected to occur at or after min_ack_cycle
                   cycles.
                  max_ack_cycle: ack is expected to occur at or before max_ack_cycle
                   cycles.
                  req_drop: Check if req is active until ack occurs
                  deassert_count: req is expected to be deactivated deassert_count
                   cycles after ack arrival.
                  max_ack_length: ack is expected to be max_ack_cycle cycles wide or
                   less. Also check if req is active for the entire deassert_count cycles after
                   ack.
                  req: Signal that starts the transaction.
                  ack: Signal that terminates the transaction.
SpyGlass Handling
                 The Av_ovl01 rule reports handshaking problems with the request and
                 acknowledge signals of a protocol.
                 The check ensures that acknowledge is occurring within a defined range of
                 cycles after a request has been sent; checks the acknowledge width
                 against its spec; if required by the user, ensures that the request is active
                 until arrival of acknowledge and remain active for specified number of
                 cycles after arrival of acknowledge; also ensures that the request is
                 inactivated within a specified number of cycles from acknowledge
                 activation. Both request and acknowledge signals must go inactive before a
                 handshake validation starts.
                                                                                           317
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_implication
Declaration
                  assert_implication
                    [#(severity_level, options, msg)]
                    inst_name(clk, reset_n, antecedent_expr, consequent_expr);
                  Where
                   antecedent_expr: Expression verified at the positive edge of clk.
                   consequent_expr: Expression verified if antecedent_expr is TRUE.
SpyGlass Handling
                  The Av_ovl01 rule reports “consequence” expressions consequent_expr that
                  are not evaluated TRUE after an “antecedent” expression antecedent_expr
                  has become TRUE.
                  Please note that the assert_implication assertion can be also
                  validated using the following statement:
                  assert_always
                    imply(clk, consequent_expr || !antecedent_expr);
318
                                           Synopsys, Inc.
                                                                             The OVL Support
OVL Assertions
assert_increment
Declaration
                 assert_increment
                   [#(severity_level, width, value, options, msg)]
                   inst_name(clk, reset_n, test_expr);
                 Where:
                  width: width of test expression test_expr
                  value: The value by which the test_expr is supposed to increase.
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr whose actual value is
                 increased by any number other than the specified increment value.
                                                                                        319
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_never
Declaration
                  assert_never
                    [#(severity_level, options, msg)]
                    inst_name (clk, reset_n, test_expr);
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that are evaluated to
                  be TRUE.
320
                                           Synopsys, Inc.
                                                                                 The OVL Support
OVL Assertions
assert_next
Declaration
                 assert_next
                   [#(severity_level, num_cks, check_overlapping, only_if,
                       options, msg)]
                   inst_name(clk, reset_n, start_event, test_expr);
                 Where:
                  num_cks, Number of clock cycles after start event at which test
                    expression must be evaluated ‘1’
                  check_overlapping, if ‘1’, allows another check to start upon a new start
                    pulse while the first check is continuing.
                  only_if, if ‘1’ causes a failure if the test expression is evaluated true
                    without a prior start event.
                  start_event: Starting event that triggers monitoring of the test_expr.
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr where no event
                 happens exactly after the specified number of cycles num_cks counted
                 from the start event start_event.
                                                                                               321
                                            Synopsys, Inc.
The OVL Support
OVL Assertions
assert_no_overflow
Declaration
                  assert_no_overflow
                    [#(severity_level, width, min, max, options, msg)]
                    inst_name (clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
                   min: Lower bound value below which the test expression cannot take
                    value while it transitions from max value.
                   max: Upper bound value above which the test expression cannot take
                    value while it transitions from max value.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that changes value
                  from a maximum value to another value outside the min-max range.
                  No message is reported if the value outside the min-max range is reached
                  from a value different from the max value.
322
                                           Synopsys, Inc.
                                                                                The OVL Support
OVL Assertions
assert_no_transition
Declaration
                 assert_no_transition
                   [#(severity_level, width, options, msg)]
                   inst_name (clk, reset_n, test_expr, start_state,
                 next_state);
                 Where:
                  width: width of test expression test_expr
                  start_state: Source state of unwanted transition
                  next_state: Destination transition of unwanted transition.
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that changes value
                 from a given state start_state to another state next_state.
                                                                                           323
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_no_underflow
Declaration
                  assert_no_underflow
                    [#(severity_level, width, min, max, options, msg)]
                    inst_name (clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
                   min: Lower bound value below which the test expression cannot take
                    value while it transitions from the min value.
                   max: Upper bound value above which the test expression cannot take
                    value while it transitions from the min value.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that changes value
                  from the min value to another value outside the min-max range.
                  No message is reported if the value outside the min-max range is reached
                  from a value different from the min value.
324
                                           Synopsys, Inc.
                                                                            The OVL Support
OVL Assertions
assert_odd_parity
Declaration
                 assert_odd_parity
                   [#(severity_level, width, options, msg)]
                   inst_name (clk, reset_n, test_expr);
                 Where:
                  width: width of test expression test_expr
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr where an even
                 number of bits are asserted at any time.
                                                                                       325
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_one_cold
Declaration
                  assert_one_cold
                    [#(severity_level, width, inactive, options, msg)]
                    inst_name(clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
                   inactive: If inactive is 0, then the test_expr must be one_cold or all 0. If
                    inactive is 1, then the test_expr must be one_cold or all 1.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that have been
                  asserted to be one_cold encoded but are not modeled to be one_cold
                  encoded.
                  The cause of this violation may be obvious if the signals are defined in a
                  case statement with clear encoding. But the one_cold-encoded signals may
                  be independent signals defined in different places in the RTL code. First,
                  determine why you assumed the signals should be one_cold encoded. If
                  the assumption is correct, then check why the signals are not one_cold
                  encoded.
326
                                            Synopsys, Inc.
                                                                             The OVL Support
OVL Assertions
assert_one_hot
Declaration
                 assert_one_hot
                   [#(severity_level, width, options, msg)]
                   inst_name(clk, reset_n, test_expr);
                 Where:
                  width: width of test expression test_expr
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that have been
                 asserted to be one_hot encoded but are not modeled to be one_hot
                 encoded.
                 The cause of this violation may be obvious if the signals are defined in a
                 case statement with clear encoding. But the one_hot-encoded signals may
                 be independent signals defined in different places in the RTL code. First,
                 determine why you assumed the signals should be one_hot encoded. If the
                 assumption is correct, then check why the signals are not one_hot
                 encoded.
                                                                                        327
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_proposition
Declaration
                  assert_proposition
                    [#(severity_level, options, msg)]
                    inst_name(reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that are not always
                  evaluated to be TRUE.
                  The assert_proposition assertion requires that the expression
                  should always be TRUE whereas the assert_always assertion requires that
                  the expression should be TRUE for all active edges of the clock.
328
                                           Synopsys, Inc.
                                                                                  The OVL Support
OVL Assertions
assert_quiescent_state
Declaration
                 assert_quiescent_state
                   [#(severity_level, width, options, msg)]
                   inst_name(clk,reset_n, state_expr, check_value,
                 sample_event);
                 Where:
                  width: width of state expression state_expr
                  state_expr: The state signals
                  check_value: The state_expr must be at this value at the edge of event
                  sample_event: The event at which the check is performed
        NOTE: SpyGlass Auto Verify solution does not support Verilog macros specific to the
              assert_quiescent_state OVL assertion.
SpyGlass Handling
                 The Av_ovl01 rule reports state expressions state_expr that are not in the
                 state check_value at the edge of event sample_event.
                                                                                              329
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_range
Declaration
                  assert_range
                    [#(severity_level, width, min, max, options, msg)]
                    inst_name(clk, reset_n, test_expr);
                  Where:
                   width: width of test expression test_expr
                   min: minimum value allowed for the test expression test_expr
                   max: maximum value allowed for the test expression test_expr. Default
                    is 2**width – 1.
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that do not always
                  have a value in the min-max range.
330
                                           Synopsys, Inc.
                                                                              The OVL Support
OVL Assertions
assert_time
Declaration
                 assert_time
                   [#(severity_level, num_cks, flag, options, msg)]
                   inst_name(clk, reset_n, start_event, test_expr);
                 Where:
                  num_cks: test expression must hold for that many cycles
                  flag:
                    0: Ignore any event once a first event has been started
                    1: Restart the check whenever a new event is asserted
                    2: Fail if a new event occurs after a first event has triggered the
                      monitoring process
                  start_event: Starting with this event the test expression must hold for
                   the given number of cycles
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that are not asserted
                 for num_cks cycles starting at the edge of event start_event.
                                                                                           331
                                           Synopsys, Inc.
The OVL Support
OVL Assertions
assert_transition
Declaration
                  assert_transition
                    [#(severity_level, width, options, msg)]
                    inst_name(clk, reset_n, test_expr, start_state,
                  next_state);
                  Where:
                   width: width of test expression test_expr
                   start_state: Source state of the transition
                   next_state: Destination state of the transition
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that have a transition
                  out of state start_state to a state other than state next_state.
332
                                           Synopsys, Inc.
                                                                               The OVL Support
OVL Assertions
assert_unchange
Declaration
                 assert_unchange
                   [#(severity_level, width, num_cks, flag, options, msg)]
                   inst_name(clk, reset_n, start_event, test_expr);
                 Where:
                  width: width of test expression test_expr
                  num_cks: number of clock cycles after start event during which the test
                   expression should remain unchanged
                  flag:
                    0: Ignore repetition of start_event
                    1: Re-start with a new start_event
                    2: Report violation if a new start_event is occurring while validating a
                      previous sequence
                  start_event: Event triggering observation of the test expression
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that change value
                 within num_cks cycles after event start_event.
                                                                                          333
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_width
Declaration
                  assert_width
                    [#(severity_level, min_cks, max_cks, options, msg)]
                    inst_name(clk, reset_n, test_expr);
                  Where:
                   min_cks: The test_expr should remain TRUE for at least the specified
                    minimum number of clock cycles. When min_cks is set to 0, then there
                    is no minimum check (that is, test_expr may occur at start event).
                   max_cks: The test_expr should not remain TRUE longer than the
                    specified maximum number of clock cycles. When max_cks is set to 0,
                    then there is no maximum check (any value is valid).
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that do not evaluate to
                  TRUE for a specified minimum number of clock cycles and evaluate to TRUE
                  for more than a maximum number of clock cycles.
334
                                            Synopsys, Inc.
                                                                              The OVL Support
OVL Assertions
assert_win_change
Declaration
                 assert_win_change
                   [#(severity_level, width, options, msg)]
                   inst_name(clk, reset_n, start_event, test_expr,
                 end_event);
                 Where:
                  width: width of test expression test_expr
                  start_event: starting event after which the test expression test_expr is
                   supposed to change value
                  end_event: End event before which the test expression test_expr is
                   supposed to change value
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that changes value
                 before the start event start_event or after the end event end_event.
                                                                                         335
                                          Synopsys, Inc.
The OVL Support
OVL Assertions
assert_win_unchange
Declaration
                  assert_win_unchange
                    [#(severity_level, width, options, msg)]
                    inst_name(clk, reset_n, start_event, test_expr,
                  end_event);
                  Where:
                   width: width of test expression test_expr
                   start_event: starting event after which the test expression test_expr is
                    not supposed to change value
                   end_event: End event before which the test expression test_expr is not
                    supposed to change value
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that changes value
                  after the start event start_event or before the end event end_event.
336
                                           Synopsys, Inc.
                                                                               The OVL Support
OVL Assertions
assert_window
Declaration
                 assert_window
                   [#(severity_level, options, msg)]
                   inst_name(clk, reset_n, start_event, test_expr,
                 end_event);
                 Where:
                  start_event: starting event after which (at the next clock tick) the test
                   expression test_expr is supposed to hold true
                  end_event: End event at the end of which the test expression test_expr
                   is allowed to be false
SpyGlass Handling
                 The Av_ovl01 rule reports test expressions test_expr that do not always
                 evaluate to TRUE from the start event start_event to the end event
                 end_event.
                                                                                           337
                                            Synopsys, Inc.
The OVL Support
OVL Assertions
assert_zero_one_hot
Declaration
                  assert_zero_one_hot
                    [#(severity_level, width, options, msg)]
                    inst_name(clk, reset_n, test_expr);
SpyGlass Handling
                  The Av_ovl01 rule reports test expressions test_expr that are neither
                  one_hot encoded nor all “0”s.
338
                                           Synopsys, Inc.
Appendix:
SGDC Constraints
                                                                          339
                          Synopsys, Inc.
Appendix: SGDC Constraints
340
                                           Synopsys, Inc.
List of Topics
                                                                                                                  341
                                                      Synopsys, Inc.
Auto Verify Central Report ............................................................................. 76
Auto Verify Report ........................................................................................ 73
Auto Verify-FSM Report ................................................................................. 80
Av_complexity01_fsm.csv Tab........................................................................ 92
Av_complexity01_InstanceBased.csv Tab ........................................................ 90
Av_complexity01_module.csv Tab .................................................................. 88
av_dcode_analysis........................................................................................ 25
av_dcode_report .......................................................................................... 25
av_dump_assertions ..................................................................................... 26
av_dump_instance_complexity ....................................................................... 27
av_dump_liveness ........................................................................................ 27
av_enable_crpt ............................................................................................ 28
av_flopcount ................................................................................................ 28
av_force_soft_reset ...................................................................................... 29
av_ignore_preformal_run_time ...................................................................... 30
av_msgmode ............................................................................................... 30
av_run_time ................................................................................................ 31
av_seqdepth ................................................................................................ 32
Av_staticreg02 Spreadsheet Report ................................................................ 85
av_violation_count ....................................................................................... 32
Bidirectional Ports......................................................................................... 21
Black Boxes ................................................................................................. 20
buscompress................................................................................................ 33
Changing the Percentage Range ..................................................................... 70
Changing the Percentage-Range Color ............................................................. 70
Clock Cycle Count and Sequential Depth .......................................................... 14
Common Assertion Arguments ..................................................................... 306
Configuring the Complexity Percentage............................................................ 69
Constant Value Control Signals in OVL Assertions/Assumptions ........................... 57
Contents of This Book .................................................................................... 8
Custom-Style Encoding ................................................................................. 80
dead_code_scope ......................................................................................... 36
Definitions and Concepts in SpyGlass Auto Verify .............................................. 13
Design Virtual Cycle ...................................................................................... 15
Details of the Uninitialized_Sequential_Elements Spreadsheet Report .................. 83
detect_assign_fsm........................................................................................ 37
detect_ifelse_fsm ......................................................................................... 38
detect_nested_fsm ....................................................................................... 38
Enabling and Disabling Assertions ................................................................... 65
Finite-State Machines (FSMs) ......................................................................... 22
Formal Setup Rules..................................................................................... 142
342
                                                 Synopsys, Inc.
Functional Analysis Report ............................................................................. 93
Functional Analysis ....................................................................................... 13
Functional Constraints................................................................................... 51
fv_dcode_all_inst ......................................................................................... 39
fv_debug_sim_cycles .................................................................................... 42
fv_parallelfile ............................................................................................... 40
Gated Clocks ............................................................................................... 22
ieffort ......................................................................................................... 33
Impact of Constraints on Functional Analysis.................................................... 51
Impact of Property and Constraint Modules ...................................................... 60
Implicit Properties Rules.............................................................................. 151
Implicit Properties ........................................................................................ 13
include_construct ......................................................................................... 43
Info Rules ................................................................................................. 106
Initial State ................................................................................................. 16
Latches ....................................................................................................... 21
Library Cells ................................................................................................ 20
License Used by SpyGlass Auto Verify ............................................................. 12
Memory Blocks............................................................................................. 21
Messages Reported in the Overconstrain Info File ............................................. 99
modulelist ................................................................................................... 46
Must Rules ................................................................................................ 257
Over Constraint............................................................................................ 52
Overconstrain Info File .................................................................................. 98
Overview of SpyGlass Auto Verify ................................................................... 18
OVL Assertions Format .................................................................................. 53
OVL Assertions in Combinational Circuits ......................................................... 58
OVL Assertions........................................................................................... 307
Parameters of SpyGlass Auto Verify ................................................................ 24
passfail ....................................................................................................... 35
Possible Values of the dead_code_scope Parameter .......................................... 36
Processing Property and Constraint Modules..................................................... 61
Properties Specification using OVL .................................................................. 53
Property and Constraint Management.............................................................. 63
Property and Property Analysis....................................................................... 13
Property File Example ................................................................................... 65
Property File Format ..................................................................................... 63
Property File Processing ................................................................................ 65
Property Status Reported during Functional Analysis ......................................... 99
propfile ....................................................................................................... 46
Register Info Report ................................................................................... 101
                                                                                                                   343
                                                      Synopsys, Inc.
Report Header.............................................................................................. 94
Reports and Diagnosis Files in SpyGlass Auto Verify .......................................... 72
reset_convention .......................................................................................... 43
resetoff ....................................................................................................... 44
Restrictions in Using OVL ............................................................................... 60
Sample Auto Verify Central Report .................................................................. 77
Sample Register Info Report ........................................................................ 102
Schematic Highlight and Cross Probing ............................................................ 67
scope.......................................................................................................... 47
Section A: Run Parameters ............................................................................ 95
Section B: Clock Information.......................................................................... 95
Section C: Reset Information ......................................................................... 95
Section D: Set-Case Analysis Settings ............................................................. 96
Section E: Initial State of the Design ............................................................... 96
Section F: Results Summary (Current) ............................................................ 96
Section G: Results Summary (Cumulative)....................................................... 97
Section H: Assertion Details ........................................................................... 97
Separate File OVL Support ............................................................................. 59
Setup and Design Audit ................................................................................. 76
SGDC_fsm_setup01 .................................................................................... 284
show_static_latches ...................................................................................... 44
solvemethod ................................................................................................ 45
Source RTL Design........................................................................................ 20
Specifying Functional Constraints.................................................................... 52
SpyGlass Design Constraints ........................................................................ 340
Standard OVL Properties................................................................................ 14
Standard Properties Rules............................................................................ 253
staticnet_scope ............................................................................................ 45
Stuck-Net .................................................................................................... 17
The Av_complexity01 Spreadsheet Report ....................................................... 88
The Complexity Browser ................................................................................ 69
Tristate Buses .............................................................................................. 21
Typographical Conventions ............................................................................. 9
Uninitialized_Sequential_Elements Spreadsheet Report...................................... 81
vcdfile......................................................................................................... 48
vcdfulltrace.................................................................................................. 48
vcdtime....................................................................................................... 48
verbose....................................................................................................... 49
Waveform Display and Cross Probing .............................................................. 68
xassign_casedefault ...................................................................................... 49
344
                                                   Synopsys, Inc.