# SpyGlass<sup>®</sup> Lint Turbo Structural User Guide

Version N-2017.12-SP2, June 2018



### **Copyright Notice and Proprietary Information**

© 2018 Synopsys, Inc. All rights reserved. This Synopsys software and all associated documentation are proprietary to Synopsys, Inc. and may only be used pursuant to the terms and conditions of a written license agreement with Synopsys, Inc. All other use, reproduction, modification, or distribution of the Synopsys software or the associated documentation is strictly prohibited.

### **Destination Control Statement**

All technical data contained in this publication is subject to the export control laws of the United States of America. Disclosure to nationals of other countries contrary to United States law is prohibited. It is the reader's responsibility to determine the applicable regulations and to comply with them.

### 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 https://www.synopsys.com/company/legal/trademarks-brands.html. 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

| SpyGlass Lint Turbo Structural                                       | 7 |
|----------------------------------------------------------------------|---|
| Using the Turbo Flow                                                 | 8 |
| Turbo Initiatives                                                    |   |
| Rule-wise Initiatives                                                |   |
| erc1                                                                 |   |
| latch                                                                |   |
| lint1                                                                | 6 |
| miscellaneous2                                                       | 7 |
| morelint2                                                            | 9 |
| openmore                                                             | 0 |
| simulation4                                                          | 3 |
| starc                                                                |   |
| starc20024                                                           |   |
| starc2005                                                            |   |
| timing5                                                              |   |
| Turbo Parameter Settings 53                                          | 3 |
| Smart Rule Execution                                                 | 6 |
| Waiving Primary Messages in the Turbo Mode                           | 6 |
| Defining the Preferred Waiver Behavior5                              | 7 |
| The moresimple_turbo Report                                          | 9 |
| Known Problems                                                       | 2 |
| SauClass Functional Lint                                             | - |
| SpyGlass Functional Lint6                                            |   |
| Prerequisites for Using Turbo Functional Rules                       |   |
| Turbo Capabilities                                                   | 7 |
| Functional Lint to Lint Rule Mapping6                                | 7 |
| Generating Waivers for Structural Rules                              | 8 |
| The SpyGlass Functional Lint Rules                                   |   |
| Av_width_mismatch_assign : LHS width is less than RHS width of       | _ |
| assignment (Truncation)                                              | 3 |
| Av_width_mismatch_case : A case expression width does not match case |   |
| select expression width7                                             |   |
| Av_width_mismatch_port : An instance port connection has different   |   |

| width compared to the port definition                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Av_signed_unsigned_mismatch : Mixed signed and unsigned types93                                                                                    |
| Av_width_mismatch_expr : Bit-width of operands of a logical operator do not match                                                                  |
| Av_width_mismatch_expr02 : Av_width_mismatch_expr03 :                                                                                              |
| Reports an arithmetic comparison operator with unequal length                                                                                      |
| Av_case_default_redundant : Ensure that a case statement marked<br>full_case or a priority/unique case statement does not have a<br>default clause |
| Av_case_default_missing : Ensure that a case statement or a selected signal assignment has a default clause                                        |
| Av_dontcare_mismatch : Use of don't-care except in case labels may lead                                                                            |
| to simulation/synthesis mismatch                                                                                                                   |
| SauClass List Abstraction Flow                                                                                                                     |

| SpyGlass Lint Abstraction Flow                           | 129 |
|----------------------------------------------------------|-----|
| Overview                                                 | 129 |
| Generating an Abstract View in SpyGlass Lint             |     |
| Validating Assumptions on Abstract View in SpyGlass Lint |     |
| Using the Abstract View in SpyGlass Lint                 |     |
| Using the Automatic SoC Flow in SpyGlass Lint            |     |

# SpyGlass Lint Turbo Structural

The SpyGlass Lint Turbo Structural solution enables you to consolidate and better manage the violations reported by the SpyGlass Lint rules.

#### Prerequisite:

Make sure you have the turbo struct license, to run this solution.

This user guide covers the following topics:

- Using the Turbo Flow
- Turbo Initiatives
- Rule-wise Initiatives
- Turbo Parameter Settings
- Smart Rule Execution
- The moresimple\_turbo Report
- Known Problems

# **Using the Turbo Flow**

To use the **turbo** mode, set the following parameter:

set\_option turbo yes

When the **turbo** option is set, the violations are classified into Primary and Secondary violations. If you click on a Primary violation, a spreadsheet is opened. This spreadsheet contains secondary violations for each primary violation. You can apply the desired waivers for the violations present in the spreadsheet. You can also use the old waivers. Waivers created in turbo mode are waived in non-turbo mode.

# **Turbo Initiatives**

The following table provide details about various initiatives/enhancements introduced in the rules that lead to consolidation and better management of the violations by classifying them into primary and secondary violations.

| Initiative                                 | Performs                                                                                                                                                                                                                                       |
|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TURBO_BUS_MERGE                            | Enables bus merging.                                                                                                                                                                                                                           |
| TURBO_CONSOLIDATE_DESIGN_SCOPE             | Consolidates and reports violations,<br>in a spreadsheet, based on block<br>(always/ process)/task/ function/<br>assignment/ signed-variable/expr/<br>package/macro/typdef/`define/per<br>case statement/port/signal/<br>variable declaration. |
| TURBO_CONSOLIDATE_IO_PAIR                  | Consolidates and reports violations,<br>in a spreadsheet, for connections<br>between the same set of input and<br>output ports of a module.                                                                                                    |
| TURBO_CONSOLIDATE_MODULE                   | Consolidates and reports violations,<br>in a spreadsheet, based on module<br>name.                                                                                                                                                             |
| TURBO_CONSOLIDATE_MODULE_CON<br>FIGURATION | Consolidates and reports violations,<br>in a spreadsheet, from different<br>configurations of a module.                                                                                                                                        |
| TURBO_CONSOLIDATE_PER_SOURCE               | Consolidates and reports violations,<br>in a spreadsheet, based on the<br>source (clock, reset, and signal<br>name, etc.).                                                                                                                     |
| TURBO_CONSOLIDATE_PORT                     | Consolidates and reports violations,<br>in a spreadsheet, based on the<br>module instance offending port.                                                                                                                                      |
| TURBO_DISABLE_ON_RTL                       | Disables a rule on RTL stage of design.                                                                                                                                                                                                        |

| Initiative                          | Performs                                                                                                                                                                                 |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TURBO_GROUP_MESSAGE                 | This is a global initiative that<br>modifies messages and indicates<br>the count of violating signals. All<br>violations are reported in a<br>spreadsheet.                               |
| TURBO_IGNORE_INTERNAL_OBJECTS       | Disables reporting violations if any cells/nets/instances (combo/<br>multiplexes/tristate) are generated internally.                                                                     |
| TURBO_IGNORE_PADDING                | Disables reporting violations for extensions of bits or constant integers (like 32'h45).                                                                                                 |
| TURBO_IGNORE_PARTIAL_BUS            | Disables reporting violations if any bit of vector/multi-bit is set/read/ used.                                                                                                          |
| TURBO_IGNORE_REDUNDANT_RULE         | Enables the smart rule execution.<br>See the <i>Smart Rule Execution</i><br>section for more details.                                                                                    |
| TURBO_IGNORE_STATIC_CONSTANTS       | Disables reporting violations on<br>expressions which contain a static/<br>constant operand, for example,<br>based numbers, parameters,<br>unsized based numbers, and<br>initialization. |
| TURBO_REMOVE_DUP_MSG                | Removes the duplicate messages.                                                                                                                                                          |
| TURBO_SET_RECOMMENDED_PARAM<br>ETER | Sets a parameter to the best fit value. See the <i>Turbo Parameter Settings</i> section for details.                                                                                     |

# **Rule-wise Initiatives**

The following tables present the list of rules in each product where message-consolidation initiatives are available:

- erc
- Iatch
- lint
- miscellaneous
- morelint
- openmore
- simulation
- starc
- starc2002
- starc2005
- timing

### erc

| Rule                          | Lang.                | Rule<br>Title                                                                                                                     | Parent<br>Message                                                                                                                                                                                                                               | Turbo<br>Initiatives                                                      |
|-------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| checkMultipleDrivers          | Verilog<br>+<br>VHDL | Only tristate<br>pins may be<br>WORed<br>(multiple<br>drivers only<br>allowed, if all<br>driving pins<br>are of type<br>tristate) | Not applicable                                                                                                                                                                                                                                  | TURBO_IGNORE_RE<br>DUNDANT_RULE                                           |
| checkPinConnectedT<br>oSupply | Verilog<br>+<br>VHDL | IO-ports or<br>Output ports<br>of cells/<br>modules may<br>not be<br>connected to<br>supply signals                               | Pin of <count> cell<br/><cell-name><br/>(instance <instance-<br>name&gt;) of module<br/><module-name><br/>connected to supply<br/>signals. Please refer<br/>to the spreadsheet<br/>for details</module-name></instance-<br></cell-name></count> | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE             |
| DisabledAnd                   | Verilog<br>+<br>VHDL | And/Nand<br>gate is<br>disabled                                                                                                   | Input pin of <count><br/>(comb-and/comb-<br/>nand) gates<br/>(instance <instance-<br>name&gt;) of module<br/><module-name></module-name></instance-<br></count>                                                                                 | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_GROUP_MES<br>SAGE |
|                               |                      |                                                                                                                                   | tiedlow.                                                                                                                                                                                                                                        | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only)   |

| Rule              | Lang.                | Rule<br>Title                                           | Parent<br>Message                                                                                                                                                                       | Turbo<br>Initiatives                                                    |
|-------------------|----------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| DisabledOr        | Verilog<br>+<br>VHDL | Or/Nor gate is disabled                                 | Input pin of <count><br/>(comb-or/comb-nor)<br/>gates (instance<br/><instance-name>)</instance-name></count>                                                                            | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   |                      |                                                         | of module <module-<br>name&gt; tiedlow.</module-<br>                                                                                                                                    | TURBO_GROUP_MES<br>SAGE                                                 |
|                   |                      |                                                         |                                                                                                                                                                                         | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| FlopClockConstant | Verilog<br>+<br>VHDL | Flip-flop clock<br>pin driven by<br>a constant<br>value | Clock pin of '10' flop<br>(instance ' <inst-<br>name'&gt; of module<br/>'<module-name>'</module-name></inst-<br>                                                                        | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   |                      | tie to constant                                         |                                                                                                                                                                                         | TURBO_GROUP_MES<br>SAGE                                                 |
|                   |                      |                                                         |                                                                                                                                                                                         | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| FlopDataConstant  | Verilog<br>+<br>VHDL | Flip-flop data<br>pin driven by<br>a constant<br>value  | Data pin of <count><br/>Flops (instance<br/><instance-name>)<br/>of module <module-< td=""><td>TURBO_CONSOLIDA<br/>TE_MODULE_CONFI<br/>GURATION</td></module-<></instance-name></count> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   | value                | name> tie to<br>constant.                               | TURBO_GROUP_MES<br>SAGE                                                                                                                                                                 |                                                                         |
|                   |                      |                                                         |                                                                                                                                                                                         | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |

| Rule              | Lang.                | Rule<br>Title                                                                              | Parent<br>Message                                                                                                                                                                         | Turbo<br>Initiatives                                                    |
|-------------------|----------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| FlopEConst        | Verilog<br>+<br>VHDL | Flip-flop<br>enable pin is<br>permanently<br>disabled or                                   | Enable pin of<br>' <count>' flop<br/>(instance '<inst-<br>name'&gt; of module</inst-<br></count>                                                                                          | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   |                      | enabled ' <module-name>'<br/>tie to constant</module-name>                                 |                                                                                                                                                                                           | TURBO_GROUP_MES<br>SAGE                                                 |
|                   |                      |                                                                                            |                                                                                                                                                                                           | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| FlopSRConst       | Verilog<br>+<br>VHDL | Flip-flop set<br>or reset pin is<br>permanently<br>enabled                                 | Set or reset pin of<br><count> Flops<br/>(instance <instance-<br>name&gt;) of module</instance-<br></count>                                                                               | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   |                      | <pre>enabled name&gt;) of module<br/><module-name> tie<br/>to constant</module-name></pre> | <module-name> tie</module-name>                                                                                                                                                           | TURBO_GROUP_MES<br>SAGE                                                 |
|                   |                      |                                                                                            |                                                                                                                                                                                           | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| LatchDataConstant | Verilog<br>+<br>VHDL | Latch data pin<br>driven by a<br>constant<br>value                                         | Data pin of <count><br/>Latches (instance<br/><instance-name>)<br/>of module <module-< td=""><td>TURBO_CONSOLIDA<br/>TE_MODULE_CONFI<br/>GURATION</td></module-<></instance-name></count> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                   | n                    | name> tie to<br>constant                                                                   | TURBO_GROUP_MES<br>SAGE                                                                                                                                                                   |                                                                         |
|                   |                      |                                                                                            |                                                                                                                                                                                           | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |

| Rule                | Lang.                | Rule<br>Title                                                                           | Parent<br>Message                                                                                        | Turbo<br>Initiatives                                                    |
|---------------------|----------------------|-----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| LatchEnableConstant | Verilog<br>+<br>VHDL | Latch enable<br>pin driven by<br>a constant<br>value                                    | Enable pin of<br><count> Latches<br/>(instance <instance-<br>name&gt;) of module</instance-<br></count>  | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                     |                      |                                                                                         | <module-name> tie<br/>to constant</module-name>                                                          | TURBO_GROUP_MES<br>SAGE                                                 |
|                     |                      |                                                                                         |                                                                                                          | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| MuxSelConst         | Verilog<br>+<br>VHDL | Mux select is constant.                                                                 | Select pin of<br><count> Mux<br/>(instance <instance-<br>name&gt;) of module</instance-<br></count>      | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                     |                      |                                                                                         | <module-name> tie<br/>to constant</module-name>                                                          | TURBO_GROUP_MES<br>SAGE                                                 |
|                     |                      |                                                                                         |                                                                                                          | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>(applicable to<br>spreadsheet only) |
| NoContAssign        | Verilog              | Continuous<br>assignment<br>statement<br>present in<br>technology-<br>mapped<br>netlist | Not applicable                                                                                           | TURBO_DISABLE_O<br>N_RTL                                                |
| TristateConst       | Verilog<br>+<br>VHDL | Tristate gate<br>enable is<br>constant                                                  | Enable pin of<br><count> Tristate<br/>(instance <instance-<br>name&gt;) of module</instance-<br></count> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION                          |
|                     |                      |                                                                                         | <module-name> tie to constant</module-name>                                                              | TURBO_GROUP_MES<br>SAGE                                                 |

## latch

| Rule            | Lang.                | Rule<br>Title                                                                | Parent<br>Message                                                                                                                                                                               | Turbo<br>Initiatives                                                      |
|-----------------|----------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| W336L           | Verilog              | Blocking<br>assignment to<br>latch output<br>should be<br>avoided            | Signal ' <signal-<br>name&gt;' is assigned<br/>using blocking<br/>assignment. For<br/>'<count>' similar<br/>case(s), please refer<br/>to the spreadsheet<br/>for details</count></signal-<br>   | TURBO_GROUP_MES<br>SAGE<br>TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION |
| LatchGatedClock | Verilog<br>+<br>VHDL | Do not use<br>gated/<br>internally<br>generated<br>clock to drive<br>latches | <count> latch(es)<br/>(output variable<br/>'<variable-name>')<br/>with gated or<br/>internally generated<br/>clock. Please refer to<br/>the spreadsheet for<br/>details</variable-name></count> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_BUS_MERGE         |

# lint

|      | 3       |                                             |                                                                                                                                                                           |                                                                |
|------|---------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Rule | Lang.   | Rule<br>Title                               | Parent<br>Message                                                                                                                                                         | Turbo<br>Initiatives                                           |
| W111 | Verilog | Not all<br>elements of an<br>array are read | Not all element of array<br>' <array-name>' are<br/>read. For <count><br/>similar occurrence(s),<br/>please refer to the<br/>spreadsheet for details</count></array-name> | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_REMOVE_DUP_<br>MSG |
| W111 | VHDL    | Not all<br>elements of an<br>array are read | Not all element of array<br>' <array-name>' are<br/>read. For <count><br/>similar occurrence(s),<br/>please refer to the<br/>spreadsheet for details</count></array-name> | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_REMOVE_DUP_<br>MSG |

| Rule | Lang.   | Rule<br>Title                                                                                     | Parent<br>Message                                                                                                                                                                | Turbo<br>Initiatives                                                           |
|------|---------|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| W116 | Verilog | Unequal<br>length<br>operands in<br>bitwise<br>logical/<br>arithmetic/<br>ternary<br>operator     | Not applicable                                                                                                                                                                   | TURBO_REMOVE_DUP_<br>MSG                                                       |
| W116 | VHDL    | Unequal<br>length<br>operands in<br>bit wise<br>logical/<br>arithmetic/<br>relational<br>operator | Not applicable                                                                                                                                                                   | TURBO_REMOVE_DUP_<br>MSG                                                       |
| W120 | Verilog | A signal/<br>variable has<br>been declared<br>but is not used                                     | Variable ' <variable-<br>name&gt;' declared but not<br/>used. For <count><br/>similar occurrence(s),<br/>please refer to the<br/>spreadsheet for details.</count></variable-<br> | TURBO_IGNORE_PARTIA<br>L_BUS<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
|      |         |                                                                                                   |                                                                                                                                                                                  | TURBO_REMOVE_DUP_<br>MSG                                                       |
| W120 | VHDL    | A signal/<br>variable has<br>been declared                                                        | Variable ' <variable-<br>name&gt;' declared but not<br/>used. For <count></count></variable-<br>                                                                                 | TURBO_IGNORE_PARTIA<br>L_BUS                                                   |
|      |         | but is not used                                                                                   | similar occurrence(s),<br>please refer to the<br>spreadsheet for details.                                                                                                        | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON                                 |
|      |         |                                                                                                   |                                                                                                                                                                                  | TURBO_REMOVE_DUP_<br>MSG                                                       |

| Rule  | Lang.   | Rule<br>Title                                                           | Parent<br>Message                                                                                                    | Turbo<br>Initiatives                           |
|-------|---------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| W121  | Verilog | A variable<br>names collides<br>with and may<br>shadow                  | Name ' <variable-<br>name&gt;' is not unique at<br/><count> places and<br/>may shadow another</count></variable-<br> | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
|       |         | another<br>variable                                                     | variable. Please refer to the spreadsheet for details                                                                | TURBO_GROUP_MESSA<br>GE                        |
| W123  | Verilog | A variable has<br>been read but<br>is not set                           | Not applicable                                                                                                       | TURBO_REMOVE_DUP_<br>MSG                       |
| W123  | VHDL    | A signal or<br>variable has<br>been read but<br>is not set              | Not applicable                                                                                                       | TURBO_REMOVE_DUP_<br>MSG                       |
| W154  | Verilog | Do not declare<br>nets implicitly                                       | <count> more implicit<br/>declaration(s) of the net<br/>detected in the design.<br/>Please refer to the</count>      | TURBO_GROUP_MESSA<br>GE                        |
|       |         |                                                                         | spreadsheet for details                                                                                              | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
| W159  | Verilog | Condition<br>contains a<br>constant                                     | Constant expression<br>' <expression>' in<br/>condition. For <count></count></expression>                            | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE             |
|       |         | expression                                                              | similar occurrence(s),<br>please refer to the<br>spreadsheet for details                                             | TURBO_GROUP_MESSA<br>GE                        |
| W164a | Verilog | LHS width is<br>less than RHS<br>width of<br>assignment<br>(Truncation) | <pre>'<count>' occurrences of width mismatch on assignment '<assignment-node>'</assignment-node></count></pre>       | TURBO_GROUP_MESSA<br>GE                        |
| W164a | VHDL    | LHS width is<br>less than RHS<br>width of<br>assignment<br>(Truncation) | Not applicable                                                                                                       | TURBO_REMOVE_DUP_<br>MSG                       |

| Rule  | Lang.   | Rule<br>Title                                                             | Parent<br>Message                                                                                                                                                                                                                                                   | Turbo<br>Initiatives                                                                                            |
|-------|---------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| W164b | Verilog | LHS width is<br>greater than<br>RHS width of<br>assignment<br>(Extension) | ' <count>' occurrences<br/>of width mismatch on<br/>assignment<br/>'<assignment-node>'</assignment-node></count>                                                                                                                                                    | TURBO_GROUP_MESSA<br>GE                                                                                         |
| W164b | VHDL    | LHS width is<br>greater than<br>RHS width of<br>assignment<br>(Extension) | Not applicable                                                                                                                                                                                                                                                      | TURBO_REMOVE_DUP_<br>MSG                                                                                        |
| W164c | Verilog | LHS width is<br>greater than<br>RHS width of<br>assignment<br>(Extension) | LHS width ' <widthi>' is<br/>greater than RHS width<br/>'<widthi>' [Hierarchy:<br/>'<hier-path>'], <count><br/>occurrences of width<br/>mismatch on same<br/>assignment. Please refer<br/>to the spreadsheet for<br/>details.</count></hier-path></widthi></widthi> | TURBO_GROUP_MESSA<br>GE                                                                                         |
| W171  | Verilog | Case label is not constant                                                | <count> non constant<br/>Case-labels in a case<br/>statement. Please refer<br/>to the spreadsheet for<br/>details.</count>                                                                                                                                          | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_GROUP_MESSA<br>GE                                                   |
| W175  | Verilog | A parameter/<br>generic has<br>been defined<br>but is not used            | Module ' <module-<br>name&gt;' has '<count>'<br/>unused Parameter.<br/>Please refer to the<br/>spreadsheet for details.</count></module-<br>                                                                                                                        | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE |

| Rule | Lang.   | Rule<br>Title                                    | Parent<br>Message                                                                                   | Turbo<br>Initiatives                           |
|------|---------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------|
| W175 | VHDL    | A parameter/<br>generic has<br>been defined      | Entity ' <entity-name>'<br/>has '<count>' unused<br/>generic. Please refer to</count></entity-name> | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE             |
|      |         | but is not used                                  | the spreadsheet for details.                                                                        | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
|      |         |                                                  |                                                                                                     | TURBO_GROUP_MESSA<br>GE                        |
| W190 | Verilog | Task or<br>procedure<br>declared but<br>not used | Not applicable                                                                                      | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE             |
| W190 | VHDL    | Task or<br>procedure<br>declared but<br>not used | Not applicable                                                                                      | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE             |
| W240 | Verilog | An input has<br>been declared<br>but is not read | Input ' <input-port-<br>name&gt;' declared but not<br/>read. For <count></count></input-port-<br>   | TURBO_IGNORE_PARTIA<br>L_BUS                   |
|      |         |                                                  | similar occurrence(s),<br>please refer to the<br>spreadsheet for details.                           | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
|      |         |                                                  |                                                                                                     | TURBO_REMOVE_DUP_<br>MSG                       |
| W240 | VHDL    | An input has<br>been declared<br>but is not read | Input ' <input-port-<br>name&gt;' declared but not<br/>read. For <count></count></input-port-<br>   | TURBO_IGNORE_PARTIA<br>L_BUS                   |
|      |         |                                                  | similar occurrence(s),<br>please refer to the<br>spreadsheet for details                            | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
|      |         |                                                  |                                                                                                     | TURBO_REMOVE_DUP_<br>MSG                       |

| Rule  | Lang.   | Rule<br>Title                                                                         | Parent<br>Message                                                                                                                                                                                                                                                           | Turbo<br>Initiatives                                                                         |
|-------|---------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| W263  | Verilog | A case<br>expression<br>width does not<br>match case<br>select<br>expression<br>width | <pre>'<count>' case label width does not match case selector width of module '<module- name="">' at line '<line- number="">'</line-></module-></count></pre>                                                                                                                | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_REMOVE_DUP_<br>MSG                               |
| W280  | Verilog | A delay has<br>been specified<br>in a non-<br>blocking<br>assignment                  | <block-type> has<br/><count> non-blocking<br/>assignment(s) where<br/>intra-assignment delay<br/>is used. Please refer to<br/>the spreadsheet for<br/>details</count></block-type>                                                                                          | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE                                                           |
| W287b | Verilog | Output port of<br>an instance is<br>not connected                                     | Instance output port<br>' <output-port-name>' is<br/>not connected. For<br/>similar '<count>'<br/>violations of module<br/>'<module-name>',<br/>please refer to the<br/>spreadsheet for details</module-name></count></output-port-name>                                    | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON                                               |
| W287b | VHDL    | Output port of<br>an instance is<br>not connected                                     | Instance output<br>' <instance-name>' not<br/>used. [Elaborated<br/>Module Name:<br/><module-name>], for<br/>the similar '<count>'<br/>violation(s) of the<br/>elaborated module,<br/>please refer to the<br/>spreadsheet for details</count></module-name></instance-name> | TURBO_CONSOLIDATE_<br>PORT<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON TURBO_BUS_MERGE |
| W362  | Verilog | Unequal<br>length in<br>arithmetic<br>comparison<br>operator                          | Not applicable                                                                                                                                                                                                                                                              | TURBO_REMOVE_DUP_<br>MSG                                                                     |

| Rule  | Lang.                | Rule<br>Title                                                                                | Parent<br>Message                                                                                                                                                                                                            | Turbo<br>Initiatives                                                                                                                                            |
|-------|----------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| W401  | Verilog<br>+<br>VHDL | Clock signal is<br>not an input to<br>the design<br>unit                                     | Clock ' <clock-name>' is<br/>not an input to design<br/>unit '<design-unit-<br>name&gt;'. For similar<br/>'<count>' violation(s),<br/>please refer to the<br/>spreadsheet for details</count></design-unit-<br></clock-name> | TURBO_CONSOLIDATE_<br>PER_SOURCE<br>TURBO_GROUP_MESSA<br>GE                                                                                                     |
| W402b | Verilog              | Asynchronous<br>set/reset<br>signal is not<br>an input to the<br>module                      | 'signal-name' to flop<br>' <flip-flop-name>' is<br/>gated or internally<br/>generated. For similar<br/>'<count>' violation(s),<br/>please refer to the<br/>spreadsheet for details</count></flip-flop-name>                  | TURBO_CONSOLIDATE_<br>PER_SOURCE<br>TURBO_GROUP_MESSA<br>GE                                                                                                     |
| W415a | Verilog              | Signal may be<br>multiply<br>assigned<br>(beside<br>initialization)<br>in the same<br>scope. | Signal <signal-name> is<br/>being assigned <count><br/>times inside module<br/>'<module-name>'.<br/>Please refer to the<br/>spreadsheet for details</module-name></count></signal-name>                                      | TURBO_SET_RECOMMEN<br>DED_PARAMETER<br>TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_CONSOLIDATE_<br>PER_SOURCE<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON |
| W443  | Verilog              | 'X' value used                                                                               | <pre>'<count>' occurrence of<br/>'X' state used in '<block-<br>name&gt;' block of module<br/>'<module-name>' at<br/>line '<line-number>'</line-number></module-name></block-<br></count></pre>                               | TURBO_IGNORE_STATIC<br>_CONSTANTS<br>TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_GROUP_MESSA<br>GE                                                              |
| W443  | VHDL                 | 'X' value used                                                                               | <pre>'<count>' occurrence of<br/>'X' state used in '<block-<br>name&gt;' block of module<br/>'<module-name>' at<br/>line '<line-number>'</line-number></module-name></block-<br></count></pre>                               | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE                                                                                       |

| Rule  | Lang.   | Rule<br>Title                                                                                                                                    | Parent<br>Message                                                                                                                                                       | Turbo<br>Initiatives                                                                                             |
|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| W456a | Verilog | A signal is<br>included in the<br>sensitivity list<br>of a<br>combinational<br>always block<br>but none of its<br>bits is read in<br>that block  | ' <count>' signals/<br/>variables are not<br/>required in sensitivity<br/>list of module '<module-<br>name'&gt; at line &lt;'line-<br/>number'&gt;</module-<br></count> | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_REMOVE_DUP_<br>MSG                                                   |
| W456a | VHDL    | A signal is<br>included in the<br>sensitivity list<br>of a<br>combinational<br>process block<br>but none of its<br>bits is read in<br>that block | Not applicable                                                                                                                                                          | TURBO_REMOVE_DUP_<br>MSG                                                                                         |
| W464  | Verilog | Unrecognized<br>synthesis<br>directive used<br>in the design                                                                                     | <count> more<br/>unrecognized synthesis<br/>directive(s) used in the<br/>design. Please refer to<br/>the spreadsheet for<br/>details</count>                            | TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE                                        |
| W464  | VHDL    | Unrecognized<br>synthesis<br>directive used<br>in the design                                                                                     | <count> more<br/>unrecognized synthesis<br/>directive(s) used in the<br/>design. Please refer to<br/>the spreadsheet for<br/>details</count>                            | TURBO_SET_RECOMMEN<br>DED_PARAMETER<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE |
| W481a | Verilog | Possibly<br>unsynthesizab<br>le loop: step<br>variable<br>differs from<br>variable used<br>in condition                                          | Not applicable                                                                                                                                                          | TURBO_REMOVE_DUP_<br>MSG                                                                                         |

| Rule | Lang.   | Rule<br>Title                                                                       | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                 | Turbo<br>Initiatives                                                                                            |
|------|---------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| W484 | Verilog | Possible loss<br>of carry or<br>borrow due to<br>addition/<br>subtraction           | Possible assignment<br>overflow: Ihs width<br><widthl> (Expr:<br/>'<lexpr>') should be<br/>greater than rhs width<br/><widthr> (Expr:<br/>'<rexpr>') to<br/>accommodate carry/<br/>borrow bit, [Hierarchy:<br/>'<hierpath>'], <count><br/>occurrences of<br/>assignment overflow on<br/>same assignment.<br/>Please refer to the<br/>spreadsheet for details</count></hierpath></rexpr></widthr></lexpr></widthl> | TURBO_GROUP_MESSA<br>GE                                                                                         |
| W528 | Verilog | A signal or<br>variable is set<br>but never read                                    | Not applicable                                                                                                                                                                                                                                                                                                                                                                                                    | TURBO_IGNORE_PARTIA<br>L_BUS<br>TURBO_REMOVE_DUP_<br>MSG                                                        |
| W528 | VHDL    | A signal or<br>variable is set<br>but never read                                    | Not applicable                                                                                                                                                                                                                                                                                                                                                                                                    | TURBO_IGNORE_PARTIA<br>L_BUS<br>TURBO_REMOVE_DUP_<br>MSG                                                        |
| W553 | Verilog | Different bits<br>of a bus are<br>driven in<br>different<br>combinational<br>blocks | net/bus ' <signal-<br>name&gt;' is driven<br/>'<count>' times inside<br/>more than one<br/>combinational block.<br/>Please refer to the<br/>spreadsheet for details</count></signal-<br>                                                                                                                                                                                                                          | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE |

| Rule  | Lang.   | Rule<br>Title                                                                                                  | Parent<br>Message                                                                                                                                                                                                                                                                                                          | Turbo<br>Initiatives                                                                                            |
|-------|---------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| W563  | Verilog | Reduction of a<br>single-bit<br>expression is<br>redundant                                                     | Unary reduction<br>operator used <count><br/>times on single bit<br/>usage of variable<br/>'<variable-name>'.<br/>Please refer to the<br/>spreadsheet for details</variable-name></count>                                                                                                                                  | TURBO_GROUP_MESSA<br>GE<br>TURBO_REMOVE_DUP_<br>MSG                                                             |
| W71   | Verilog | A case<br>statement (or<br>selected signal<br>assignment)<br>does not have<br>a default or<br>OTHERS<br>clause | Not applicable                                                                                                                                                                                                                                                                                                             | TURBO_REMOVE_DUP_<br>MSG                                                                                        |
| W287a | Verilog | Some inputs<br>to instance<br>are not driven<br>or<br>unconnected                                              | Input ' <input-name>' of<br/>instance '<instance-<br>name&gt;' is unconnected<br/>or Undriven.[Hierarchy:<br/>'<hier-path>']. For<br/>similar <count><br/>violation(s) of module<br/><module-name>,<br/>please refer to the<br/>spreadsheet for details</module-name></count></hier-path></instance-<br></input-name>      | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_GROUP_MESSA<br>GE |
| W287a | VHDL    | Some inputs<br>to instance<br>are not driven<br>or<br>unconnected                                              | Input Signal ' <input-<br>name&gt;' of instance<br/>'<instance-name>' not<br/>driven. [Elaborated<br/>Module Name: <hier-<br>name&gt;], for the similar<br/>'<count>' violation(s) of<br/>the corresponding<br/>master, please refer to<br/>the spreadsheet for<br/>details</count></hier-<br></instance-name></input-<br> | TURBO_CONSOLIDATE_<br>PORT<br>TURBO_CONSOLIDATE_<br>MODULE_CONFIGURATI<br>ON<br>TURBO_BUS_MERGE                 |

| Rule  | Lang.   | Rule<br>Title                                                                    | Parent<br>Message                                                                                                                                                           | Turbo<br>Initiatives                                          |
|-------|---------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| W191  | Verilog | Function<br>declared but<br>not used                                             | NA                                                                                                                                                                          | TURBO_REMOVE_DUP_<br>MSG                                      |
| W191  | VHDL    | Function<br>declared but<br>not used                                             | NA                                                                                                                                                                          | TURBO_REMOVE_DUP_<br>MSG                                      |
| W490  | Verilog | A control<br>expression/<br>sub-<br>expression is a<br>constant                  | NA                                                                                                                                                                          | TURBO_IGNORE_STATIC<br>_CONSTANTS                             |
| W552  | Verilog | Different bits<br>of a bus are<br>driven in<br>different<br>sequential<br>blocks | Bus ' <signal-name>' is<br/>driven '<count>' times<br/>inside more than one<br/>sequential block. Please<br/>refer to the spreadsheet<br/>for details</count></signal-name> | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_GROUP_MESSA<br>GE |
| W494a | VHDL    | Input port is<br>not used                                                        | <count> input port(s) of<br/>same entity not used.<br/>Please refer to the<br/>spreadsheet for details</count>                                                              | TURBO_CONSOLIDATE_<br>DESIGN_SCOPE<br>TURBO_GROUP_MESSA<br>GE |

## miscellaneous

| Rule     | Lang.            | Rule<br>Title                                                                     | Parent<br>Message                                                                                                                                                                                                       | Turbo<br>Initiatives                                                      |
|----------|------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| ConstSig | Verilog+<br>VHDL | Signal has a<br>constant<br>value or can<br>only switch<br>to a constant<br>value | Signal ' <signal-name>'<br/>has a constant value or<br/>can only switch to a<br/>constant value. For<br/>'<count>' similar<br/>occurrence(s), please<br/>refer to the<br/>spreadsheet for details</count></signal-name> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_GROUP_MES<br>SAGE |

| Rule     | Lang.            | Rule<br>Title                                                       | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Turbo<br>Initiatives                                                                              |
|----------|------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| DeadCode | Verilog+<br>VHDL | Code does<br>not<br>contribute to<br>functionality<br>of the design | <ol> <li>The net '<net-<br>name&gt;' does not<br/>drive anything, for<br/>the similar <count><br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></net-<br></li> <li>The net '<net-<br>name&gt;' is not driven<br/>by anything, for the<br/>similar <count><br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></net-<br></li> <li>Change on net<br/>'<net-name>' has<br/>no effect on any of<br/>the outputs, for the<br/>similar <count><br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></net-name></li> <li>Change on net<br/>'<net-name>' has<br/>no effect on any of<br/>the outputs, for the<br/>similar <count><br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></net-name></li> <li>None of the inputs<br/>have any effect on<br/>net '<net-name>',<br/>for the similar<br/><count><br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></net-name></li> </ol> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_GROUP_MES<br>SAGE<br>TURBO_BUS_MERGE      |
| Mux01    | Verilog+<br>VHDL | Connected<br>muxes<br>should not<br>have a<br>common<br>select.     | Some inputs of mux<br>' <mux1-name>' do not<br/>propagate to connected<br/>mux '<mux2-name>',<br/>due to common select.<br/>For '<count>' similar<br/>occurrence(s), please<br/>refer to the<br/>spreadsheet for details</count></mux2-name></mux1-name>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TURBO_CONSOLIDA<br>TE_PER_SOURCE<br>TURBO_IGNORE_IN<br>TERNAL_OBJECTS<br>TURBO_REMOVE_DU<br>P_MSG |

## morelint

| Rule              | Lang.   | Rule<br>Title                                                                         | Parent<br>Message                                                                                                                                                                                | Turbo<br>Initiatives                                                      |
|-------------------|---------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| AsgnToOneBit-ML   | Verilog | Assigning a 0<br>or 1(32-bits)<br>to a 1 bit is<br>not allowed                        | 1-bit is assigned a 0<br>or 1 (32 bits) in<br>module ' <module-<br>name&gt;' at '<count>'<br/>place(s). Please refer<br/>to the spreadsheet<br/>for details</count></module-<br>                 | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                                        |
| BitOrder-ML       | Verilog | Bit order<br>specification<br>should follow<br>recommended<br>convention              | Bit order<br>specification(s) at<br><count> more<br/>places do not follow<br/>the recommended</count>                                                                                            | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE             |
|                   |         |                                                                                       | convention. Please<br>refer to the<br>spreadsheet for<br>details                                                                                                                                 | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                            |
| ChkUndefMacro-ML  | Verilog | Macro is not<br>defined<br>before<br>undefining it                                    | <count><br/>occurrence(s) of<br/>improper usage of<br/>'undef' for macro<br/>detected in the file<br/>'<file-name>'.<br/>Please refer to the<br/>spreadsheet for<br/>details</file-name></count> | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                                        |
| ConstDrivenNet-ML | Verilog | All internal<br>nets of<br>module<br>should not be<br>assigned a<br>constant<br>value | Please refer to the<br>'ConstDrivenNet-<br>ML_Ve_001.csv' for<br>rest <count><br/>violations of Verilog<br/>cases</count>                                                                        | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION<br>TURBO_GROUP_MESS<br>AGE |

| VHDL                 | All internal                                                     |                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | nets of<br>module<br>should not be                               | Please refer to the<br>'ConstDrivenNet-<br>ML_Vh_001.csv' for<br>rest <count></count>                                                                                                             | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      | assigned a<br>constant<br>value                                  | violations of Verilog<br>cases                                                                                                                                                                    | TURBO_GROUP_MESS<br>AGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Verilog              | Design should<br>not use casez<br>constructs                     | Not applicable                                                                                                                                                                                    | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Verilog<br>+<br>VHDL | Net connected<br>to output port<br>of instance is<br>unconnected | Net ' <net-name>'<br/>connected to output<br/>port of instance is<br/>unconnected. For</net-name>                                                                                                 | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                      |                                                                  | similar <count><br/>occurrence(s) for<br/>same module</count>                                                                                                                                     | TURBO_GROUP_MESS<br>AGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                      |                                                                  | <pre>'<module-name>', please refer to the spreadsheet for details</module-name></pre>                                                                                                             | TURBO_CONSOLIDATE<br>_MODULE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Verilog              | Arithmetic<br>Operators<br>should be<br>avoided.                 | Expression ' <expr-<br>name&gt;' containing<br/>'<operator>'<br/>operator. For similar<br/><count></count></operator></expr-<br>                                                                  | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                      |                                                                  | occurrence(s) for the<br>same ' <scope-<br>name&gt;' scope,<br/>please refer to the<br/>spreadsheet for</scope-<br>                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                      | Verilog<br>+<br>VHDL                                             | assigned a<br>constant<br>valueVerilogDesign should<br>not use casez<br>constructsVerilogNet connected<br>to output port<br>of instance is<br>unconnectedVHDLArithmetic<br>Operators<br>should be | assigned a<br>constant<br>valueviolations of Verilog<br>casesVerilogDesign should<br>not use casez<br>constructsNot applicableVerilogNet connected<br>to output port<br>of instance is<br>unconnectedNet ' <net-name>'<br/>connected to output<br/>port of instance is<br/>unconnected. For<br/>similar <count><br/>occurrence(s) for<br/>same module<br/>'<module-name>',<br/>please refer to the<br/>spreadsheet for<br/>detailsVerilogArithmetic<br/>Operators<br/>should be<br/>avoided.Expression '<expr-<br></expr-<br>name&gt;' containing<br/>'<operator>'<br/>operator. For similar<br/><count><br/>occurrence(s) for the<br/>same '<br/>spreadsheet for<br/>details</count></operator></module-name></count></net-name> |

| Rule              | Lang.                | Rule<br>Title                                                               | Parent<br>Message                                                                                                                                                                                                                                                    | Turbo<br>Initiatives                                                                 |
|-------------------|----------------------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| NoArithOp-ML      | VHDL                 | Arithmetic<br>Operators<br>should be<br>avoided.                            | Expression ' <expr-<br>name&gt;' containing<br/>'<operator>'<br/>operator. For similar<br/><count><br/>occurrence(s) for the<br/>same '<scope-<br>name&gt;' scope,<br/>please refer to the<br/>spreadsheet for<br/>details</scope-<br></count></operator></expr-<br> | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
| NoAssignX-ML      | Verilog              | RHS of the<br>assignment<br>contains 'X                                     | 'RHS of the<br>assignment contains<br>'X' <reason> at<br/>'<count>' place(s) in<br/>always block. Please<br/>refer to the<br/>spreadsheet for<br/>details</count></reason>                                                                                           | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                                                   |
| NoBusPartClock-ML | Verilog<br>+<br>VHDL | Bus bits or<br>slices should<br>not be used<br>as clocks                    | ' <count>' times Bus<br/>bits or slices used as<br/>clocks. Please refer<br/>to the spreadsheet<br/>for details</count>                                                                                                                                              | TURBO_CONSOLIDAT<br>E_PER_SOURCE<br>TURBO_BUS_MERGE                                  |
| NoExprInPort-ML   | VHDL                 | Port<br>connections in<br>instances<br>should not<br>contain<br>expressions | Instantiation of<br>module<br>' <modulename>'<br/>has '<count>' similar<br/>occurrence(s).Please<br/>refer to the<br/>spreadsheet for<br/>details</count></modulename>                                                                                               | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION<br>TURBO_GROUP_MESS<br>AGE            |

| Rule                     | Lang.                | Rule<br>Title                                                       | Parent<br>Message                                                                                                                                                                                                        | Turbo<br>Initiatives                                  |
|--------------------------|----------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| NoFeedThrus-ML           | Verilog<br>+<br>VHDL | Block should<br>not contain<br>feed-throughs                        | There is feed-<br>through from input<br>' <input-name>' to<br/>output '<output-<br>name&gt;', for <count><br/>occurrence(s) of the<br/>similar feed-through<br/>paths, please refer to</count></output-<br></input-name> | TURBO_BUS_MERGE<br>TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE |
|                          |                      |                                                                     |                                                                                                                                                                                                                          | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION        |
|                          |                      |                                                                     | the spreadsheet for details                                                                                                                                                                                              | TURBO_CONSOLIDAT<br>E_IO_PAIR                         |
| NoParamMultConcat<br>-ML | Verilog              | Do not use<br>parameter as<br>left operand                          | Parameter<br>' <parameter-name>'<br/>used '<count>' times</count></parameter-name>                                                                                                                                       | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                    |
|                          |                      | in multiple<br>concatenation<br>expression                          | in the multiple<br>concatenation<br>expression. Please<br>refer to the<br>spreadsheet for the<br>details                                                                                                                 | TURBO_GROUP_MESS<br>AGE                               |
| NoSigCaseX-ML            | Verilog              | Design should<br>not use<br>signals in                              | ' <count>' signals<br/>used in '<casex  <br="">casesz&gt; (<select-< td=""><td>TURBO_CONSOLIDAT<br/>E_DESIGN_SCOPE</td></select-<></casex></count>                                                                       | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                    |
|                          |                      | casex and<br>casez<br>constructs                                    | line-signal)' item at<br>line ' <line-number>'</line-number>                                                                                                                                                             | TURBO_GROUP_MESS<br>AGE                               |
| NoXInCase-ML             | VHDL                 | Case<br>expression<br>and case<br>choices<br>should not<br>have 'X' | <pre>'<count>' case expressions of case construct at line '<line-number>' of arch '<architecture- name="">' contains X</architecture-></line-number></count></pre>                                                       | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION        |

| Rule                         | Lang.                | Rule<br>Title                                                                                                              | Parent<br>Message                                                                                                                                                                                                                                                                                                                            | Turbo<br>Initiatives                                                                                             |
|------------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| ParamOverrideMism<br>atch-ML | Verilog              | Mismatch in<br>the number of<br>parameter<br>over-rides<br>and number<br>of parameters<br>in the<br>instantiated<br>module | Module ' <module-<br>name&gt;' has<br/>'<count>'<br/>instantiation for<br/>mismatch in number<br/>of parameter over-<br/>rides and number of<br/>parameters in the<br/>instantiated module.<br/>Please refer to the<br/>spreadsheet for<br/>details</count></module-<br>                                                                     | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION<br>TURBO_GROUP_MESS<br>AGE                                        |
| PartConnPort-ML              | Verilog              | Port is<br>unconnected<br>or partially<br>connected                                                                        | Port ' <port-name>'<br/>is unconnected or<br/>partially connected in<br/>instance '<instance-<br>name&gt;'[Hierarchy:<br/>'<hier-path>'].<br/>Module '<module-<br>name&gt;' has<br/>'<count>' similar<br/>occurrence(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count></module-<br></hier-path></instance-<br></port-name> | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION<br>TURBO_GROUP_MESS<br>AGE                                        |
| ReEntrantOutput-ML           | Verilog<br>+<br>VHDL | The re-<br>entrant<br>outputs<br>should be<br>avoided                                                                      | Output port<br>' <output-port-<br>name&gt;' is driving the<br/>input port '<input-<br>port-name&gt;' of the<br/>same instance. For<br/>'<count>' similar<br/>occurrence(s),<br/>please refer to the<br/>spreadsheet for<br/>details</count></input-<br></output-port-<br>                                                                    | TURBO_BUS_MERGE<br>TURBO_GROUP_MESS<br>AGE<br>TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_CONSOLIDAT<br>E_MODULE |

| Rule                      | Lang.                                                                                    | Rule<br>Title                                                                                            | Parent<br>Message                                                                                                                                                                                                                                      | Turbo<br>Initiatives                           |
|---------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| ResetFlop-ML              | + flo<br>VHDL ha<br>se<br>se<br>sy                                                       | All the flip-<br>flops should<br>have either<br>asynchronous<br>set/reset or<br>synchronouss<br>et/reset | Flip-flop ' <flip-flop-<br>name&gt;' has no set or<br/>reset.[Hierarchy:<br/>'<hier-path>'], for<br/>the similar <count><br/>occurrence(s) of flip-<br/>flops, please refer to<br/>the spreadsheet for<br/>details</count></hier-path></flip-flop-<br> | TURBO_REMOVE_DUP<br>_MSG                       |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE             |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_GROUP_MESS<br>AGE                        |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_BUS_MERGE                                |
| SignedUnsignedExpr<br>-ML | Verilog Do not mix<br>signed &<br>unsigned<br>variables/<br>constants in<br>expressions, | signed &                                                                                                 | Unsigned expression<br>used with Signed<br>expression <count><br/>times within same<br/>statement. Please<br/>refer to the</count>                                                                                                                     | TURBO_IGNORE_STA<br>TIC_CONSTANTS              |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_GROUP_MESS<br>AGE                        |
|                           |                                                                                          | assignment<br>statements or<br>in<br>comparisons.                                                        | spreadsheet for<br>details                                                                                                                                                                                                                             | TURBO_SET_RECOMM<br>ENDED_PARAMETER            |
| UndrivenInTerm-ML         | +                                                                                        | Undriven but<br>loaded input<br>terminal of an                                                           | ' <count>' input<br/>terminal(s) of<br/>module '<module-< td=""><td>TURBO_CONSOLIDA<br/>TE_PORT</td></module-<></count>                                                                                                                                | TURBO_CONSOLIDA<br>TE_PORT                     |
|                           |                                                                                          | instance<br>detected                                                                                     | name>' are undriven                                                                                                                                                                                                                                    | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
|                           |                                                                                          |                                                                                                          |                                                                                                                                                                                                                                                        | TURBO_GROUP_MESS<br>AGE                        |

| Rule                          | Lang.                | Rule<br>Title                              | Parent<br>Message                                                                                                                | Turbo<br>Initiatives                           |
|-------------------------------|----------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| UndrivenNUnloaded-<br>ML      | Verilog<br>+<br>VHDL | Undriven and<br>Unloaded<br>nets/          | Detected undriven<br>and<br>unloaded(unconnect                                                                                   | TURBO_CONSOLIDA<br>TE_PORT                     |
|                               |                      | terminals<br>detected in<br>the design     | ed) <terminal-<br>name&gt;. For similar<br/><count></count></terminal-<br>                                                       | TURBO_GROUP_MESS<br>AGE                        |
|                               |                      |                                            | occurrence(s) of<br>same module<br>' <module-name>',<br/>please refer to the<br/>spreadsheet for<br/>details</module-name>       | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
| UndrivenOutPort-ML            | Verilog<br>+<br>VHDL | Undriven but<br>loaded output<br>port of a | <pre>'<count>' output port of module '<module-name>'</module-name></count></pre>                                                 | TURBO_CONSOLIDA<br>TE_PORT                     |
|                               |                      | module<br>detected                         | are undriven                                                                                                                     | TURBO_GROUP_MESS<br>AGE                        |
|                               |                      |                                            |                                                                                                                                  | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
| UndrivenOutTermNL<br>oaded-ML | Verilog<br>+<br>VHDL | Undriven<br>output pins<br>connected to    | <pre>'<count>' input terminals of module '<module-name>'</module-name></count></pre>                                             | TURBO_CONSOLIDAT<br>E_PORT                     |
|                               |                      | instance input                             | are connected to<br>undriven output<br>terminal                                                                                  | TURBO_GROUP_MESS<br>AGE                        |
|                               |                      |                                            |                                                                                                                                  | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
| UnloadedInPort-ML             | Verilog<br>+<br>VHDL | Unloaded but<br>driven input<br>port of a  | Detected ' <count>'<br/>unloaded(unconnect<br/>ed) (input port type</count>                                                      | TURBO_CONSOLIDAT<br>E_PORT                     |
|                               |                      | module<br>detected                         | <pre><pre><pre>closeline (mput port spot<br/><pre>&gt; of<br/>module '<module-<br>name&gt;'</module-<br></pre></pre></pre></pre> | TURBO_GROUP_MESS<br>AGE                        |
|                               |                      |                                            |                                                                                                                                  | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |

| Rule                      | Lang.                | Rule<br>Title                                            | Parent<br>Message                                                                                                                                                           | Turbo<br>Initiatives                                              |
|---------------------------|----------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| UnloadedNet-ML            | Verilog<br>+<br>VHDL | Unloaded but<br>driven net<br>detected in<br>the design  | Detected ' <count>'<br/>unloaded(unconnect<br/>ed) (net type <net-<br>type&gt;) of module<br/>'<module-name>'</module-name></net-<br></count>                               | TURBO_BUS_MERGE<br>TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION |
|                           |                      |                                                          |                                                                                                                                                                             | TURBO_GROUP_MESS<br>AGE                                           |
| UnloadedOutTerm-<br>ML    | Verilog<br>+<br>VHDL | Unloaded but<br>driven output<br>terminal of an          | Detected ' <count>'<br/>unloaded(unconnect<br/>ed) (output terminal</count>                                                                                                 | TURBO_CONSOLIDAT<br>E_PORT                                        |
|                           | UTIDE                | instance<br>detected                                     | type <terminal-<br>name&gt;<connected<br>to a floating net&gt;<br/>(<net-name>)) of<br/>module '<module-<br>name&gt;'</module-<br></net-name></connected<br></terminal-<br> | TURBO_GROUP_MESS<br>AGE                                           |
|                           |                      |                                                          |                                                                                                                                                                             | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                    |
| NoWidthInBasedNu<br>m-ML  | Verilog              | Width should<br>be specified<br>for all based<br>numbers | Width specification<br>missing for <count><br/>based number(s).<br/>Please refer to the<br/>spreadsheet for</count>                                                         | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE     |
|                           |                      |                                                          | details                                                                                                                                                                     | TURBO_IGNORE_PAD<br>DING                                          |
| ParamWidthMismatc<br>h-ML | Verilog              | Parameter<br>width does<br>not match<br>with the value   | or <count><br/>occurrence(s) of<br/>parameter width<br/>mismatch in module</count>                                                                                          | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION                    |
|                           |                      | assigned                                                 | <module-name>,<br/>please refer to the<br/>spreadsheet for<br/>details</module-name>                                                                                        | TURBO_GROUP_MESS<br>AGE                                           |

| Rule              | Lang.   | Rule<br>Title                                                          | Parent<br>Message                                                                                                                                                                                                                       | Turbo<br>Initiatives                                          |
|-------------------|---------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| NestedCaseStmt-ML | Verilog | Nesting depth<br>of case<br>construct<br>exceeds<br>specified<br>depth | Nested case<br>construct found.<br>Depth exceeding<br>specified limit<br>\$casedepth at<br>' <count>' place(s) in<br/>source '<source-file-<br>name&gt;'. Please refer<br/>to the spreadsheet<br/>for details</source-file-<br></count> | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE |
| NestedCaseStmt-ML | VHDL    | Nesting depth<br>of case<br>construct<br>exceeds<br>specified<br>depth | Nested case<br>construct found.<br>Depth exceeding<br>specified limit<br>\$casedepth at<br>' <count>' place(s) in<br/>source '<source-file-<br>name&gt;'. Please refer<br/>to the spreadsheet<br/>for details</source-file-<br></count> | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE |
| UnrecSynthDir-ML  | Verilog | Synthesis<br>directive is<br>not<br>recognized                         | <count> more<br/>unrecognized<br/>synthesis directive(s)<br/>for pragmas used in<br/>the design. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                        | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE |
| UnrecSynthDir-ML  | VHDL    | Synthesis<br>directive is<br>not<br>recognized                         | <count> more<br/>unrecognized<br/>synthesis directive(s)<br/>for pragmas used in<br/>the design. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                        | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE |

| Rule                      | Lang.                | Rule<br>Title                                           | Parent<br>Message                                                                                    | Turbo<br>Initiatives                                   |
|---------------------------|----------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| RedundantLogicalOp<br>-ML | Verilog              | Logical<br>operation<br>result is same<br>as one of the | Redundant logical<br>operation is<br>performed at<br><count> more</count>                            | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS |
|                           |                      | operands or is<br>a constant                            | places. Please refer<br>to the spreadsheet<br>for details                                            | AGE                                                    |
| RedundantLogicalOp<br>-ML | VHDL                 | Logical<br>operation<br>result is same                  | Redundant logical<br>operation is being<br>performed on a                                            | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                     |
|                           |                      | as one of the<br>operands or is<br>a constant           | constant at <count><br/>more places. Please<br/>refer to the<br/>spreadsheet for<br/>details</count> | TURBO_GROUP_MESS<br>AGE                                |
| SynchReset-ML             | Verilog              | Do not use<br>synchronous<br>reset in the               | Synchronous reset<br>used at ' <count>'<br/>place(s) inside</count>                                  | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                     |
|                           |                      | design                                                  | module ' <module-<br>name&gt;'. Please refer<br/>to the spreadsheet<br/>for details</module-<br>     | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION         |
|                           |                      |                                                         |                                                                                                      | TURBO_GROUP_MESS<br>AGE                                |
| SynchReset-ML             | Verilog<br>+<br>VHDL | Do not use<br>synchronous<br>reset in the               | Synchronous reset<br>used at ' <count>'<br/>place(s) inside</count>                                  | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE                     |
|                           | UTICE .              | design                                                  | module ' <module-<br>name&gt;'. Please refer<br/>to the spreadsheet<br/>for details</module-<br>     | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION         |
|                           |                      |                                                         |                                                                                                      | TURBO_GROUP_MESS<br>AGE                                |

| Rule                    | Lang.                | Rule<br>Title                                                | Parent<br>Message                                                                                                                                                                                               | Turbo<br>Initiatives                                                      |
|-------------------------|----------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| HangingInstInput-<br>ML | Verilog<br>+<br>VHDL | Net connected<br>to input port<br>of instance is<br>undriven | <pre>'<count>' input port of master '<master- mod-name="">' are '<undriven>'</undriven></master-></count></pre>                                                                                                 | TURBO_CONSOLIDAT<br>E_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE             |
| UndrivenNet-ML          | Verilog<br>+<br>VHDL | Undriven but<br>loaded net is<br>detected in<br>the design   | Detected undriven<br>net <net-name>. For<br/>similar <count><br/>occurrence(s) of<br/>same module<br/>'<module-name>',<br/>please refer to the<br/>spreadsheet for<br/>details</module-name></count></net-name> | TURBO_CONSOLIDAT<br>E_MODULE_CONFIGU<br>RATION<br>TURBO_GROUP_MESS<br>AGE |

## openmore

| Rule       | Lang.                | Rule<br>Title                                              | Parent<br>Message                                                                                                                                                                                                                       | Turbo<br>Initiatives                                                                                                                               |
|------------|----------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| ArrayIndex | Verilog              | Bus signals<br>are declared<br>with low-order<br>bit first | <count> arrays not<br/>declared in<br/>recommended format<br/>of [MSB:LSB]. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                                             | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE                                                                                      |
| ArrayIndex | VHDL                 | Bus signals<br>are declared<br>with low-order<br>bit first | Not applicable                                                                                                                                                                                                                          | TURBO_REMOVE_DU<br>P_MSG                                                                                                                           |
| InferLatch | Verilog<br>+<br>VHDL | Latch inferred                                             | ' <count>' latche(s)<br/>inferred for signal<br/>'<signal-name> in<br/>module '<module-<br>name&gt;'</module-<br></signal-name></count>                                                                                                 | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_BUS_MERGE<br>TURBO_SET_RECOM<br>MENDED_PARAMETE<br>R |
| IntClock   | Verilog<br>+<br>VHDL | Internally<br>generated<br>clock detected                  | Internally generated<br>Clock ' <clock-<br>name&gt;'(flop: <flip-<br>flop-name&gt;)<br/>detected, for the<br/>similar <count><br/>occurrence(s), please<br/>refer to the<br/>spreadsheet for<br/>details</count></flip-<br></clock-<br> | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_BUS_MERGE                                                                                  |

| Rule     | Lang.                | Rule<br>Title                                         | Parent<br>Message                                                                                                                                                                                | Turbo<br>Initiatives                                              |
|----------|----------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| IntReset | Verilog<br>+<br>VHDL | Internally<br>generated<br>reset detected             | <count><br/>occurrence(s) of<br/>Internally generated<br/>asynchronous set/<br/>reset '<signal-<br>name&gt;'. Please refer<br/>to the spreadsheet</signal-<br></count>                           | TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION<br>TURBO_BUS_MERGE |
|          |                      |                                                       | for details                                                                                                                                                                                      |                                                                   |
| ConsCase | Verilog              | Name not<br>used<br>consistently<br>with same<br>case | Module < module-<br>name> has <count><br/>names which are not<br/>used with consistent<br/>case. Please refer to<br/>the spreadsheet for<br/>details.</count>                                    | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE     |
| ConsCase | VHDL                 | Name not<br>used<br>consistently<br>with same<br>case | Name ' <identifier-<br>name&gt;' not used<br/>with consistent case.<br/>For <count> similar<br/>occurrence(s) ,<br/>please refer to the<br/>spreadsheet for<br/>details</count></identifier-<br> | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE     |

| Rule       | Lang.   | Rule<br>Title                                                               | Parent<br>Message                                                                                                                                                                                                                                     | Turbo<br>Initiatives                                                                 |
|------------|---------|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| ActLowName | Verilog | Active-low<br>signal name<br>does not<br>follow the<br>naming<br>convention | Active Low signal<br>' <signal-name>'<br/>does not follow<br/>naming convention.<br/>For <count> similar<br/>occurrence(s) of</count></signal-name>                                                                                                   | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_CONSOLIDA<br>TE_MODULE_CONFI<br>GURATION |
|            |         |                                                                             | module <module-<br>name&gt;, please refer<br/>to the spreadsheet<br/>for details</module-<br>                                                                                                                                                         | TURBO_GROUP_MES<br>SAGE                                                              |
| ActLowName | VHDL    | Active-low<br>signal name<br>does not<br>follow the<br>naming<br>convention | Active Low signal<br>' <signal-name>'<br/>does not follow<br/>naming convention.<br/>For <count> similar<br/>occurrence(s) of<br/>module <module-<br>name&gt;, please refer<br/>to the spreadsheet<br/>for details</module-<br></count></signal-name> | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE                        |

**NOTE:** In the turbo mode, irrespective of the parameter setting, the InferLatch rule will not report violation for those latches whose input 'D' is tied to constant.

## simulation

| Rule       | Lang.   | Rule<br>Title                                                                           | Parent<br>Message                                                                                                                                                                                           | Turbo<br>Initiatives                                               |
|------------|---------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| sim_race01 | Verilog | Assignment<br>and use of<br>signal in same<br>simulation<br>cycle (Read-<br>Write Race) | <pre>'<count>' occurrences of Read-Write Race for signal '<signal-name>' w.r.t. always block at line '<line-number>'. Please refer to the spreadsheet for details</line-number></signal-name></count></pre> | TURBO_IGNORE_PA<br>RTIAL_BUS<br>TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE |

## starc

| Rule          | Lang.                | Rule<br>Title                                                             | Parent<br>Message                                                                                                                                                                                                                        | Turbo<br>Initiatives             |
|---------------|----------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| STARC-1.4.3.4 | Verilog<br>+<br>VHDL | Flip-flop clock<br>signals must<br>not be used as<br>non-clock<br>signals | Clock signal ' <signal-<br>name&gt;' used as a<br/>non-clock (Used with<br/>name '<non-clock-<br>name&gt;'). For similar<br/><count> cases,<br/>please refer to the<br/>spreadsheet for<br/>details</count></non-clock-<br></signal-<br> | TURBO_CONSOLIDATE<br>_PER_SOURCE |
| STARC-1.6.6.3 | Verilog              | Do not<br>instantiate<br>library cells in<br>the design                   | Library cell ' <cell-<br>name&gt;' instantiated.<br/>For similar '<count>'<br/>violations for module<br/>'<module-name>',<br/>please refer to the<br/>spreadsheet for<br/>details</module-name></count></cell-<br>                       | TURBO_GROUP_MESS<br>AGE          |

| Rule           | Lang.   | Rule<br>Title                                                         | Parent<br>Message                                                                                                                                                                                                 | Turbo<br>Initiatives                                                                      |
|----------------|---------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| STARC-1.6.6.3  | VHDL    | Do not directly<br>instantiate<br>cells in the<br>design              | Library cell ' <cell-<br>name&gt;' instantiated.<br/>For similar '<count>'<br/>violations for module<br/>'<module-name>,<br/>please refer to the<br/>spreadsheet for<br/>details</module-name></count></cell-<br> | TURBO_GROUP_MESS<br>AGE                                                                   |
| STARC-2.1.6.1  | Verilog | Array<br>specification<br>should follow<br>recommended<br>convention. | <count> arrays not<br/>declared in<br/>recommended format<br/>of [MSB:LSB]. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                       | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE<br>TURBO_REMOVE_DUP<br>_MSG |
| STARC-2.1.6.1  | VHDL    | Specification<br>of one-<br>dimensional<br>array should<br>be downto  | <count> arrays not<br/>declared in<br/>recommended format<br/>of [MSB:LSB]. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                       | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE                             |
| STARC-2.10.3.5 | Verilog | Base should<br>be specified<br>for constant<br>value used.            | Missing base type<br>specification in<br>constant value at<br><count> place(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count>                                                                   | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_CONSOLIDATE<br>_MODULE_CONFIGUR<br>ATION      |
| STARC-2.10.6.1 | Verilog | Possible loss<br>of carry or<br>borrow in<br>addition/<br>subtraction | <count> occurrences<br/>of assignment<br/>overflow on same<br/>assignment. Please<br/>refer to the<br/>spreadsheet for<br/>details</count>                                                                        | TURBO_GROUP_MESS<br>AGE<br>TURBO_IGNORE_RED<br>UNDANT_RULE                                |

#### **Rule-wise Initiatives**

| Rule          | Lang.   | Rule<br>Title                                                                                                        | Parent<br>Message                                                                                                                                                                                         | Turbo<br>Initiatives                                                                                |
|---------------|---------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| STARC-2.2.2.2 | Verilog | A variable<br>specified in<br>the sensitivity<br>list must be<br>read in the<br>contained<br>block                   | <variable-name><br/>signal/variable(s) not<br/>read in <block-type><br/>is/are not required in<br/>sensitivity list. Please<br/>refer to the<br/>spreadsheet for<br/>details</block-type></variable-name> | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_IGNORE_STAT<br>IC_CONSTANTS<br>TURBO_REMOVE_DUP<br>_MSG |
| STARC-2.2.2.2 | VHDL    | A signal<br>should not be<br>included in<br>sensitivity list<br>of a process if<br>it is not read<br>in that process | Not applicable                                                                                                                                                                                            | TURBO_REMOVE_DUP<br>_MSG                                                                            |
| STARC-3.2.2.7 | Verilog | Constants<br>should be<br>defined using<br>parameters<br>only.                                                       | Use parameter<br>instead of macro at<br><count> place(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count>                                                                                 | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE                                       |

| Rule           | Lang.                | Rule<br>Title                                                                                                                       | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Turbo<br>Initiatives                                                                                    |
|----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| STARC-3.3.2.2a | Verilog<br>+<br>VHDL | Internal clocks<br>must be<br>controllable<br>from external<br>pins                                                                 | Internal clock<br>' <clock-name>'<br/>(flop: '<flip-flop-<br>name&gt;') not<br/>controllable from<br/>external pins, for the<br/>similar <count><br/>occurrence(s), please<br/>refer to the<br/>spreadsheet for<br/>details</count></flip-flop-<br></clock-name>                                                                                                                                                                                                                            | TURBO_CONSOLIDATE<br>_MODULE_CONFIGUR<br>ATION<br>TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_BUS_MERGE |
| STARC-1.3.1.3  | Verilog<br>+<br>VHDL | Asynchronous<br>reset/preset<br>signals must<br>not be used as<br>non-reset/<br>preset or<br>synchronous<br>reset/preset<br>signals | Asynchronous<br><type> signal<br/>'<signal-name>'<br/>(<flop latch=""  ="">:<br/>'<flip-flop-name  <br="">latch-name&gt;') used<br/>as non-<type>/<br/>synchronous-<type><br/>at instance<br/>'<instance-name>'<br/>(File Name: '<file-<br>name&gt;',Line no.:<br/>'<line-number>').<br/>For similar '<count>'<br/>case(s), please refer<br/>to the spreadsheet<br/>for details</count></line-number></file-<br></instance-name></type></type></flip-flop-name></flop></signal-name></type> | TURBO_CONSOLIDATE<br>_PER_SOURCE                                                                        |

## starc2002

| Rule             | Lang.                | Rule<br>Title                                                                                                                   | Parent<br>Message                                                                                                                                                                                                                     | Turbo<br>Initiatives                                                                      |
|------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| STARC02-1.4.3.4  | Verilog<br>+<br>VHDL | Connected net<br>name of a<br>module<br>instance must<br>be same as or<br>based on the<br>master<br>module output<br>port name. | Clock signal ' <signal-<br>name&gt;1' used as a<br/>non-clock (Used with<br/>name '<non-clock-<br>name&gt;'). For similar<br/><count> cases, please<br/>refer to the<br/>spreadsheet for details</count></non-clock-<br></signal-<br> | TURBO_CONSOLIDA<br>TE_PER_SOURCE                                                          |
| STARC02-2.1.6.1  | Verilog              | Array<br>specification<br>should follow<br>recommended<br>convention.                                                           | <count> arrays not<br/>declared in<br/>recommended format<br/>of [MSB:LSB]. Please<br/>refer to the<br/>spreadsheet for details</count>                                                                                               | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE<br>TURBO_REMOVE_DU<br>P_MSG |
| STARC02-2.1.6.1  | VHDL                 | Specification<br>of one-<br>dimensional<br>array should<br>be downto                                                            | <count> arrays not<br/>declared in<br/>recommended format<br/>of [MSB:LSB]. Please<br/>refer to the<br/>spreadsheet for details</count>                                                                                               | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE                             |
| STARC02-2.10.3.5 | Verilog              | A function<br>description<br>must assign<br>return values<br>to all possible<br>states of the<br>function.                      | Missing base type<br>specification in<br>constant value at<br><count> place(s).<br/>Please refer to the<br/>spreadsheet for details</count>                                                                                           | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE                                                        |
| STARC02-2.10.3.7 | Verilog              | Match the bit<br>width with the<br>base number<br>part                                                                          | Mismatch in actual<br>width and specified<br>width for <count><br/>based number(s).<br/>Please refer to the<br/>spreadsheet for details</count>                                                                                       | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_IGNORE_PA<br>DDING                            |

| Rule             | Lang.                | Rule<br>Title                                                         | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Turbo<br>Initiatives                                          |
|------------------|----------------------|-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| STARC02-2.10.6.1 | Verilog              | Possible loss<br>of carry or<br>borrow in<br>addition/<br>subtraction | Possible assignment<br>overflow: Ihs width<br><widthl> (Expr:<br/>'<lexpr>') should be<br/>greater than rhs width<br/><widthr> (Expr:<br/>'<rexpr>') to<br/>accommodate carry/<br/>borrow bit, [Hierarchy:<br/>'<hier-path>'],<br/><count> occurrences<br/>of assignment overflow<br/>on same assignment.<br/>Please refer to the<br/>spreadsheet for details.</count></hier-path></rexpr></widthr></lexpr></widthl>                                                            | TURBO_GROUP_MES<br>SAGE<br>TURBO_IGNORE_RE<br>DUNDANT_RULE    |
| STARC02-3.2.2.7  | Verilog              | Constants<br>should be<br>defined using<br>parameters<br>only.        | Use parameter instead<br>of macro at <count><br/>place(s). Please refer<br/>to the spreadsheet for<br/>details</count>                                                                                                                                                                                                                                                                                                                                                          | TURBO_CONSOLIDA<br>TE_DESIGN_SCOPE<br>TURBO_GROUP_MES<br>SAGE |
| STARC02-1.3.1.3  | Verilog<br>+<br>VHDL | Do not use<br>case variants<br>of names in<br>the same<br>scope.      | Asynchronous <type><br/>signal '<signal-name>'<br/>(<flop latch=""  ="">: '<flip-<br>flop-name   latch-<br/>name&gt;') used as non-<br/><type>/synchronous-<br/><type> at instance<br/>'<instance-name>'<br/>(File Name: '<file-<br>name&gt;' ,Line no.:<br/>'<line-number>'). For<br/>similar '<count>'<br/>case(s), please refer to<br/>the spreadsheet for<br/>details</count></line-number></file-<br></instance-name></type></type></flip-<br></flop></signal-name></type> | TURBO_CONSOLIDA<br>TE_PER_SOURCE                              |

## starc2005

| Rule             | Lang.                | Rule<br>Title                                                                                                     | Parent<br>Message                                                                                                                                                                      | Turbo<br>Initiatives                                           |
|------------------|----------------------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| STARC05-1.4.3.4  | Verilog<br>+<br>VHDL | Flip-flop clock<br>signals must<br>not be used as<br>non-clock<br>signals                                         | ' <count>' Non-clock<br/>signal '<non-clock-<br>signal-name&gt;' infer<br/>from same RTL used<br/>as clock signal</non-clock-<br></count>                                              | TURBO_CONSOLIDATE<br>_PER_SOURCE                               |
| STARC05-2.1.3.1  | Verilog              | Bit-width of<br>function<br>arguments<br>must match<br>bit-width of<br>the<br>corresponding<br>function<br>inputs | <count>occurrences<br/>of width mismatch on<br/>same function call<br/>argument<br/>'<argument-name>'.<br/>Please refer to the<br/>spreadsheet for<br/>details</argument-name></count> | TURBO_GROUP_MESS<br>AGE TURBO<br>TURBO_IGNORE_PAD<br>DING      |
| STARC05-2.10.3.5 | Verilog              | Base should<br>be specified<br>for constant<br>value used                                                         | Missing base type<br>specification in<br>constant value at<br><count> place(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count>                                        | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE                             |
| STARC05-2.10.3.7 | Verilog              | Match the bit<br>width with the<br>base number<br>part                                                            | Mismatch in actual<br>width and specified<br>width for <count><br/>based number(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count>                                    | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_IGNORE_PAD<br>DING |

| Rule             | Lang.                | Rule<br>Title                                                         | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                             | Turbo<br>Initiatives                                                                                    |
|------------------|----------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| STARC05-2.10.6.1 | Verilog              | Possible loss<br>of carry or<br>borrow in<br>addition/<br>subtraction | Possible assignment<br>overflow: Ihs width<br><widthl> (Expr:<br/>'<lexpr>') should be<br/>greater than rhs<br/>width <widthr><br/>(Expr: '<rexpr>') to<br/>accommodate carry/<br/>borrow bit,<br/>[Hierarchy: '<hier-<br>path&gt;'], <count><br/>occurrences of<br/>assignment overflow<br/>on same assignment.<br/>Please refer to the<br/>spreadsheet for<br/>details</count></hier-<br></rexpr></widthr></lexpr></widthl> | TURBO_GROUP_MESS<br>AGE<br>TURBO_IGNORE_RED<br>UNDANT_RULE                                              |
| STARC05-3.2.2.7  | Verilog              | Constants<br>should be<br>defined using<br>parameters<br>only         | Use parameter<br>instead of macro at<br><count> place(s).<br/>Please refer to the<br/>spreadsheet for<br/>details</count>                                                                                                                                                                                                                                                                                                     | TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_GROUP_MESS<br>AGE                                           |
| STARC05-3.3.1.1  | Verilog<br>+<br>VHDL | Internal clocks<br>must be<br>controllable<br>from external<br>pins   | Internal clock<br>' <clock-name>'<br/>(flop: '<flip-flop-<br>name&gt;') not<br/>controllable from<br/>external pins, for the<br/>similar <count><br/>occurrence(s),<br/>please refer to the</count></flip-flop-<br></clock-name>                                                                                                                                                                                              | TURBO_CONSOLIDATE<br>_MODULE_CONFIGUR<br>ATION<br>TURBO_CONSOLIDATE<br>_DESIGN_SCOPE<br>TURBO_BUS_MERGE |

| Rule             | Lang.                | Rule<br>Title                                                                                                                       | Parent<br>Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Turbo<br>Initiatives                                                                         |
|------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| STARC05-3.3.1.4b | Verilog<br>+<br>VHDL | A flip-flop<br>should have<br>an<br>asynchronous<br>set or an<br>asynchronous<br>reset                                              | Flip-flop ' <flip-flop-<br>name&gt;' has neither<br/>asynchronous set nor<br/>asynchronous reset.<br/>[Hierarchy: '<hier-<br>path&gt;'], for the<br/>similar '<count>'<br/>occurrence(s),</count></hier-<br></flip-flop-<br>                                                                                                                                                                                                                                                                | TURBO_CONSOLIDATE<br>_MODULE_CONFIGUR<br>ATION<br>TURBO_GROUP_MESS<br>AGE<br>TURBO_BUS_MERGE |
| STARC05-1.3.1.3  | Verilog<br>+<br>VHDL | Asynchronous<br>reset/preset<br>signals must<br>not be used as<br>non-reset/<br>preset or<br>synchronous<br>reset/preset<br>signals | Asynchronous<br><type> signal<br/>'<signal-name>'<br/>(<flop latch=""  ="">:<br/>'<flip-flop-name  <br="">latch-name&gt;') used<br/>as non-<type>/<br/>synchronous-<type><br/>at instance<br/>'<instance-name>'<br/>(File Name: '<file-<br>name&gt;',Line no.:<br/>'<line-number>').<br/>For similar '<count>'<br/>case(s), please refer<br/>to the spreadsheet<br/>for details</count></line-number></file-<br></instance-name></type></type></flip-flop-name></flop></signal-name></type> | TURBO_CONSOLIDATE<br>_PER_SOURCE                                                             |

# timing

| Rule       | Lang.                | Rule<br>Title                                                                                                                                                                                                                                                            | Parent<br>Message | Turbo<br>Initiatives                |
|------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------------------|
| LogicDepth | Verilog<br>+<br>VHDL | Logic depth exceeds<br>specified number of<br>levels (using<br>parameter delaymax/<br>delaymax_memtoflop<br>/<br>delaymax_floptomem<br>m/delaymax_err/<br>delaymax_inputtoflop<br>/<br>delaymax_floptoflop/<br>delaymax_floptooutp<br>put/<br>delaymax_floptooutp<br>ut) | Not<br>applicable | TURBO_SET_RECOMM<br>ENDED_PARAMETER |
| LogNMux    | Verilog<br>+<br>VHDL | LogN mux with large<br>number of inputs<br>detected - potential<br>performance problem                                                                                                                                                                                   | Not applicable    | TURBO_SET_RECOMM<br>ENDED_PARAMETER |

## **Turbo Parameter Settings**

The default value of the following rule parameters is changed when the **turbo** mode is enabled:

| Parameter                                                                                          | Rules                                                                                                                                                                                               |
|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| checkfullrecord                                                                                    | W456a, W528, W123, W120, W240                                                                                                                                                                       |
| checkfullbus                                                                                       | W240, W528, W120,<br>UnUsedFunctionInput-ML,<br>UndrivenInTerm-ML                                                                                                                                   |
| min_based_width is set to 1                                                                        | NoWidthInBasedNum-ML                                                                                                                                                                                |
| delaymax is set to 500                                                                             | LogicDepth                                                                                                                                                                                          |
| logmux_max is set to 5                                                                             | LogNMux                                                                                                                                                                                             |
| check_initialization_assignment,<br>ignore_multi_assign_in_forloop,<br>ignore_bitwiseor_assignment | W415a                                                                                                                                                                                               |
| ignoreforindex                                                                                     | SignedUnsignedExpr-ML                                                                                                                                                                               |
| checkInHierarchy                                                                                   | HangingInstInput-ML, UndrivenOutPort-<br>ML, UndrivenInTerm-ML, UndrivenNet-<br>ML, UnloadedInPort-ML,<br>UnloadedOutTerm-ML, UnloadedNet-ML,<br>UndrivenNUnloaded-ML,<br>UndrivenOutTermNLoaded-ML |
| checkRTLCInst                                                                                      | UndrivenInTerm-ML                                                                                                                                                                                   |
| checkalldimension                                                                                  | ArrayIndex                                                                                                                                                                                          |
| ignoreModuleInstance                                                                               | W123                                                                                                                                                                                                |
| ignore_chain_cell                                                                                  | DisabledAnd, DisabledOr                                                                                                                                                                             |
| nocheckoverflow                                                                                    | STARC05-<br>2.1.3.1,W116,W164a,W164b,W263,W11<br>0,W486,W362                                                                                                                                        |
| strict                                                                                             | W342, W343                                                                                                                                                                                          |

However, to retain the default value of the above parameters in the turbo mode, specify the following command:

set\_option disable\_turbo\_param yes

By default, the strict parameter is always enabled for the *InferLatch* rule. In order to disable it, use the disable turbo param option.

**NOTE:** In the **turbo** mode, the default value of the parameters will be synchronized with GuideWare 2015.12 setting.

#### base\_turbo\_limit\_viol

This parameter specifies the limit of violation messages to be reported in the message tree, while remaining messages are reported in the spreadsheet.

By default, this parameter is set to 2.

Set the base\_turbo\_limit\_viol parameter to a positive integer value to limit the number of violation messages to be reported in message tree. You can also specify different values for different rules using the comma-separated (no spaces) <rulename>=<value> pairs. See the examples below for more clarity.

- **NOTE:** There should be no spaces between the rule name and its limit value before and after the = symbol, that is, <rule-name>=<value>.
- **NOTE:** If you specify a value that is less than 1, the rule considers the default value only, which is 2.

#### Examples:

set\_parameter base\_turbo\_limit\_viol 10,SynchReset-ML=15,ConsCase=4

In this case, for the rules other than *SynchReset-ML* and *ConsCase* value of this parameter will be set to 10, while for the *SynchReset-ML* and *ConsCase* rules, it will be set to 15 and 4 respectively.

set\_parameter base\_turbo\_limit\_viol SynchReset-ML=15,ConsCase=4

In this case, for the rules other than *SynchReset-ML* and *ConsCase*, the value of this parameter will be set to 2 (default value).

- If the base\_turbo\_limit\_viol rules is not set, then the default value, which is 2, is considered for all the rules.
- **NOTE:** The parameter is valid only when the 'set\_option turbo yes' is specified.

The base\_turbo\_limit\_viol parameter is supported by the following rules:

| Rule name             | Product  | Language |
|-----------------------|----------|----------|
| ArrayIndex            | openmore | Verilog  |
| ConstDrivenNet-ML     | morelint | Verilog  |
| ConstDrivenNet-ML     | morelint | VHDL     |
| ConsCase              | openmore | Verilog  |
| NestedCaseStmt-ML     | morelint | Verilog  |
| ParamWidthMismatch-ML | morelint | Verilog  |
| SynchReset-ML         | morelint | Verilog  |
| ActLowName            | openmore | Verilog  |
| ConsCase              | openmore | VHDL     |
| NestedCaseStmt-ML     | morelint | VHDL     |
| W494a                 | lint     | VHDL     |
| SynchReset-ML         | morelint | VHDL     |
| UnrecSynthDir-ML      | morelint | VHDL     |

## **Smart Rule Execution**

SpyGlass Lint Turbo Structural enables the smart execution of rules. When a superset rule is run, in that case subset rule will not run. So, you can use a superset rule to perform the tasks of specified subset rules.

The smart rule execution works in the **Turbo** mode only.

For the smart rule execution to perform, the following should be set:

- set option turbo yes
- set option smart rule execution yes

The following table lists the rules that are part of smart rule execution:

| Superset Rule    | Subset Rule(s)                                        |
|------------------|-------------------------------------------------------|
| W484             | STARC-2.10.6.1, STARC05-2.10.6.1,<br>STARC02-2.10.6.1 |
| STARC05-2.10.6.1 | STARC-2.10.6.1, STARC02-2.10.6.1                      |
| STARC02-2.10.6.1 | STARC-2.10.6.1                                        |
| W415             | checkMultipleDrivers                                  |

- **NOTE:** Smart rule execution is also applicable for the Starc, Starc2002 and Starc2005 rules. The Starc2005 rules are superset of Starc2002 and Starc rules. The Starc2002 rules are superset of Starc rules.
- **NOTE:** If the smart\_rule\_execution option is set to yes and the turbo\_struct license is not found, then the smart rule execution feature is disabled.

#### Waiving Primary Messages in the Turbo Mode

In the **turbo** mode, you can waive primary messages along with the respective secondary messages.

When you click on the waive option, a confirmation box is displayed with the following options, as shown in the figure:

Yes: Primary messages are waived along with all the secondary messages.

- No: Primary messages are waived. However, if you select multiple messages (primary along with secondary messages of the same or different rules), only secondary messages are waived.
- **Cancel**: No violations are waived.



FIGURE 1. Primary message waiver confirmation

#### **Defining the Preferred Waiver Behavior**

You can define the preferred waiver behavior by using the **Waiving** primary messages set of options in the **Tools > Preferences > Waiver** menu of **SpyGlass Console**.



FIGURE 2. Defining the primary messages waiver behavior

The following options are available:

- Allow with warning: This option is selected by default. In case of any primary message in the selected message list, the warning/confirmation box is displayed.
- Allow without warning: Primary messages are waived without any warning and the warning/confirmation box is not displayed.
- Disallow waiving: Primary messages are not waived and the warning/ confirmation box is also not displayed. This changes the right-click menu behavior as follows:

**I** Right-click when both primary and non-primary violations selected:

 Options for waiving messages are displayed in the right-click menu. However only non-primary messages are waived on selecting it.

**I** Right-click when only the primary messages are selected:

 Options for waiving messages are not displayed in the right-click menu.

## The moresimple\_turbo Report

In the **turbo** mode, the moresimple\_turbo.rpt report is also generated by default.

This report contains all the violation messages from the message tree and spreadsheet.

The following is a sample of this report:

\*\*\*\*\*

```
#
# This file has been generated by SpyGlass:
#
                        : moresimple_turbo
      Report Name
#
      Report Created by: nadunig
      Report Created on: Tue Mar 15 18:24:08 2016
#
#
      Working Directory: /remote/atr_sl_user/nadunig/Test/560/98424/
case3
#
      SpyGlass Version : 5.6.1-FCS-C2
#
      Policy Name
                        : SpyGlass(5.6.1)
#
                          erc(5.6.1)
#
                          lint(5.6.1)
#
                          morelint(5.6.1)
#
#
      Total Number of Generated Primary Messages
                                                                10
                                                     :
#
      Total Number of Generated Secondary Messages :
                                                                 2
#
      Number of Waived Primary Messages
                                                      :
                                                                 0
#
      Number of Waived Secondary Messages
                                                                 0
                                                      :
                                                                10
#
      Number of Reported Primary Messages
                                                      ٠
#
      Number of Reported Secondary Messages
                                                                 2
#
      Number of Overlimit Messages
                                                                 0
                                                      :
```

#

```
MORESIMPLE TURBO REPORT:
TD
     ParentID
             Rule
                             Alias
                                            Severity
File
Line
     Wt
Message
_____
[3]
     N.A
           DetectTopDesignUnits DetectTopDesignUnits
                                              Info
checkPinConnectedToSupply.v
10
     2
Module top is a top level design unit
[0]
     N.A
            AutoGenerateSqlib
                            AutoGenerateSqlib
                                             Tnfo
Work/Linux4/test/spyglass_cache/autogenerated_sglib/lc/
spyglass lc aggregate reports/moresimple.rpt
                                         2
                                   0
Sqlib 'Work/Linux4/test/spyglass cache/autogenerated sqlib/
aggregate.sqlib' has been auto-generated successfully
[2]
     N.A
             ElabSummary
                             ElabSummary
                                             Tnfo
Work/Linux4/test/test_goal/spyglass_reports/SpyGlass/elab_summary.rpt
0
     2
Please refer file 'Work/Linux4/test/test goal/spyglass reports/SpyGlass/
elab_summary.rpt' for elab summary report
[1]
     ΝΔ
            TurboModeStatus
                             TurboModeStatus
                                             Tnfo
N.A.
     10
0
Turbo-Mode is enabled in the current run as turbo struct license feature
```

The moresimple\_turbo Report

successfully checked out ParentID Rule Alias Severity File ID Line Wt Message [4] N.A Warning RegInputOutput-ML checkPinConnectedToSupply.v 5 10 Port 'a' is not registered [Hierarchy: 'top'] [5] N.A RegInputOutput-ML Warning checkPinConnectedToSupply.v 5 10 Port 'b' is not registered [Hierarchy: 'top'] [6] N.A RegInputOutput-ML Warning checkPinConnectedToSupply.v 6 10 Port 'c' is not registered [Hierarchy: 'top'] RegInputOutput-ML [7] N.A Warning checkPinConnectedToSupply.v 10 Port 'd' is not registered 13 [Hierarchy: 'top'] [8] N.A RegInputOutput-ML Warning checkPinConnectedToSupply.v Port 'e' is not registered 14 10 [Hierarchy: 'top'] [B] N.A checkPinConnectedToSupply Warning checkPinConnectedToSupply.v 2 Pin of 2 cell LAN2 (instance 5 top.U1.I1) of module mod connected to supply signals. Please refer to the spreadsheet for details [9] [B] checkPinConnectedToSupply Warning checkPinConnectedToSupply.v 5 2 pin Z for instance top.U2.I1 (Cell LAN2) connected to supply signals [A] [B] checkPinConnectedToSupply Warning checkPinConnectedToSupply.v 5 2 pin Z for instance top.U1.I1 (Cell LAN2) connected to supply signals 

## **Known Problems**

The following are the current known issues in the Turbo mode:

- Performance (run-time) issue in GUI while applying waivers in spreadsheet.
- Assume if there are two parents messages, P1 and P2, and each parent message is having two child messages, 'C1' and 'C2' corresponding to the parent message 'P1' and child messages 'C3' and 'C4' corresponding to the parent message 'P2' (child message is a static message, that is, no variable argument in it). In this case if a waiver is applied to the child message 'C1' of parent message 'P1' then waiver will be applied to all the child messages, but parent message 'P1' will be waived and there will be no impact on the parent message 'P2' also gets waived.
- When you open spreadsheet tab to apply waiver, after applying waivers if we press cancel button on waiver window, the waivers are still applied.
- For a message having same argument but different line/file, if you apply waiver, it is set on all messages. But if you unwaive one message then it will be applicable to only that one. So there is inconsistency.
- For rules which are spyCreateruleByCopy, the CSV file directory is created inside the parent rules->policy directory structure of spyglass\_reports/<policy\_name>.
- Parent violations have been made transient, and waivers are not saved for parent, for subsequent runs. This may lead to difference with respect to parent message if you load the GUI (after running the design in the batch run).
- Peak memory and the runtime may increase slightly. As multiple callbacks DS is getting invoked.
- If a parent message is not added into the vdb by the sgHandleMessage call (violStatus from sgHandleMessage is: SG\_VIOL\_STATUS\_ERROR), then all of its child messages will be lost. Currently no non-error child message we are made as parent violations.
- As parent messages can be added as a child messages, assume a parent message has a flip-flop I1.q1[0] and it has four child messages, that is, I1.q1[0], I1.q1[1], I1.q1[2] and I1.q1[3]. If the child q1[0] is internally waived by the tool, then parent is reported as I1.q1[0] with three child messages (except the child I1.q1[0]). Ideally I1.q1[1] or I1.q1[2] or

11.q1[3] should be reported as a parent argument, which mean the parent arguments are not changed, so the count in the parent message is being adjusted.

- Child count in the parent message can be one due to various reasons.
  - □ Few child messages are internally waived [other than user waivers]
  - Child messages are getting bus-merged
  - □ If child messages are part of enable\_dup\_msg\_removal, then the parent with single child will be dumped
- For some violations of the *LatchGatedClock* rule, gated/internally generated clock source terminal and latch instance will only be highlighted instead of the complete path.
- If the message label changes, in that case there may be a case of break in waiver with respect to the old release.
- If parameterized module is instantiated in multiple places and all are having the same message then in few rules user may see one duplicate violation out of the spreadsheet in message tree. This will happen to a rule having a the -enable\_dup\_msg\_removal support
- If one parent message is waived (through user waiver or msg-tree), then infrastructure should waive all its child messages.
- Internal waivers may get applied on parent message, so all its child messages will be lost.
- Waive –du field is not applied on spreadsheet violation, while its applicable for normal message tree violations.
- Overload severity through external command will not be applicable for new parent messages (as their label will be different).
- In the Turbo mode, bus-merging may break in a few cases. This is due to enable\_smdb\_reports, which populates the reports in the Turbo mode.

Known Problems

# **SpyGlass Functional Lint**

Recent advancements in the industry have put emphasis to couple static lint checker with formal verification to augment current verification flows.

The existing SpyGlass Lint rules adopt structural analysis techniques. Some of these rules report many false violations because of the lack of design intent information.

SpyGlass supports Functional Lint rules that use formal verification strategies resulting in less noise and accurate results.

This section describes the following topics:

- Prerequisites for Using Turbo Functional Rules
- Turbo Capabilities
- Functional Lint to Lint Rule Mapping
- Generating Waivers for Structural Rules
- The SpyGlass Functional Lint Rules

For information on lint concepts and debug, refer to the *SpyGlass Lint and SpyGlass Auto Verify Rules Reference Guides.* 

# **Prerequisites for Using Turbo Functional Rules**

Specify the following:

- The lint\_func licenses
- Clocks and resets in an SGDC file (recommended approach)

If you do not specify clocks and resets in an SGDC file, set the use\_inferred\_clocks and use\_inferred\_resets parameter to yes to enable SpyGlass to automatically infer clocks and resets.

- Single top-level design
- If the turbo\_struct license is successfully checked out, then the noise reduction for the structural rule will be ported to the formal rule.
- By default, waveform viewer is disabled. You can enable it using the Edit -> Preferences option in SpyGlass Explorer.

# **Turbo Capabilities**

The SpyGlass Functional Lint product supports noise reduction capability, similar to the SpyGlass Turbo Lint (structural) product.

# **Functional Lint to Lint Rule Mapping**

The following table lists the rules in the *SpyGlass Functional Lint* product and the corresponding rule in *SpyGlass Lint* product:

 TABLE 1
 Rule Mapping

| Functional Lint Rule        | Lint Rule             |
|-----------------------------|-----------------------|
| Av_width_mismatch_assign    | W164a                 |
| Av_width_mismatch_case      | W263                  |
| Av_width_mismatch_port      | W110                  |
| Av_width_mismatch_function  | STARC-2.1.3.1         |
| Av_signed_unsigned_mismatch | SignedUnsignedExpr-ML |
| Av_width_mismatch_expr      | STAR-2.10.3.2a        |
| Av_width_mismatch_expr02    | W116                  |
| Av_width_mismatch_expr03    | W362                  |
| Av_case_default_redundant   | W551                  |
| Av_case_default_missing     | W71                   |
| Av_dontcare_mismatch        | W467                  |

# **Generating Waivers for Structural Rules**

SpyGlass Functional Lint allows you to filter false violations generated by the SpyGlass Lint rules. SpyGlass Functional Lint generates an SGDC file, which when used with the subsequent SpyGlass Lint run waives the false violations filtered by Formal-Lint. This SGDC file is generated at the following location:

```
<run_directory>/spyglass_reports/auto-verify/
structural_rule_waiver.sgdc
```

#### Example

Consider the following example:

```
module top(input clk, rst);
parameter p = 1'b1;
wire [1:0] a;
wire [1:0] b;
reg [1:0] k;
function bit myfunction1;
  input a, b ;
  case ({a,b})
         1'b1 :
                  myfunction1 = a;
         default: myfunction1 = b;
  endcase
endfunction
function void myvoidfunction;
input a, b;
output c;
c = a + myfunction1({a,a}, {b,b}) + p +
myfunction1({a,a}, {b,b});
endfunction
function bit myfunction;
input a, b ;
case ({a,b})
       1'b1 :
                begin
```

```
myfunction = a+b +p;
myvoidfunction({a,a}, {b,b},k[1]);
end
default: myfunction = a+b +p;
endcase
endfunction
wire d = myfunction({a,a}, {b,b});
endmodule
```

For the above example, the *Av\_width\_mismatch\_function* rule reports the following violation messages:



```
For the Av_width_mismatch_function rule, the following structural_rule_waiver.sgdc file is used, which will filter the false violations reported by t he SpyGlass Lint rule:
```

```
waive -rule W263 -msg q%Case label (1'b1) width (1) does not
match selector ({a ,b}) width (2).[Hierarchy: 'all-
hierarchy']%
```

```
waive -rule STARC-2.1.3.1 -msg q%Bit-width mismatch between
function call argument '{a ,a}' ('2' bits) and function input
'a' ('1' bits).[Hierarchy: 'all-hierarchy']%
```

waive -rule STARC02-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC05-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC02-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC05-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

waive -rule STARC02-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']% waive -rule STARC05-2.1.3.1 -msg q%Bit-width mismatch between function call argument '{a ,a}' ('2' bits) and function input 'a' ('1' bits).[Hierarchy: 'all-hierarchy']%

As shown in *Figure 1*, SpyGlass functional lint rule, *Av\_width\_mismatch\_function*, filters three false violations reported by the SpyGlass Lint rules, STARC-2.1.3.1, STARC02-2.1.3.1, and STARC05-2.1.3.1.

## The SpyGlass Functional Lint Rules

The SpyGlass Functional Lint has the following rules:

- Av\_width\_mismatch\_assign
- Av\_width\_mismatch\_case
- Av\_width\_mismatch\_port
- Av\_width\_mismatch\_function
- Av\_signed\_unsigned\_mismatch
- Av\_width\_mismatch\_expr
- Av\_width\_mismatch\_expr02
- Av\_width\_mismatch\_expr03
- Av\_case\_default\_redundant
- Av\_case\_default\_missing
- Av\_dontcare\_mismatch

# Av\_width\_mismatch\_assign

#### LHS width is less than RHS width of assignment (Truncation)

# When to Use

Use this rule to identify assignments in which the LHS width is less than the RHS width.

# Description

The *Av\_width\_mismatch\_assign* rule reports assignments in which the LHS width is less than the (implied) width of the RHS expression.

**NOTE:** The Av\_width\_mismatch\_assign rule supports the TURBO\_GROUP\_MESSAGE noise reduction initiative. For details of this initiative, refer to the SpyGlass Turbo Lint Application Note.

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to y es.
- check\_unsign\_overflow: Default value is no. Set this parameter to yes to not suppress overflow in unsigned expressions when the sign extension is used, as shown in the following example:

```
wire [5:0] a,b;
wire [6:0] c;
wire [8:0] d;
assign c = {a[5],a} + {b[5],b};
```

- strict: Default value is no. In the default behavior, only the assignments in which the RHS expression contains wires or reg are checked. Set this parameter to yes to perform strict checking for all the assignments.
- check\_static\_value: Default value is no. Set this parameter to yes to report violations for static expressions and the non static expressions containing static expressions.

check\_counter\_assignment: Default value is no. Set this parameter to yes to report violations for counter type of assignments, as shown in the following example:

assign w1[3:0] = w1[3:0] + 1;

- **NOTE:** Ensure that the value of the check\_static\_value and check\_counter\_assignment parameters is set to yes.
  - check\_counter\_assignment\_turbo: Default value is no. Set this parameter to yes or comma-separated list of rules to consider an assignment statement as counter type assignment in the following conditions:
    - □ Any constant (including based numbers or parameters) is added to or subtracted from a variable/signal on the RHS of the assignment.
    - □ The variable on RHS matches the variable on the LHS expression, that is, the same variable is used on both sides, LHS and RHS, of assignment with same bit-width.
  - scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
  - disable\_rtl\_deadcode: Default value is no. Set this parameter to yes to not make assertions for the disabled code (evaluated statically) using loops and conditional statements, such as if condition and ternary operator.
  - use\_lrm\_width: Default value is no. Set this parameter to yes to consider the LRM width of integer constants, which is 32 bits.
  - check\_concat\_max\_width: Default value is no. In this case, no violation is reported when the width of the LHS expression is present between the width of the RHS expression without considering zero concatenated bits and the width of the RHS after adding zero concatenated bits.

If you set this parameter to yes, the RHS width is considered as the width after adding zero concatenated bits. That is, the violation is reported if the LHS width does not match the RHS width after adding zero concatenated bits. This parameter is applicable for Verilog only.

handle\_shift\_op: Default value is no. In this case, no violation is reported if the shifted or non-shifted width of a shift expression (at the port connection of a module instance) matches the width of the corresponding module port definition. But the rule does not calculate the shifted width, if the RHS of the shift expression is non-static. Set this parameter to shift\_left, shift\_right, shift\_both, no\_shift, or comma separated list of rule names, to compare shifted or non shifted widths for left and right shift expressions.

av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.
- set\_case\_analysis: Use this constraint to specify case analysis
  conditions.
- ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip block constraint is as follows:

```
ip_block -name <module-name>
```

# **Messages and Suggested Fix**

The following message appears to specify the width mismatch between LHS and RHS expressions:

```
[WARNING] LHS: '<lhs-expr>' width <lhs-width> is less than RHS:
'<rhs-expr>' width <rhs-width> in assignment [Hierarchy:
'<hier-path>']
```

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

### **Potential Issues**

This violation appears when the LHS width is less than the RHS width.

#### **Consequences of Not Fixing**

If you do not fix this violation, SpyGlass truncates some bits in the assignment.

#### How to Debug and Fix

Refer to the *auto\_verify.rpt* report for details on this violation.

To debug this violation, trace the waveform viewer and check the values of the signals present in the RHS of the assignment, which are causing the width of RHS to be more than the width of LHS.

#### Example Code and/or Schematic

Consider the following example:

```
`define S0 2'b00
`define S1 2'b01
`define S2 2'b10
`define S3 2'b11
module top( input clk, rst,
            input [4:0]a1,
            input [4:0]a2,
            input [2:0]a3,
            output reg [3:0] out1,
            output reg [3:0] out2,
            output reg [2:0] out3
            );
    reg [1:0] state1;
    reg [1:0] state2;
    reg [1:0] state3;
    reg [1:0] state4;
    always @(posedge clk or posedge rst) begin
            if(rst) begin
                 state1 <= `S0;</pre>
                 out3 <= 3'b000;
            end
            else begin
```

```
priority case(state1)
                            `S0: state1 <= `S1;</pre>
                            `S1: state1 <= `S2;</pre>
                            `S2: state1 <= `S0;</pre>
                  default: begin
                       state3 <= `S3;</pre>
                  out3 = 3'b11?;
              end
                  endcase
                   if(state1 >= a3 ) begin
                            out3 <= a1[1:0] + a3; //filtered violations
                   if(al > out1)
                       out2 <= a2; //violations not filtered</pre>
                   end
              end
    end
endmodule
```

For the above example, the *Av\_width\_mismatch\_assign* rule reports following violation messages:

| Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | File   | Line |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|
| Message Tree (Total: 9, Displayed: 9, Waived: 0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | 1.0  |
| 🕀 🛱 Design Read (4)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |      |
| 🖻 🗅 test goal (5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        |      |
| D Av initiate01 (1): Reports initial state of the design.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |      |
| Av report01 (1): Reports statistics of properties and functional constraints.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |      |
| Av report01 (1): Reports statistics of properties and functional constraints.     Av width mismatch assign (1): LHS width is less than RHS width of assignment (Truncation)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        |      |
| Carter of the state of the stat | test v | 38   |
| Av_width_mismatch_assign (1): LHS width is less than RHS width of assignment (Truncation)     LHS: 'out2' width 4 is less than RHS: 'a2' width 5 in assignment [Hierarchy: 'top']                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | test.v | 38   |
| Carter of the state of the stat | test v | 38   |

FIGURE 2. Av\_width\_mismatch\_assign Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, Av\_width\_mismatch\_assign, filters one violation reported by the SpyGlass Lint rule, W164a.

# **Default Severity Label**

Warning

# **Rule Group**

**Implicit-Properties** 

# **Reports and Related Files**

No report or related file

# Av\_width\_mismatch\_case

A case expression width does not match case select expression width

# When to Use

Use this rule to identify assignments in which a case expression width does not match with the select expression width.

### Description

The *Av\_width\_mismatch\_case* rule reports a violation when the case expression width does not match the select expression width.

**NOTE:** The Av\_width\_mismatch\_case rule supports the TURBO\_CONSOLIDATE\_DESIGN\_SCOPE and TURBO\_REMOVE\_DUP\_MSG noise reduction initiatives. For details of these initiatives, refer to the SpyGlass Turbo Lint Application Note.

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to yes.
- scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
- use\_lrm\_width: Default value is no. Set this parameter to yes to consider the LRM width of integer constants, which is 32 bits.
- av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.
- set\_case\_analysis: Use this constraint to specify case analysis conditions.

ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip\_block constraint is as follows:

```
ip_block -name <module-name>
```

# **Messages and Suggested Fix**

The following message appears to specify the mismatch between the width of a case expression and a select expression:

[WARNING] Case label (<case-label>) width (<case-width>) does not match selector (<select-label>) width (<select-width>). [Hierarchy: '<hier-path>].

This violation can be formally failed, partially-proved, or not analyzed by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

### Potential Issues.

This violation appears when the case expression width does not match the select expression width.

### **Consequences of Not Fixing**

If you do not fix this violation, it may lead to unwanted target in case expressions during selection.

#### How to Debug and Fix

To debug this violation, trace the waveform viewer and check the values of the signals present in the case label or case select expression (whose width is more than the other).

To fix this violation, perform the following steps:

1. Double-click on the violation message.

This step highlights the line of case label in the HDL Viewer pane.

- 2. Scroll up in the *HDL Viewer* pane to view the case selector and the width mismatch.
- 3. Modify the case expression to match with the select expression in all bits.

This makes the behavior of the RTL code easier to understand and does not rely on undefined behavior in handling unmatched bits.

# **Example Code and/or Schematic**

Consider the following example:

```
module top(input actclk);
   wire clk;
   wire dl; reg q; reg [2:0]e;
   always @ (actclk or clk or dl)
      case (actclk)
      2'b00 : e <= d1;
   2'b01 : e <= d1 + 1;
      2'b11 : e <= d1 + 2;
   endcase</pre>
```

endmodule

```
module supertop(wire actclk, d, input [2:0]in_1, in_2, output
reg q);
     top inst1(actclk);
endmodule
```

For the above example, the *Av\_width\_mismatch\_case* rule reports the following violation messages:

| Message                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | File       | Line        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|
| 🖻 🗀 Message Tree ( Total: 8, Displayed: 8, Waived: 0 )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | - Contract |             |
| Design Read (3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            |             |
| e 🗅 test goal (5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |             |
| Av_report01 (1) : Reports statistics of properties and functional constraints.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |            |             |
| Av width mismatch case (1) : A case expression width does not match case select expression width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            | 1411        |
| Case label (2'b11) width (2) does not match selector (actclk) width (1) [Hierarchy: 'superior inst.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1 test v   | 9           |
| Case label (2'b11) width (2) does not match selector (actclk) width (1).[Hierarchy: 'supertop.inst1     W263 (3): A case expression width does not match case select expression width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ] test.v   | 9           |
| 🖻 🖬 W263 (3) : A case expression width does not match case select expression width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            | 9           |
| W263 (3) : A case expression width does not match case select expression width Case label (2'b00) width (2) does not match selector (actclk) width (1).[Hierarchy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | test.v     | 9           |
| W263 (3) - A case expression width does not match case select expression width Case label (2'b00) width (2) does not match selector (actclk) width (1).[Hierarchy: 'supertop:inst1@top']                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | test.v     | 7           |
| W263 (3) - A case expression width does not match case select expression width     &      Case label (2'b00) width (2) does not match selector (actclk) width (1).[Hierarchy:         '.supertop:inst1@top']     &      Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         '.supertop:inst2@top']     &      Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         '.supertop:inst2@top']     &          Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         '.supertop:inst2@top']     &          Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (1).[Hierarchy:         Case label (2'b01) width (2) does not match selector (actclk) width (2) does not match se |            | 9<br>7<br>8 |
| W263 (3) - A case expression width does not match case select expression width Case label (2'b00) width (2) does not match selector (actclk) width (1).[Hierarchy: 'supertop:inst1@top']                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | test.v     | 7           |

FIGURE 3. Av\_width\_mismatch\_case Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_width\_mismatch\_case*, filters one violation reported by the SpyGlass Lint rule, *W253*.

# **Default Severity Label**

Warning

# **Rule Group**

**Implicit-Properties** 

# **Reports and Related Files**

No report or related file

# Av\_width\_mismatch\_port

An instance port connection has different width compared to the port definition

# When to Use

Use this rule to identify the width mismatch between the bus width and instance port width while connecting a bus to an instance port.

# Description

The *Av\_width\_mismatch\_port* rule reports a violation if you try connecting a bus to an instance port but there is a mismatch between the bus width and the instance port width.

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to yes.
- report\_blackbox\_inst: Default value is no. Set this parameter to yes to report violations for port width mismatch for black box instances.
- scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
- use\_lrm\_width: Default value is no. Set this parameter to yes to consider the LRM width of integer constants, which is 32 bits.
- handle\_shift\_op: Default value is no. In this case, no violation is reported if the shifted or non-shifted width of a shift expression (at the port connection of a module instance) matches the width of the corresponding module port definition. But the rule does not calculate the shifted width, if the RHS of the shift expression is non-static. Set this parameter to shift\_left, shift\_right, shift\_both, no\_shift, or comma separated list of rule names, to compare shifted or non shifted widths for left and right shift expressions.
- report\_blackbox\_inst: Default value is no. Set this parameter to yes to report violations for port width mismatch for black box instances.

av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.
- set\_case\_analysis: Use this constraint to specify case analysis
  conditions.
- ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip block constraint is as follows:

ip\_block -name <module-name>

# **Messages and Suggested Fix**

The following message appears if there is a mismatch between the bus width and instance port width:

[WARNING] Incompatible width for port '<port-name>'(width <port-width> in module '<module-name>') on instance '<instance-name>' (terminal width <instance-term-width>) [Hierarchy: '<hier-path>'].

This violation can be formally failed, partially-proved, or not analyzed by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

### Potential Issues.

This violation appears when there is a width mismatch between the bus width and instance port width during connection of a bus to an instance port.

### Consequences of Not Fixing

The excess bits on the bus are ignored if the bus is too wide to be connected to an input or the bus is too small to be connected to an output

#### How to Debug and Fix

To debug this violation, trace the waveform viewer to check the values of the signals present in the port connection.

To fix this violation, perform the following steps:

1. Double-click on the violation message.

The *HDL Viewer* window highlights the module instance where a port connection has more width as compared to the port definition.

2. Specify correct number of bits across the hierarchy boundary, and then explicitly ignore the bits that are not required.

# **Example Code and/or Schematic**

Consider the following message:

```
module top(input clk);
    wire [3:0] sel;
    wire signed [4:0] = -8;
    wire unsigned [4:0]a1;
   wire [4:0] b;
    wire [5:0] c;
   parameter p1 = 1;
    parameter p2 = 1;
    parameter p = 1;
    slave inst(.a(a) , .aa(a1[p1:0]) , .b(b[p2:0]) ,
   .c(c[p:0]));
endmodule
module slave (input [3:0]a , input [3:0]aa , input [3:0]b ,
input [3:0]c);
endmodule
module supertop(input clk);
    top #(3,4,3) inst1(clk);
    top #(4,3,3) inst2(clk);
endmodule
```

For the above example, the *Av\_width\_mismatch\_port* rule reports four violations, *Violation 1*, *Violation 2*, and *Two Violations Not Analyzed By the Formal Engine*.

However, no *Av\_width\_mismatch\_port* rule violation is reported for the port connection c[3:0] through the supertop.inst1 or supertop.inst2 hierarchy.

### Violation 1

Incompatible width for port 'aa' (width 4 in module 'slave') on instance 'inst' (terminal width 5) [Hierarchy: 'supertop.inst2'].

In this case, the values of the signal present in the port connection may attain 10 (hex value) corresponding to the a1[4:0] signal for the supertop.inst2 hierarchy whose width is more than the width of the aa port.

The following figure shows the waveform viewer of this violation:

| Signals                  | Waves                                        |
|--------------------------|----------------------------------------------|
| Time                     | ) 1 ns 2 ns 3 ns 4 ns 5 ns 6 ns 7 ns<br>Lure |
| G1                       |                                              |
| verification_cycle[15:0] | 0000                                         |
| Data Pin al              |                                              |
| a1[4:0]                  | 10000                                        |
|                          |                                              |
|                          |                                              |

**FIGURE 4**. Waveform Viewer of the Av\_width\_mismatch\_port Rule Violation - Example 1

### Violation 2

Incompatible width for port 'b'(width 4 in module 'slave') on instance 'inst'(terminal width 5) [Hierarchy: 'supertop.inst1'].

In this case, the values of the signals present in the port connection can be

16 corresponding to the b[4:0] signal for the supertop.inst1 hierarchy whose width is more than the width of the b port in the slave module.

The following figure shows the waveform viewer of this violation:

| Signals                             | Waves                                                |  |  |
|-------------------------------------|------------------------------------------------------|--|--|
| Time                                | ) 1 ns 2 ns 3 ns 4 ns 5 ns 6 ns 7 ns 8<br>Iune       |  |  |
| G1                                  | يستن ويبدين ويبدوا ويستو المستو المتحي المعيين وتصري |  |  |
| <pre>verification_cycle[15:0]</pre> | 0000                                                 |  |  |
| Data Pin b                          |                                                      |  |  |
| b[4:0]                              | 10000                                                |  |  |
|                                     |                                                      |  |  |

**FIGURE 5.** Waveform Viewer of the Av\_width\_mismatch\_port Rule Violation - Example 2

### Two Violations Not Analyzed By the Formal Engine

The following two violations are *not analyzed* by the formal engine:

Incompatible width for port 'a'(width 4 in module 'slave') on instance 'inst'(terminal width 5) [Hierarchy: ':supertop:inst1@top']

Incompatible width for port 'a'(width 4 in module 'slave') on instance 'inst'(terminal width 5) [Hierarchy: ':supertop:inst2@top']

The above violations appear because the width mismatch between the signed and unsigned expressions is not passed to the formal engine. Therefore, they are *not analyzed* by the formal engine.

### **Default Severity Label**

Warning

# **Rule Group**

**Implicit-Properties** 

# **Reports and Related Files**

No report or related file

# Av\_width\_mismatch\_function

# Bit-width of function call arguments must match bit-width of the corresponding function definition arguments

### When to Use

Use this rule to detect bit-width mismatches between the function input and the corresponding function call argument.

# Description

The *Av\_width\_mismatch\_function* rule reports bit-width mismatch between the function input and the corresponding function call argument.

**NOTE:** The Av\_width\_mismatch\_function rule supports the TURBO\_GROUP\_MESSAGE TURBO and TURBO\_IGNORE\_PADDING noise reduction initiatives. For details of these initiatives, refer to the SpyGlass Turbo Lint Application Note.

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to yes.
- scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
- check\_pad\_concat: The default value is no so that this rule ignores leading zeros in concat/multi-concat operator while width calculation. Set the value of the parameter to yes or <rule-name> to consider leading zeros in concatenation/multi-concatenation operator while width calculation.
- av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.

- set\_case\_analysis: Use this constraint to specify case analysis
  conditions.
- ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip\_block constraint is as follows:

ip\_block -name <module-name>

# **Messages and Suggested Fix**

The following message appears if there is a bit-width mismatch between the function input and the corresponding function call argument:

[WARNING] Bit-width mismatch between function call argument '<func-call-arg>' ('<func-bits>' bits) and function input '<func-input>' ('<input-bits>' bits). [Hierarchy: '<hier>']

This violation can be formally failed, partially-proved, or not analyzed by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

This violation appears if the bit-width of the function call arguments do not match with the bit-width of the corresponding function definition arguments.

#### Consequences of Not Fixing

If the function input is narrower than the function call argument, the value of the function call argument is left truncated and the function is evaluated on the truncated value.

#### How to Debug and Fix

Modify the code such that the bit-width of the function call arguments match with the bit-width of the corresponding function definition arguments.

The SpyGlass Functional Lint Rules

# **Example Code and/or Schematic**

```
Consider the following example:
module top(input clk, rst);
parameter p = 1'b1;
wire [1:0] a;
wire [1:0] b;
req [1:0] k;
function bit myfunction1;
  input a, b ;
  case ({a,b})
         1'b1 : myfunction1 = a;
         default: myfunction1 = b;
  endcase
endfunction
function void myvoidfunction;
input a, b ;
output c;
c = a + myfunction1({a,a}, {b,b}) + p +
myfunction1({a,a}, {b,b});
endfunction
function bit myfunction;
input a, b ;
case ({a,b})
       1'b1 :
                begin
                  myfunction = a+b +p;
                   myvoidfunction({a,a}, {b,b},k[1]);
                end
       default: myfunction = a+b +p;
endcase
endfunction
wire d = myfunction(\{a,a\},\{b,b\});
endmodule
```

For the above example, the Av\_width\_mismatch\_function rule reports the



#### following violation messages:

#### FIGURE 6. Av\_width\_mismatch\_function Messages

As shown in the above figure, SpyGlass functional lint rule, *Av\_width\_mismatch\_function*, filters three false violations reported by the SpyGlass Lint rule, STARC-2.1.3.1.

### **Default Severity Label**

Warning

# **Rule Group**

**Implicit-Properties** 

### **Reports and Related Files**

No report or related file

# Av\_signed\_unsigned\_mismatch

### Mixed signed and unsigned types

# When to Use

Use this rule to detect the cases in which signed and unsigned types are mixed.

# Description

The *Av\_signed\_unsigned\_mismatch* rule reports a violation if signals of the signed and unsigned types are mixed to form a single expression or there is a sign conversion in an assignment or a comparison statement.

**NOTE:** The Av\_signed\_unsigned\_mismatch rule supports the TURBO\_IGNORE\_STATIC\_CONSTSANTS, TURBO\_GROUP\_MESSAGE, and TURBO\_SET\_RECOMMENDED\_PARAMETER noise reduction initiatives. For details of these initiatives, refer to the SpyGlass Turbo Lint Application Note.

The rule details are covered under the following topics:

- Cases when the Type Conversions are Checked by this Rule
- Rule Assumptions to Avoid Spurious Violations
- Operators Ignored from Rule Checking
- Considering Integer Constants as Signed
- Ignoring Violations for the for-loop and while-loop Indexes

### Cases when the Type Conversions are Checked by this Rule

This rule checks for the type conversions, such as signed to unsigned or unsigned to signed, in the following cases:

- Sign conversion in an assignment (only if strict is set)
- Sign conversion during comparison in constructs, such as case and if.
- Sign conversion during binary operations in an expression/sub-expression

### **Rule Assumptions to Avoid Spurious Violations**

This rule considers an unsized integer constant, such as 4 as both signed and unsigned.

# **Operators Ignored from Rule Checking**

This rule does not report for the following operators:

- Right shift operators both logical and arithmetic i.e. ">>" & ">>>"
- Left shift operators both logical and arithmetic i.e. "<<" & "<<<"
- Power operator "\*\*"

### **Considering Integer Constants as Signed**

Set the dccompat parameter to yes to consider unsized integer constants as signed.

### Ignoring Violations for the for-loop and while-loop Indexes

Set the ignoreforindex parameter to yes to ignore violations for the for-loop and while-loop indexes.

When a bit select or a part select is used as a loop index, violations for the entire array are ignored. The following code snippet shows such array:

```
integer j[3];
for(j[0] = 1; j[0] < 3; j[0]++)
j[1] = j[1] + 3'b111;
```

In the above example, no Av\_signed\_unsigned\_mismatch violation appears for all the array bits in j, because j is marked as for/while loop index.

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to yes.
- scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
- dccompat: Default value is no. Set this parameter to yes to follow Design Compiler (DC) conventions for rule checking.

- ignoreforindex: Default value is no. Set this parameter to yes to ignore violations for the for-loop and while-loop indexes. For details, see Ignoring Violations for the for-loop and while-loop Indexes.
- strict: Default value is no. Set this parameter to yes to check all the assignments in addition to wire and reg in RHS.
- av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.
- set\_case\_analysis: Use this constraint to specify case analysis
  conditions.
- ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip block constraint is as follows:

```
ip_block -name <module-name>
```

# **Messages and Suggested Fix**

This rule reports the following message:

[WARNING] Unsigned expression '<expr1>' used with signed expression '<expr2>'<stmt>

Where, *<stmt>* can be in assignment or in comparison depending upon whether the type (signed or unsigned) conversion has occurred in an assignment statement or in a comparison statement.

This violation can be formally failed, partially-proved, or not analyzed by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

This violation appears when an unsigned expression is used with a signed expression.

#### How to Debug and Fix

Either use signed or unsigned types in an expression. Do not mix the signals of the signed and unsigned types to form a single expression.

### **Example Code and/or Schematic**

Consider the following example:

```
module top( input clk, rst,
            input al,
            output reg bl
            );
    //Av_signed_unsigned_mismatch
    test sub test sub instance(a1,b1);
endmodule
module test_sub(d, q);
  input d;
  output q;
  req q;
  reg r, clk;
  integer i, j;
  wire wireVar;
  wire a = i + wireVar + j;
  always @(posedge clk)
  begin
    if(r)
      q = d < j;
  end
endmodule
```

For the above example, the *Av\_signed\_unsigned\_mismatch* rule reports the following violation messages:



**FIGURE 7.** Av\_signed\_unsigned\_mismatch Messages

As shown in the above figure, SpyGlass functional lint rule, *Av\_signed\_unsigned\_mismatch*, filters one false violation reported by the SpyGlass Lint rule, SignedUnsignedExpr-ML.

# **Default Severity Label**

Warning

# **Rule Group**

**Implicit-Properties** 

# **Reports and Related Files**

No report or related file

# Av\_width\_mismatch\_expr

### Bit-width of operands of a logical operator do not match

# When to Use

Use this rule to detect bit-width mismatch between the operands of logical operators.

# Description

The *Av\_width\_mismatch\_expr* rule reports bit-width mismatches between the operand expressions of logical operations.

# Width Calculation Approach

Set the nocheckoverflow parameter to yes to calculate width according to LRM.

rhswidth

| me matri ca | iodiation approach is as relieve | 51                          |
|-------------|----------------------------------|-----------------------------|
| Operator    | LRM Width                        | Normal Width                |
| +,-         | Max (Ihswidth,rhswidth)          | Max (Ihswidth,rhswidth) + 1 |
| *           | Max (lhswidth,rhswidth)          | lhswidth+rhswidth           |
| /           | Max (Ihswidth,rhswidth)          | lhswidth                    |

# The width-calculation approach is as follows:

#### <u>Example:</u>

%

In the following expression, this rule reports a violation when the nocheckoverflow parameter is set to no:

Max (lhswidth,rhswidth)

(in1[3:2] + in1[1]) && in2[3:2]

To suppress violation for the above example, set the nocheckoverflow parameter to yes.

# **Rule Exceptions**

If an integer constant is used in one of the operands, this rule does not report a violation if the width of that constant is less than or equal to the width of the other operand. This rule does not report violations for the expressions where the width of the constant expression, constant integer, or base number is less than the width of the other operand.

#### Example:

```
assign out = base [4:0] && (1023>>6) ; //No Violation
assign out1 = base1 [4:0] || 10 ; //No Violation
assign out2 = base2 [4:0] || 1023; //Violation
```

# Parameter(s)

- nocheckoverflow: Default value is no. Set this parameter to yes to calculate the width of expressions as per LRM. Other possible value is the list of rules for which you want to set this parameter to yes.
- scope: Default value is block. Set this parameter to chip to consider the complete fan-in cone of an assertion.
- disable\_rtl\_deadcode: Default value is no. Set this parameter to yes to not make assertions for the disabled code (evaluated statically) using loops and conditional statements, such as if condition and ternary operator.
- use\_lrm\_width: Default value is no. Set this parameter to yes to consider the LRM width of integer constants, which is 32 bits.
- av\_seqdepth: Specifies a sequential depth so that the input cone of properties can be abstracted by cutting the logic behind the specified depth in that cone (as specified by av\_seqdepth) or till the module boundary (that is, scope=block), whichever is reached earlier.

# Constraint(s)

- clock: Use this constraint to specify clock signals in a design.
- reset: Use this constraint to specify reset signals in a design.
- set\_case\_analysis: Use this constraint to specify case analysis conditions.
- ip\_block: Use this constraint to specify module names so that no formal checking is done for the constructs inside those modules.

The syntax of using the ip\_block constraint is as follows:

ip\_block -name <module-name>

# **Messages and Suggested Fix**

This rule reports the following message:

[ERROR] Operand bit-width mismatch for operator '<op-name>': '<op1-exp>'('<op1-width>' bits) and '<op2-exp>'('<op2-width>' bits). [Hierarchy: <hier-path>]

This violation can be formally failed, partially-proved, or not analyzed by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

### **Potential Issues**

This violation appears if there are bit-width mismatches between the operand expressions of logical operations.

#### Consequences of Not Fixing

Bit-width mismatch between operands of a logical operation may lead to incorrect results.

### How to Debug and Fix

Review the code and correct the reported mismatch.

# **Example Code and/or Schematic**

Consider the following example:

```
module top();
wire [2:0]c;
wire [2:0]d;
wire [3:0]e;
function bit myfunction1;
input [2:0]a; input [3:0] b;
case ({a,b})
1'b1: myfunction1 = a || b;
```

```
default: myfunction1 = b || {a,a};
endcase
endfunction
assign c = { myfunction1(d,e) , myfunction1(d,e) ,
myfunction1(d,e)};
endmodule
```

For the above example, the *Av\_width\_mismatch\_expr* rule reports the following violation messages:

| Message                                                                                                                                                                                  | File             | Line       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------|
| 🖯 🗀 Message Tree ( Total: 9, Displayed: 9, Waived: 0 )                                                                                                                                   |                  | a contract |
| Design Read (5)                                                                                                                                                                          |                  |            |
| 🖻 🗅 test, goal (4)                                                                                                                                                                       |                  |            |
| D Av report01 (1): Reports statistics of properties and functional constraints.                                                                                                          |                  |            |
| C Av width mismatch expr (1) : Bit-width of operands of a logical operator must match.                                                                                                   |                  |            |
|                                                                                                                                                                                          |                  |            |
|                                                                                                                                                                                          | testv            | 10         |
| ▲ Operand bit-width mismatch for operator "  ": "b" (4" bits) and "(a, a)" (5" bits). [Hierarchy: "top"]<br>□ STARC-210.32a (2): Bit-width of operands of a logical operator must match. | test.v           | 10         |
| ▲ Operand bit-width mismatch for operator '  ': 'b' ('4' bits) and '(a, a)' ('6' bits). [Hierarchy: 'top']                                                                               | test.v<br>test.v | 10<br>9    |

FIGURE 8. Av\_width\_mismatch\_expr Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_width\_mismatch\_expr*, filters one false violation reported by the SpyGlass Lint rule, STARC-2.10.3.2a.

# **Default Severity Label**

Error

# **Rule Group**

**Implicit-Properties** 

# **Reports and Related Files**

No report or related file

# Av\_width\_mismatch\_expr02

Identifies the unequal length operands in the bit-wise logical, arithmetic, and ternary operators

# When to Use

Use this rule to identify bit-width mismatch between operands of the bitwise logical, arithmetic, and ternary operators.

# Description

The *Av\_width\_mismatch\_expr02* rule flags bit-width mismatch between operands of bit-wise logical, arithmetic, or ternary operators.

Following is the list of operators covered under the *Av\_width\_mismatch\_expr02* rule:

| Arithmetic Operators   |                       |  |
|------------------------|-----------------------|--|
| Subtraction (-)        | Addition (+)          |  |
| Multiplication (*)     | Division (/)          |  |
| Modulus (%)            |                       |  |
| Bit-wise Operators     |                       |  |
| bit-wise xor (^)       | bit-wise negation (~) |  |
| bit-wise and (&)       | bit-wis e or ( )      |  |
| Ternary Operator (? :) |                       |  |

**NOTE:** If the count of operators is more than 500 in an expression, then the expression is ignored for rule checking.

#### Width Calculation

If you set the value of the nocheckoverflow parameter to yes or *Av\_width\_mismatch\_expr02*, the *Av\_width\_mismatch\_expr02* rule checks the bit-width as per the LRM, as shown in the following table:

| Operator | LRM width                  | Normal width               |
|----------|----------------------------|----------------------------|
| +, -     | Max (LHS width, RHS width) | Max (LHS width, RHS width) |
| *        | Max (LHS width, RHS width) | LHS width + RHS width      |

| Operator | LRM width                  | Normal width |
|----------|----------------------------|--------------|
| /        | Max (LHS width, RHS width) | LHS width    |
| %        | Max (LHS width, RHS width) | RHS width    |

For constants, the natural width is considered.

- **NOTE:** The Av\_width\_mismatch\_expr02 rule does not check for expressions in signal or variable indexes, such as bit-select expression.
- **NOTE:** This rule does not report a violation for integer variable expressions.

### **Rule Exceptions**

The *Av\_width\_mismatch\_expr02* rule does not report violations for expressions where the width of a constant expression, a constant integer, or a base number is less than the width of the other operand.

#### Language

Verilog

### **Default Weight**

10

# Parameter(s)

- check\_static\_value: Default value is no. Set the value of the parameter to yes or <rule\_list> to report violation for cases with width mismatch, involving static expressions and non-static expressions having a static part. Other possible values are only\_const and only\_expr. For an expression having one operand constant and other non constant, a violation is reported only when the width of the constant operand is greater.
- disable\_rtl\_deadcode: The default value is no. Set the value of the parameter to yes to disable violations for disabled code in loops and conditional (if condition, ternary operator) statements.
- reportconstassign: The default value is no. Set the value of the parameter to yes to enable the *Av\_width\_mismatch\_expr02* rule to check for constants whose width is less than the operand.
- strict: Default value is no. Therefore, the rule behavior is as follows:

□ Ignores addition (+) and multiplication (\*) operations

Reports violation on subtraction (-), division (/), or modulus (%) operations only if the width of the right operand is greater than the width of the left operand.

Set this parameter to yes to check for the addition and multiplication operations and to report subtraction, division, or modulus operations when there is a width mismatch between operands (both A > B and B > A for operations A-B, A/B, and A%B). You can also set this parameter to check for ternary operators

- use\_lrm\_width: Default value is no. Set this parameter to yes to consider the LRM width of integer constants, which is 32 bits. The rule does not check the bit-width as per LRM by default.
- nocheckoverflow: Default value is no. Set the value of the parameter to yes or rule name to calculate the width as per the LRM. See *Width Calculation* to know more about calculating width.
- use\_carry\_bit: Default value is no and the width is taken as maximum of the two operands for a binary expression having plus and minus operators. Set this parameter to yes or <rule-name> to get width after considering the carry bit of addition. No violation is reported, even using this parameter, for sub-expressions of a binary expression if all terms have the same width and all operators are either plus or minus. Also, refer to *Examples Code and/or Schematic*.

# Constraint(s)

None

# **Messages and Suggested Fix**

The following message appears at the location of an operation of operator <*opr-name>* where there is a bit-width mismatch between left expression <*exprl>* of bit-width <*bit-widthl>* and right expression <*exprr>* of bit-width <*bit-widthr>*:

**[WARNING]** For operator (<opr-name>), left expression: "<exprl>" width <bit-widthl> should match right expression: "<exprr>" width <bit-widthr>. [Hierarchy: '<hier-path>']

Where, *<hier-path>* is the complete hierarchical path of the containing scope.

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

A violation is reported when there is a bit-width mismatch between the left expression of bit-width and right-expression of bit-width.

#### **Consequences of Not Fixing**

While working with expressions of different bit-widths may be the intended behavior, it is also a potentially error-prone design practice. For example, the addition of two words of unequal widths may indicate that you forgot to update the width of one of the buses.

#### How to Debug and Fix

Double-click the violation message. The HDL window highlights the line, where, width mismatch in operators is detected.

To resolve the violation, check each case for potential messages, especially in the bit-wise operators. Review the RTL code mentioned in message, this code may cause some unintended behavior. Make all arguments in such comparisons of equal width such as by explicitly extending narrower operators in a concatenation, to see cases where upper bits are zeroed.

### **Examples Code and/or Schematic**

Consider the following example:

| `define SO | 0 2'b00  |           |
|------------|----------|-----------|
| `define S1 | l 2'b01  |           |
| `define S2 | 2 2'b10  |           |
| `define S3 | 3 2'bll  |           |
|            |          |           |
| module top | p( input | clk, rst, |
|            | input    | [4:0]a1,  |
|            | input    | [4:0]a2,  |
|            | input    | [2:0]dib, |

```
output reg [2:0] out1,
         output reg [2:0] out2,
         output reg [2:0] out3
         );
reg [1:0] state1;
reg [1:0] state2;
reg [1:0] state3;
reg [1:0] state4;
always @(posedge clk or posedge rst) begin
         if(rst) begin
             state1 <= `S0;</pre>
             out1 <= 3'b000;
         end
         else begin
             priority case(state1)
                      `S0: state1 <= `S1;</pre>
                      `S1: state1 <= `S2;</pre>
                      S2: state1 <= S0;
             endcase
             if(state1 >= dib ) begin
                      out1 <= a1[1:0] + dib;
             end
         end
end
always @(posedge clk or posedge rst) begin
         if(rst) begin
             state2 <= `S0;</pre>
         end
         else if (a2[2]) begin
             case (state2)
                      `S0: state2 <= `S1;</pre>
                      `S1: state2 <= `S2;</pre>
                      `S2: state2 <= `S3;</pre>
             endcase
         end else if (state2 >= a2[2:0] )begin
```

out2 <= a1[1:0] - dib;

end

end endmodule

Now, consider the value of the strict parameter is set to yes.

The *Av\_width\_mismatch\_expr02* rule generates the following violation messages:





In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_width\_mismatch\_expr02*, filters one false violation reported by the SpyGlass Lint rule, W116.

# **Default Severity Label**

Warning

# **Rule Group**

Implicit-properties

# **Reports and Related Files**

No related reports or files.

# Av\_width\_mismatch\_expr03

#### Reports an arithmetic comparison operator with unequal length

#### When to Use

Use this rule to identify arithmetic comparison operator with unequal length.

#### Description

The *Av\_width\_mismatch\_expr03* rule reports arithmetic comparison operations with operands of unequal widths. Following is the list of operators covered under this rule:

| <b>Relational Operators</b> |                                 |
|-----------------------------|---------------------------------|
| Greater than (>)            | Greater than or equal to (>=)   |
| Less than (<)               | Less than or equal to (<=)      |
| Equality Operators          |                                 |
| logical Equality(==)        | logical inequality(!=)          |
| case equality(===)          | <pre>case inequality(!==)</pre> |

**NOTE:** If the count of operators is more than 500 in an expression, then the expression is ignored for rule checking.

If the nocheckoverflow parameter is set to yes or *Av\_width\_mismatch\_expr03*, the width of the expression is calculated as per the LRM. However, for constants, normal width is considered.

| +, - | Max (Ihswidth, rhswidth) | Max (Ihswidth, rhswidth) + 1 |
|------|--------------------------|------------------------------|
| *    | Max (, rhswidth)         | lhswidth + rhswidth          |
| /    | Max (Ihswidth, rhswidth) | lhswidth                     |
| %    | Max (Ihswidth, rhswidth) | rhswidth                     |

#### Handling of Unary Negation:

In case of unary negation, the width is calculated as follows:

- Variable and based numbers: If an operand is a variable or a based number, the width is incremented by one. For example, width of -a [3:0] is 5, and width of -3 'b101 is 4, etc. This is applicable only when the nocheckoverflow parameter is set to no.
- Constant and unsized based number: In case of constants, the natural width is calculated first and is then incremented by one. For example, width of -9 is 5. An unsized based number is treated similarly. For example, width of 'b101 is 4. However, if you set the use\_lrm\_width parameter to yes, the width is considered as 32 bit.

#### **Rule Exceptions**

The *Av\_width\_mismatch\_expr03* rule does not report violation for the following cases:

- counter cases, for example, data = = data+1.
- If any one operand is of integer data type. See *Example Code and/or Schematic* for details.

#### Language

Verilog

#### **Parameters**

- check\_sign\_extend: Default value is no. Set the value of the parameter to yes to check for width mismatch due to sign extension in signed comparisons.
- disable\_rtl\_deadcode: The default value is no. Set the value of the parameter to yes to disable violations for disabled code in loops and conditional (if condition, ternary operator) statements.
- use\_lrm\_width: Default value is no. This indicates the Av\_width\_mismatch\_expr03 rule considers the natural width of integer constants. Set this parameter to yes to consider the LRM width, which is 32 bits.
- nocheckoverflow: Default value is no. This indicates the Av\_width\_mismatch\_expr03 rule does not check the bit-width as per LRM. Set this parameter to yes or rule name to check the bit-width as per LRM.

check\_static\_value and strict: By default, the Av\_width\_mismatch\_expr03 rule does not report violation when the right or left expression is a constant, including parameter, sized or unsized based number, and unsized integer. Setting the check\_static\_value parameter to yes changes this behavior, and setting the strict parameter in addition further alters the behavior. The following table summarizes these variations in behavior:

| Type of left or                | check_static_value | check_static_v                                      | alue set to yes                                     |
|--------------------------------|--------------------|-----------------------------------------------------|-----------------------------------------------------|
| right<br>expression            | set to no          | <i>strict</i> set to no                             | <i>strict</i> set to<br>yes                         |
| Parameter                      | Does not report    | Reports if the<br>width of<br>constant is<br>larger | Reports any width mismatch                          |
| Sized based<br>number (8'h15)  | Does not report    | Reports if the<br>width of<br>constant is<br>larger | Reports any width mismatch                          |
| Unsized based<br>number ('h15) | Does not report    | Reports if the<br>width of<br>constant is<br>larger | Reports if the<br>width of<br>constant is<br>larger |
| Unsized integer<br>(18)        | Does not report    | Does not report                                     | Reports if the<br>width of<br>constant is<br>larger |

See *Example Code and/or Schematic* for details. Also, when set to yes, the check\_static\_value parameter checks for width mismatch involving static expressions and non-static expressions that contain a static part. Refer to the check\_static\_value section for more details.

**NOTE:** When the strict parameter is set, the Av\_width\_mismatch\_expr03 rule does not report violation for width mismatch in the for loop condition.

# Constraints

None

# **Messages and Suggested Fix**

The following message appears at the location where a width <widthl> of a left expression <exprl> does not match a width <widthr> of a right expression <exprr> in an operation of an arithmetic operator <op-name>.

**[WARNING]** For operator (<op-name>), left expression: "<exprl>" width <widthl> should match right expression: "<exprr>" width <widthr> [Hierarchy: '<hier-path>']

Where, *<hier-path>* is the complete hierarchical path.

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

A violation is reported when an arithmetic operation has operands of unequal length.

#### Consequences of Not Fixing

For some range of values of the wider operand in arithmetic comparison operations, the comparison operation evaluates to a constant, independent of the value of the narrower operand. This may result in an unexpected behavior.

#### How to Debug and Fix

Double-click the violation message. The HDL Viewer window highlights the line where the width mismatch is found for comparison operator.

This is not a major issue. However, you can avoid possible problems by explicitly comparing sub-expressions of equal width. This also enhances the code readability.

### **Example Code and/or Schematic**

Consider the following example:

```
`define S0 2'b00
`define S1 2'b01
`define S2 2'b10
`define S3 2'b11
module top( input clk, rst,
     input [4:0]a1,
     input [4:0]a2,
     input [2:0]dib,
     output reg [2:0] out1,
     output reg [2:0] out2,
     output reg [2:0] out3
        );
      req [1:0] state1;
     reg [1:0] state2;
     reg [1:0] state3;
     reg [1:0] state4;
   always @(posedge clk or posedge rst) begin
       if(rst) begin
             state1 <= `S0;</pre>
               out1 <= 3'b000;
             end
             else begin
                 priority case(state1)
                          `S0: state1 <= `S1;</pre>
                          `S1: state1 <= `S2;</pre>
                          `S2: state1 <= `S0;</pre>
                 endcase
                 if(state1 >= dib ) begin
                          out1 <= a1[1:0] + dib;
                 end
             end
    end
    always @(posedge clk or posedge rst) begin
             if(rst) begin
                 state2 <= `S0;</pre>
             end
             else if (a2[2]) begin
                 case (state2)
```

`S0: state2 <= `S1; `S1: state2 <= `S2; `S2: state2 <= `S3; endcase end else if (state2 >= a2[2:0] )begin out2 <= a1[1:0] - dib; end

endendmodule

For the above example, the *Av\_width\_mismatch\_expr03* rule reports the following violation messages:



FIGURE 10. Av\_width\_mismatch\_expr03 Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_width\_mismatch\_expr03*, filters one false violation reported by the SpyGlass Lint rule, W362.

### **Default Severity Label**

Warning

### **Rule Group**

Implicit-properties

# **Reports and Related Files**

None

# Av\_case\_default\_redundant

Ensure that a case statement marked full\_case or a priority/unique case statement does not have a default clause.

#### When to Use

Use this rule to identify the case statements that are marked either full\_case or priority/unique\_case and have a default clause.

#### Description

The *Av\_case\_default\_redundant* rule reports violation for the following constructs with a default clause:

- case constructs with full\_case pragma
- priority/unique case constructs

The *Av\_case\_default\_redundant* rule checks for priority cases inside always blocks, initial blocks, tasks and functions in all scopes like generate block, packages, global scope, and interfaces.

The rule reports violation when a priority modifier is used with case, casex, or casez statements with default clause as one of its case selection item.

#### Language

Verilog

#### **Default Weight**

5

#### Parameter(s)

check\_case\_type: Default value is all. Therefore, the *Av\_case\_default\_redundant* rule checks for priority, unique, and full\_case cases. Set the value of the parameter to either priority or unique or full\_case to check for priority, unique and full\_case cases, respectively. You can also specify multiple values for the parameter so as to check for the specified cases.

### Constraint(s)

None

#### Messages and Suggested Fix

The following message appears at the first line of a case construct with the default clause and full\_case pragma or priority/unique case construct with a default clause:

[WARNING] Case statement marked <type> has a default clause

Where, <type> can be full\_case or priority\_case or unique case.

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

The *Av\_case\_default\_redundant* rule may report a violation because of the following reasons:

- Full\_case pragma or the default clause is redundant.
- In case of priority/unique case the default clause is redundant.

#### **Consequences of Not Fixing**

This rule points to the need of intent review. If the designer meant to specify full\_case then there should not be a reason for a default clause. A review at the RTL coding stage can help you uncover subtle design issues.

#### How to Debug and Fix

Use either the full\_case pragma directive or the default clause in a case construct. For priority/unique case constructs, default clause is redundant.

To fix the violation, remove either the full\_case pragma or the default clause.

#### Example Code and/or Schematic

Consider the following example:

```
input [4:0]a7p,
         output reg [3:0]b6p,
         output reg [3:0]b7p);
always @ (al or a6p or a7p)
  case (a1) //synopsys full_case
     2'b00 : b6p <= a6p;
 2'b01 : b7p <= a7p;
 2'b11 : b7p <= a6p + a7p;
 2'b10 : b7p <= a7p - a6p;
 default: b7p <= 2'b11;
endcase
always @ (al or a6p or a7p)
  casez (a1[1]) //synopsys full_case
     1'b0 : b6p <= a6p;
     1'b1 : b7p <= a6p + a7p;
     default: b7p <= 2'b11;</pre>
   endcase
```

endmodule

In the above example, the *Av\_case\_default\_redundant* rule reports following violation messages:

| essage                                                                                                                                                                                                                                                         | File          | Line |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------|
| E C Message Tree (Total: 16, Displayed: 16, Waived: 0)                                                                                                                                                                                                         |               |      |
| Design Read (3)                                                                                                                                                                                                                                                |               |      |
| 🖻 🛱 test goal (13)                                                                                                                                                                                                                                             |               |      |
| Av_case_default_redundant (1): A case statement marked full_case or a priority/unique c<br>have a default clause.                                                                                                                                              | ase statement |      |
| Core statement marked hill, care has a default eleven.                                                                                                                                                                                                         | testv         | 18   |
| Case statement marked full_case has a default clause                                                                                                                                                                                                           | ELGINE F      |      |
| Case statement marked full_case has a default clause Av_initistate01 (1): Reports initial state of the design.                                                                                                                                                 | is at t       |      |
|                                                                                                                                                                                                                                                                | tool 1        |      |
| Av_initstate01 (1): Reports initial state of the design.                                                                                                                                                                                                       | ELOI. F       |      |
| ⊕ ⊅ Av_initistate01 (1): Reports initial state of the design. ⊕ ≏ Av_report01 (1): Reports statistics of properties and functional constraints.                                                                                                                |               |      |
| <ul> <li>Av_initistate01 (1): Reports initial state of the design.</li> <li>Av_report01 (1): Reports statistics of properties and functional constraints.</li> <li>Av_sanity02 (B): Reports all the nets in the design which have multiple drivers.</li> </ul> |               | 9    |

FIGURE 11. Av\_case\_default\_redundant Messages

In the above example, violations filtered by SpyGlass Functional Lint are

highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_case\_default\_redundant*, filters one false violation reported by the SpyGlass Lint rule, W551.

# **Default Severity Label**

Warning

# **Rule Group**

Implicit-properties

# **Reports and Related Files**

No related reports or files.

# Av\_case\_default\_missing

Ensure that a case statement or a selected signal assignment has a default clause

#### When to Use

Use this rule to identify case constructs without the default clause.

#### Description

The *Av\_case\_default\_missing* rule reports violation for case constructs without the default clause and case constructs and selected signal statements.

A default clause should always be specified in a case construct to handle unexpected situations even if the construct covers all potential situations.

**NOTE:** The Av\_case\_default\_missing rule supports generate-if and generate-for block.

#### **Rule Exceptions**

The *Av\_case\_default\_missing* rule does not report for missing default clause in the following cases:

- If the target signals in the case construct are assigned using a blocking or non-blocking assignment statement before the case statement
- Case constructs that are inside always construct that infer a flip-flop (Set check sequential rule parameter to report such cases).
- Case constructs with associated full\_case pragma and unique / priority cases.
- Fully-specified case constructs.
- Case statements with static case select (including generate case).

#### Language

Verilog

#### **Default Weight**

5

# Parameter(s)

strict: The default value is no. Set the value of the parameter to yes
to report fully-specified case constructs without the default clause.

check\_sequential: The default value is no. Set the value of the parameter to yes to enable rule checking in sequential block.

### Constraint(s)

None

### Messages and Suggested Fix

The following message appears at the location where a case construct is defined without a default clause:

[WARNING] Case statement does not have a default clause and is not preceded by assignment of target signal <block-type> [Hierarchy: '<hier-path>']

Where, *<block-type>* can be either a sequential or a combinational block and the *<hier-path>* is the complete hierarchical name of the containing scope excluding subprograms.

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

A violation is reported when a case construct is defined without a default clause.

#### **Consequences of Not Fixing**

If all possible cases of the case construct selector are covered, this is not directly an error. However, if the case construct selector has an undefined value (X or Z) and there is no default clause, then the design simulation may produce unexpected results.

If the width of the case construct selector changes as the design evolves, then what had once been a fully covered case construct may become only partially covered and can lead to inferred latches. Hence, it is recommended to always describe a default clause even if all possible cases of the case construct selector are described.

#### How to Debug and Fix

Double-click the violation message. The HDL Viewer window is displayed. The HDL Viewer window highlights the line where the case statement with missing default is declared.

To fix the violation, add a default clause to specify default behavior. If you are specifying simulation X behavior, bracket this behavior in translate\_off and translate\_on pragmas.

#### **Example Code and/or Schematic**

Consider the following example:

```
module top( input clk, rst,
            input [4:0]a1,
            input [4:0]a6p,
            input [4:0]a7p,
            output reg [3:0]b6p,
            output reg [3:0]b7p);
    always @ (al or a6p or a7p)
      case (a1)
        2'b00 : b6p <= a6p;
        2'b01 : b7p <= a7p;
        2'b11 : b7p <= a6p + a7p;
      endcase
    always @ (al or a6p or a7p)
      case (a1[0])
    1'b0 : b6p <= a6p;
    1'b1 : b7p <= a6p + a7p;
   endcase
endmodule
```

Now, consider that the value of the strict parameter is set to yes.

For this example, the *Av\_case\_default\_missing* generates the following violation messages:

| Message                                                                                                                                    | File      | Line |
|--------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|
| 🖻 🗀 Message Tree ( Total: 15, Displayed: 15, Waived: 0 )                                                                                   |           |      |
| Design Read (2)                                                                                                                            |           |      |
| 🖻 🖨 test goat (13)                                                                                                                         |           |      |
| Av_case_default_missing (1): A case statement(or selected signal assignment) does not have a defaulte                                      | wit       |      |
| Case statement does not have a default clause and is not preceded by assignment of target sign<br>in combinational block[Hierarchy; 'top'] | al test.v | 9    |
| Av initiate01 (1): Reports initial state of the design.                                                                                    |           |      |
| Av report01 (1) Reports statistics of properties and functional constraints.                                                               |           |      |
| ⊕                                                                                                                                          |           |      |
| 🖻 🛱 W71 (2) : A case statement(or selected signal assignment) does not have a default or OTHERS clau                                       | se        |      |
| Case statement does not have a default clause and is not preceded by assignment of target sign<br>in combinational block[Hierarchy: "top"] | al test.v | 9    |
| Case statement does not have a default clause and is not preceded by assignment of target sign<br>in combinational block[Hierarchy: "top"] | al test.v | 16   |

FIGURE 12. Av\_case\_default\_missing Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_case\_default\_missing*, filters one false violation reported by the SpyGlass Lint rule, W71.

### **Default Severity Label**

Warning

# **Rule Group**

Implicit-properties

### **Reports and Related Files**

No related reports or files.

# Av\_dontcare\_mismatch

#### Use of don't-care except in case labels may lead to simulation/ synthesis mismatch

#### When to Use

Use this rule to identify the usage of don't care character in the design.

#### Description

The *Av\_dontcare\_mismatch* rule reports violation for based numbers that contain the don't care character.

#### **Rule Exceptions**

The *Av\_dontcare\_mismatch* rule does not flag a violation for a parameter, generic, or constants that are assigned a don't-care value and are used only as case-label.

Also, no rule checking is done for unused macro definitions.

#### Language

Verilog, VHDL

#### **Default Weight**

5

# Parameter(s)

None

### Constraint(s)

None

### **Messages and Suggested Fix**

The following message appears at the location where a don't care character (?) is encountered in a based number <*num*>:

**[WARNING]** Based number <num> contains a don't care (?) - might lead to simulation/synthesis mismatch

This violation can be formally failed, partially-proved, not analyzed, or other by the formal engine. The not-analyzed violations appear when the

width mismatch between the signed and unsigned expressions is not passed to the formal engine.

For more information on the property status reported during the functional analysis, see *SpyGlass Auto Verify Rules Reference Guide*.

#### **Potential Issues**

Violation may arise when a based number contains a don't care value.

#### **Consequences of Not Fixing**

There is no physical counterpart for the don't-care value. In simulation, these values are typically mapped to 'Z' which causes a tristate to be inferred. However, this behavior should be avoided as it may result in inferring spurious logic.

#### How to Debug and Fix

Double-click the violation message. The HDL Viewer window highlights the line where the don't care value, ?, is used in the design other than in the case label.

To fix the violation, test both 0 and 1 values in a comparison. Also, in an assignment, choose either 0 or 1.

#### **Example Code and/or Schematic**

Consider the following example:

```
reg [1:0] state4;
    always @ (out0)
    begin
         out0 <= 4'b110?;</pre>
    end
    always @(posedge clk or posedge rst) begin
              if(rst) begin
                  state3 <= `S0;</pre>
              end
             else begin
                  priority case (state3)
                            `S0: state3 <= `S1;</pre>
                            `S1: state3 <= `S2;</pre>
                            `S2: state3 <= `S0;</pre>
                           default: begin
                       state3 <= `S3;</pre>
                       out1 = 3'b11?;
                  end
                  endcase
              end
    end
endmodule
```

In the above example, the *Av\_dontcare\_mismatch* rule reports following violation messages:

| Message                                                                                                        | File    | Line |
|----------------------------------------------------------------------------------------------------------------|---------|------|
| 🖯 🗀 Message Tree ( Total: 8, Displayed: 8, Walved: 0 )                                                         |         |      |
| 🖻 🖨 Design Read (3)                                                                                            |         |      |
| 🖻 🛱 test goal (5)                                                                                              |         |      |
| Av_dontcare_mismatch (1): Use of don't-care except in case labels may lead to simulation/synthesis<br>mismatch | 80)<br> |      |
| Based number 4'b110? contains a don't-care (?) - might lead to simulation/synthesis mismatch                   | testv   | 18   |
| D Av initistate01 (1): Reports initial state of the design.                                                    |         |      |
| Av report01 (1) : Reports statistics of properties and functional constraints.                                 |         |      |
| 🕒 🛱 W467 (2) : Use of don't-care except in case labels may lead to simulation/synthesis mismatch               |         |      |
| Based number 4'b110? contains a don't-care (?) - might lead to simulation/synthesis mismatch                   | testv   | 18   |
| Based number 3'b11? contains a don't-care (?) - might lead to simulation/synthesis mismatch                    | testv   | 32   |

FIGURE 13. Av\_dontcare\_mismatch Messages

In the above example, violations filtered by SpyGlass Functional Lint are highlighted in green. However, violations not filtered by SpyGlass Functional Lint are highlighted in red.

As shown in the above figure, SpyGlass functional lint rule, *Av\_dontcare\_mismatch*, filters one false violation reported by the SpyGlass Lint rule, W467.

### **Default Severity Label**

Warning

#### **Rule Group**

**Expression Rules** 

### **Reports and Related Files**

No related reports or files.

# SpyGlass Lint Abstraction Flow

# **Overview**

Based on the goal run while generating an abstract view of a block and validating assumptions on an abstract view, SpyGlass generates and validates product-specific details.

This section describes the different type of information generated and validated during the SoC methodology flow.

- Generating an Abstract View in SpyGlass Lint
- Validating Assumptions on Abstract View in SpyGlass Lint
- Using the Abstract View in SpyGlass Lint
- Using the Automatic SoC Flow in SpyGlass Lint

In the SpyGlass 5.6 release, the *Invoking the Automatic SoC Flow* has been enhanced.

# **Generating an Abstract View in SpyGlass Lint**

To generate an abstract view while using SpyGlass Lint solution, run the lint\_abstract goal.



The following figure shows the process of generating an abstract view in the SpyGlass Lint solution:

To generate Abstract View for clock-reset integrity checks, Advanced CDC license is required.

# **Example - Generating an Abstract View in SpyGlass Lint**

This section describes an example of generating an abstract view of the blockA block in the SpyGlass Lint solution.

It covers the following topics:

- Reading the blockA.v and blockA.sgdc Files in SpyGlass
- Generating an Abstract View of blockA
- Understanding the Generated Abstract View of blockA

### Reading the blockA.v and blockA.sgdc Files in SpyGlass

Consider the following files (RTL and SGDC for blockA) specified for generating an abstract view:

**NOTE:** For generating the abstract view, you can capture the block interface information by using the include\_block\_interface project file option. Alternatively, you can manually specify the block interface information in the form of SGDC constraints for the abstract model.

```
// Block SGDC (blockA.sgdc)
 // Block RTL (blockA.v)
module blockA (output op1, op2, input in1,
                                             current_design blockA
            in2, in3, rst, clk, tm);
                                               set_case_analysis -name tm -value 1
    reg ff1, ff2, ff3;
    wire d1, clkn;
    assign clkn = !clk;
    assign d1 = in1 & in2;
   always @(posedge clk or posedge rst) begin
        if (rst) begin
            ff1 <= 1'b0;
           ff2 <= 1'b0;
        end
        else begin
            ff1 <= d1;
            ff2 <= ff1;
       end
    end
    always @(posedge clkn or posedge rst) begin
        if (rst) begin
            ff3 <= 1'b0;
        end
        else begin
            ff3 <= !(tm & in2);
       end
   end
   assign op1 = ff2 & ff3;
   assign op2 = ff3 & in3;
endmodule
```

Following is the schematic of the above design:





To read in the above design and its SGDC file, use the following project file: # File: blockA.prj

```
##Data Import Section
read_file -type verilog blockA.v
read_file -type sgdc blockA.sgdc
##Common Options Section
set_option language_mode mixed
set_option projectwdir .
set_option current_methodology $SPYGLASS_HOME/GuideWare/
2015.12/soc/rtl_handoff/
```

set\_option top blockA

# Generating an Abstract View of blockA

Specify the following command to generate the abstract view for the design read in the *Reading the blockA.v and blockA.sgdc Files in SpyGlass* step:

spyglass -project blockA.prj -batch -goal lint/lint\_abstract

**NOTE:** For generating the abstract view, you can capture the block interface information by using the include\_block\_interface project file option. Alternatively, you can manually specify the block interface information in the form of SGDC constraints for the abstract model.

### Understanding the Generated Abstract View of blockA

After *Reading the blockA.v and blockA.sgdc Files in SpyGlass* and *Generating an Abstract View of blockA*, the following SGDC file is generated representing the abstract view:

current\_design "blockA" -def\_param

abstract\_port -ports "opl" -connected\_inst "\blockA.ff2\_reg " -inst\_master "RTL\_FDC" -inst\_pin "Q" -path\_logic combo -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD"

abstract\_port -ports "op2" -connected\_inst "\blockA.ff3\_reg " -inst\_master "RTL\_FDC" -inst\_pin "Q" -path\_logic combo -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD"

abstract\_port -ports "in1" -connected\_inst "\blockA.ff1\_reg " -inst\_master "RTL\_FDC" -inst\_pin "D" -path\_logic combo -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD"

abstract\_port -ports "in2" -connected\_inst "\blockA.ff3\_reg " -inst\_master "RTL\_FDC" -inst\_pin "D" -path\_logic combo -path\_polarity inv -mode set\_case\_analysis -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD"

abstract\_port -ports "in2" -connected\_inst "\blockA.ff1\_reg " -inst\_master "RTL\_FDC" -inst\_pin "D" -path\_logic combo -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD" abstract\_port -ports "in3" -related\_ports "op2" -path\_logic combo -path\_polarity buf -mode set\_case\_analysis -scope base -data "PORT\_WITH\_RELATED\_PORT" abstract\_port -ports "rst" -connected\_inst "\blockA.ff2\_reg " -inst\_master "RTL\_FDC" -inst\_pin "CLR" -path\_logic buf -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_RST\_PORT" abstract\_port -ports "clk" -connected\_inst "\blockA.ff3\_reg

abstract\_port -ports "CIK" -Connected\_inst "\blockA.II3\_reg
" -inst\_master "RTL\_FDC" -inst\_pin "CP" -path\_logic inv
-path\_polarity inv -mode set\_case\_analysis -scope base
-data "REGISTERED\_CLK\_PORT"

abstract\_port -ports "clk" -connected\_inst "\blockA.ff2\_reg " -inst\_master "RTL\_FDC" -inst\_pin "CP" -path\_logic buf -path\_polarity buf -mode set\_case\_analysis -scope base -data "REGISTERED\_CLK\_PORT"

abstract\_port -ports "tm" -scope base -data "REGISTERED\_PORT\_WITH\_COMBO\_CLOUD"

In the above abstract view, the lint\_abstract goal generates the following information:

■ The abstract port constraint for only one unique path of each port.

For example, if an input pin of a block is connected to the data-pin of 10 flip-flops without any combinational or inverter logic, only one entry is generated in the abstract view (SGDC file).

However, if there are paths that have some combinational logic or an inverter, a separate entry is generated for each for buffer, inverter, and combinational path. For example, the in2 port reaches the ff1\_reg and ff3\_reg flip-flops with different polarity. Therefore, there will be two entries in the generated SGDC file.

The abstract\_port constraints for the op1 and op2 output ports with the -path\_logic combo argument and the -path\_polarity buf argument.

Here, combo represents a combinatorial path from the source object to

the destination out-pin. Similarly, buf represents a buffer type as there is no path inversion between the source object and the destination out pin Q of the ff2\_reg and ff3\_reg flip-flop.

- RTL\_FDC is the name of master module of the ff2\_reg and ff3\_reg flip-flops and the -inst\_pin argument represents the pin of the master module RTL\_FDC, which is connected to the block ports, such as op1 and op2.
- Similarly, the abstract\_port constraint is also generated for the blockA input port, which hits flip-flops. For example, the in1 and in2 ports are connected to the ff1\_reg and ff3\_reg flip-flops, respectively.
- If any input reaches the output port having only combination logic, SpyGlass generates the output port as related\_port <output-port-name> in the SGDC file. For example, the in3 port reaches the op2 output port, which has combinational logic only.

# Validating Assumptions on Abstract View in SpyGlass Lint

At this stage, read in the abstract views of lower level blocks and their port interfaces and validate them to check if top-level constraints are matching with the block-level constraints under which abstraction occurred.

The following figure shows the process of validation in SpyGlass Lint solution. If you have an enhanced abstract model, specify the use\_block\_interface project file option.



FIGURE 3.

#### **Importing Abstract View**

Create an SoC-level SGDC file to read (import) abstract view created in the *Example - Generating an Abstract View in SpyGlass Lint* step.

// File: top.sgdc

current\_design top
sgdc -import blockA blockA/blockA\_abstract.sgdc

**NOTE:** You must also import the port interface information of the block for which you have imported the abstract view. The port interface information is imported in the *Creating a Project File Used during Validation step.* 

#### **Creating a Project File Used during Validation**

Create the following project file in which you read the abstract view of blockA and its port interface information in the form of its RTL:

```
# File: top.prj
##Data Import Section
read_file -type verilog top.v
## Import the 'abstract view' of the blocks
read_file -type sgdc top.sgdc
```

```
## Read the port interface of the abstract blocks
read_file -type verilog ./blockA/blockA_port_interface.v
##Common Options Section
set_option language_mode mixed
set_option projectwdir .
set_option current_methodology $SPYGLASS_HOME/GuideWare/
2015.12/soc/rtl_handoff/
set_option top top
```

# **Performing Validation**

Run the lint\_abstract\_validate goal to validate the sanity of the abstract view with respect to the top-level test environment.

```
spyglass -project top.prj -batch -goal lint/
lint_abstract_validate
```

#### Viewing Validation-Related Messages

Look for the violation messages of the *LINT\_sca\_validation* rule in the GUI or the moresimple.rpt report.

The *LINT\_sca\_validation* rule reports a violation if the simulated value reaches the top-level net connected to a block-level port but no set\_case\_analysis constraint is specified on the block-level port, or vice-versa. This indicates that the abstract view is not suitable to be used at top-level.

Fix such violations, and regenerate the abstract view and validate it again.

# Using the Abstract View in SpyGlass Lint

Once validation is successfully performed (block versus top-level constraints), you can perform SpyGlass Lint analysis at the top-level.

The following figure shows the process of validation in SpyGlass Lint. If you have an enhanced abstract model, specify the use\_block\_interface project file option.



FIGURE 4.

For details on the steps during this stage, see the *Using the Abstract View during SoC-Level Verification* section in the SoC Methodology Guide.

# Using the Automatic SoC Flow in SpyGlass Lint

Performing SoC verification involves multiple steps, such as verifying each block in SoC, generating an abstract view for each block, validating abstract views with SoC and performing SoC verification using the validated abstract views. This process requires complex file handling. In case of multiple instances of a block, input files for each instance should be tracked.

To simply the above process, SpyGlass Lint provides *The Automatic SoC Flow* (also known as the single push button flow). In this flow, you provide necessary inputs once and then SpyGlass automatically performs the following steps of SoC verification:

- 1. Generate block-level SGDC files by performing top-down constraint migration of blocks.
- 2. Verify each block by using the generated block-level SGDC.
- 3. Generate abstract views of the verified blocks.

4. Verify the generated abstract views at the SoC level.

This section covers the following topics:

- Invoking the Automatic SoC Flow
- Configuration File for the Automatic SoC Flow
- Incremental Run of the Automatic SoC Flow
- Output of the Automatic SoC Flow

# Invoking the Automatic SoC Flow

# Prerequisite

You must first load a design in *sg\_shell* by using the open\_project Tcl command.

# Invoke the Automatic Flow

You can invoke the Automatic Flow the following ways in *sg\_shell*:

- Method 1: Configuration File
- Method 2: Non-Configuration File

#### Method 1: Configuration File

By specifying the following command, you can provide the configuration file. In this method, the mode is top down by default.

```
sg_shell> auto_soc -configfile <configuration-file>
```

For details on the -configfile argument of the above command, see *Configuration File for the Automatic SoC Flow*.

#### Method 2: Non-Configuration File

When you do not have a configuration file, by default, all the blocks instantiated directly in top are abstracted. In this method, you have the option of:

- Changing the mode to bottom up by using the mode argument
- Specifying a parallel file by using the parallelfile argument.

#### Example 1

By specifying the following command, you can provide the output directory and the parallel file. In this method, the mode is top down by default.

```
sg_shell> auto_soc -outdir <output-directory> -parallelfile
<lsf-file> -current_product lint
```

Where, <lsf-file> should have the following format:

```
LOGIN_TYPE: lsf
MAX_PROCESSES: 2
LSF_CMD: /delsoft/software/lsf/7.0/linux2.6-glibc2.3-x86_64
/bin/bsub -I -q normal -R "rusage[mem=4000]"
```

Here, LOGIN\_TYPE accepts only the lsf value.

#### Example 2

In this example, the mode is explicitly set to bottom\_up and a parallel file is not provided. By default, the mode is top down.

sg\_shell> auto\_soc -outdir <output-directory>
-mode bottom\_up -current\_product lint

#### Example 3

By specifying the following command, you can provide the output directory, the parallel file, and the mode. In this example, the mode is explicitly set to bottom up. By default, the mode is top down.

sg\_shell> auto\_soc -outdir <output-directory> -parallelfile
<lsf-file> -mode bottom\_up -current\_product lint

#### The Automatic SoC Flow

The following figure shows the automatic SoC Flow:



FIGURE 5. The Automatic SoC Flow

# **Configuration File for the Automatic SoC Flow**

The configuration file provides the following information:

- Block-level and top-level goals to run
- Block-level setup information, such as parameters, input SGDC, and block abstract views
- Block-level project files
- Mode of run, that is bottom-up or top-down
- Location of output

To create a configuration file, use the -config\_file option of the auto\_soc Tcl command.

# Sections in a Configuration File

The configuration file is divided into three top-level sections defining the following scopes:

- Product Scope
- Top-Level Scope
- Block-Level Scopes

Each of the above scope is defined by using a particular command. Within a scope, you can specify different specifications as described in the following table:

| Specification                                         | Corresponding Command                                                                                                                                                                               |
|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Define a verification methodology and/or goal to run. | <pre>soc_arg current_methodology <name> soc_arg current_goal <goal-name></goal-name></name></pre>                                                                                                   |
| Define product-specific parameters and options.       | <pre>soc_arg set_parameter <name> <value></value></name></pre>                                                                                                                                      |
| Define block-level project file.                      | <pre>soc_arg set_project_file <prj-file></prj-file></pre>                                                                                                                                           |
|                                                       | Top-down constraints migration and project file generation is not done for the block specified with this command.                                                                                   |
| Define block-level SDC and/or SGDC file               | <pre>soc_arg sgdcfile <sgdc-file></sgdc-file></pre>                                                                                                                                                 |
| Define a run mode                                     | soc_arg mode bottom_up<br>OR<br>soc_arg mode top_down <b>(default)</b>                                                                                                                              |
|                                                       | If you specify <i>top_down</i> , top-level constraints are migrated to the block (top-down constraints migration).                                                                                  |
|                                                       | If you specify <i>bottom_up</i> , you must specify<br>SGDC file for the block. In this case, SpyGlass<br>performs block verification directly without<br>performing top-down constraints migration. |
| Disable specific steps                                | <ul> <li>soc_arg disable top_down Disables the top-down constraints migration. In this case, you should specify block-level SGDC files.</li> </ul>                                                  |
|                                                       | <ul> <li>soc_arg disable verif</li> <li>Disables block or top-level verification.</li> </ul>                                                                                                        |
| Define the location of the output of SoC verification | <pre>soc_arg outdir <directory-path></directory-path></pre>                                                                                                                                         |

# TABLE 1 Commands of a Configuration File

| Specification                                  | Corresponding Command                                                                                                          |
|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Enable the parallel run of block-level modules | <pre>soc_arg num_parallel_runs <number-of-<br>block-level-modules&gt;</number-of-<br></pre>                                    |
|                                                | For example, if you specify the value 4 to this command, <i>The Automatic SoC Flow</i> is run for any four blocks in parallel. |
|                                                | If you do not specify this command, <i>The Automatic SoC Flow</i> of blocks occur serially.                                    |
| Enable the LSF mode for parallel blocks run    | <pre>soc_arg parallelfile <lsf-file></lsf-file></pre>                                                                          |
|                                                | Where <isf-file> is the LSF file containing the<br/>following format:</isf-file>                                               |
|                                                | LOGIN_TYPE: lsf                                                                                                                |
|                                                | MAX_PROCESSES: 2                                                                                                               |
|                                                | LSF_CMD: /delsoft/software/lsf/7.0/<br>linux2.6-glibc2.3-x86_64/bin/bsub -I -q                                                 |
|                                                | normal -R "rusage[mem=4000]"                                                                                                   |
|                                                | LOGIN_TYPE is static and it only accepts the lsf value.                                                                        |

#### See Configuration File Format.

#### **Product Scope**

This section defines the product under which *The Automatic SoC Flow* should be done.

Use the following command to define SpyGlass Lint scope:

current\_product Lint

Use different *Commands of a Configuration File* to specify settings under this scope.

#### **Top-Level Scope**

This section defines the top-level block (SoC) for which *The Automatic SoC Flow* should be done:

Use the following command to define the top-level scope:

soc\_top <top-name>

Use different *Commands of a Configuration File* to specify settings under this scope.

#### **Block-Level Scopes**

This section defines settings, such as parameters and SGDC files for a particular block. Repeat this section for each block.

Use the following command to define a block-level scope:

soc\_block <block-name> [<inst-name>]

Use different *Commands of a Configuration File* to specify settings under this scope.

#### **Configuration File Format**

```
Following is the sample configuration file:
current_product Lint
soc_arg outdir run_soc_dir
#soc_arg mode bottom_up
soc_top <TOP-NAME>
soc_arg current_methodology <METHODOLOGY-NAME>
soc_arg current_goal <GOAL-NAME>
soc_block <BLOCK1-NAME> <INSTANCE-NAME>
soc_arg current_methodology <METHODOLOGY-NAME>
soc_arg current_methodology <METHODOLOGY-NAME>
soc_arg current_goal <GOAL-NAME>
soc_arg sgdcfile <block.sgdc>
soc block <BLOCK2-NAME> <INSTANCE-NAME>
```

soc\_arg current\_methodology <METHODOLOGY-NAME>

soc\_arg current\_goal <GOAL-NAME>

#### Configuration File Without soc\_block

If you do not specify soc\_block in a configuration file, *The Automatic SoC Flow* performs top-down constraints migration for all the blocks at the top-level module.

For example, consider the following configuration file:

```
current_product lint
soc_arg outdir ./Work/Linux4
soc_arg parallelfile lsf
soc_top top
soc_arg current_goal lint/lint_rtl
soc_arg current_methodology $::env(SPYGLASS_HOME)
/GuideWare2.0/soc/rtl_handoff
```

In the above file, soc\_block is missing. Therefore, all the top-level blocks are picked for top-down constraints migration. In addition, during block abstraction, all the goals available for soc top are run.

# Incremental Run of the Automatic SoC Flow

Incremental run of *The Automatic SoC Flow* enables you to incrementally analyze specific blocks as and when they are modified.

To incrementally analyze specific blocks, use the following command:

```
auto_soc -configfile <Tcl-file> -incremental "<space-
separated-block-list>"
```

The following example shows the usage of the above command:

```
auto_soc -configfile cfg.tcl -incremental "b1 b2 b3 b4"
```

Running *The Automatic SoC Flow* incrementally is required in the following cases:

You make updates in the top-level RTL, project file, or SGDC file.
Performing incremental run in this case invokes *The Automatic SoC Flow* 

again including top-down constraints migration.

You update the project file of a specific block or the RTL/SGDC of specific blocks.

# **Output of the Automatic SoC Flow**

This section covers the following topics:

- Directories Created in the Automatic SoC Flow
- Run Results in the GUI in the Automatic SoC Flow
- The HTML Report Generated in the Automatic SoC Flow

# **Directories Created in the Automatic SoC Flow**

The following table summarizes the directories created in *The Automatic SoC Flow*:

| Lint/block_run | <block-name>_<instance-name></instance-name></block-name> | abstract_view      | Contains the<br>abstract view of<br>the block                                   |
|----------------|-----------------------------------------------------------|--------------------|---------------------------------------------------------------------------------|
|                |                                                           | project_files      | Contains<br>project-file<br>related<br>information of<br>the block              |
|                |                                                           | top_down_gen_files | Contains the<br>SGDC file<br>generated for<br>the block in the<br>top-down flow |

| Lint/soc_run/                                              | <top-level-module-name></top-level-module-name> | top_down                         | Contains files,<br>such as project<br>files and SGDC<br>files used in the<br>top-down flow |
|------------------------------------------------------------|-------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------|
|                                                            |                                                 | verif                            | Contains<br>top-level<br>verification files,<br>such as project<br>files and SGDC<br>files |
| <top>_lint_VERI<br/>F/<top>/<br/>html_reports/</top></top> | dashboard.html                                  | Shows consolidated top-down flow | run results of the                                                                         |
| Lint/<br>_spyglass_intern<br>al                            | error.log                                       | Shows SpyGlass fat               | al and run errors                                                                          |
| Lint/<br>_spyglass_intern<br>al                            | run.log                                         | Shows information of executed.   | of the steps                                                                               |

# Run Results in the GUI in the Automatic SoC Flow

SpyGlass generates the run results of different blocks in the GUI under the *Hierarchical Flow* tab that appears after *The Automatic SoC Flow* is complete.

The *Hierarchical Flow* tab is shown in the following figure:



FIGURE 6. The Hierarchical Flow menu

The **Hierarchical Flow** menu enables you to load the verification run results of the top-level and the block.

#### The HTML Report Generated in the Automatic SoC Flow

SpyGlass generates the *dashboard.html* report in the <top>\_lint\_VERIF/<top>/html\_reports/ directory after *The Automatic SoC Flow* is complete. This report shows the consolidated run results of the top-down flow.

The following figure shows this part of the report:

| PYGLAŚ        | S SpyG                  | ilass DashBo            | oard       |            |              |            |              |                                        |                             |                                            |
|---------------|-------------------------|-------------------------|------------|------------|--------------|------------|--------------|----------------------------------------|-----------------------------|--------------------------------------------|
| nmary Quality | Goals Design            | Objectives B            | LK/TES     | ST-U1      | <b>0</b> TI  | EST (      | 3 tem        | plate/sample 😣                         |                             |                                            |
|               |                         |                         |            |            |              |            |              |                                        |                             |                                            |
| Module Name   | Quality Goals           |                         | U          | nresolv    | ved          | w          | aived        |                                        | Show All                    | ■ <u>Pass</u>   <mark>■</mark> <u>Fail</u> |
| Module Name   | Quality Goals           | Run Status              |            |            |              |            |              | Success Criteria                       | <u>Show All</u>  <br>Status | ■ <u>Pass</u>   ■ <u>Fail</u>              |
| Module Name   | Quality Goals<br>sample | Run Status<br>Completed |            |            |              |            | warning      | Success Criteria<br>Fatal =0, Error =0 |                             |                                            |
|               |                         |                         | fatal      | error      | warning      | error      | warning      |                                        | Status                      | View Results                               |
| BLK/TEST-U1   | sample                  | Completed               | fatal<br>0 | error<br>0 | warning<br>3 | error<br>0 | warning<br>0 | Fatal =0, Error =0                     | Status<br>Pass              | View Results<br><u>Open</u>                |

#### FIGURE 7. The dashboard.html Report

For more details, you can view the detailed results in the GUI. To launch the GUI, click the **Open** link in the **View Results** column. The GUI launches automatically, enabling you to use the debugging capabilities of the GUI.