OpenCores
URL https://opencores.org/ocsvn/t6507lp/t6507lp/trunk

Subversion Repositories t6507lp

[/] [t6507lp/] [trunk/] [lint/] [run/] [hal.def] - Rev 225

Go to most recent revision | Compare with Previous | Blame | View Log


    // --------------------------------- //
    //  Includes & Category Definitions  //
    // --------------------------------- //

category ALL "This category consists of all the categories in HAL" default_on
{
  ALL_BEHAVIORAL        // Category of all the Behavioral level checks
  ALL_RTL       // Category of all the RTL level checks
  ALL_NETLIST   // Category of all the Netlist level checks
  ALL_TOOL      // HAL usage errors
  ALL_SYSTEMC   // SystemC(r) specific checks
}

category ALL_BEHAVIORAL "Category of all the Behavioral level checks" default_on
{
  BEH_CODINGSTYLE_VHDL          // Behavioral level coding style checks
}

category ALL_RTL "Category of all the RTL level checks" default_on
{
  RTL_NAMING    // Category of all the RTL Naming checks
  RTL_FILEFORMAT        // Category of all the RTL File format checks
  RTL_CODECOMMENT       // Category of all the RTL Code comment checks
  RTL_CODINGSTYLE       // Category of all the RTL coding style checks
  RTL_SIMSYNTH          // Category of pre and post-synthesis simulation mismatch checks
  RTL_SYNTH     // Category of all the synthesizability checks
  RTL_SIMRACE   // Category of all the simulation race condition checks
  DFT   // Verilog and VHDL DFT checks
  FSM   // Verilog and VHDL, FSM coding style checks
  STRUCTURAL    // Verilog/VHDL structural checks
  CLOCKDOMAIN   // Verilog/VHDL clock domain checks
  PALLADIUM     // Category of all the checks to qualify design to run on Palladium
  RMM   // All checks complying to Reuse Methodology Manual
  LOW_POWER     // All checks related to low power design
}

category ALL_NETLIST "Category of all the Netlist level checks" default_on
{
  DFT   // Verilog and VHDL DFT checks
  STRUCTURAL    // Verilog/VHDL structural checks
  CLOCKDOMAIN   // Verilog/VHDL clock domain checks
  SCANCHAIN     // Verilog/VHDL Netlist level scan chain checks
}

category RTL_NAMING "Category of all the RTL Naming checks" default_off
{
  RTL_NAMING_VERILOG    // Verilog only Naming checks
  RTL_NAMING_VHDL       // VHDL only Naming checks
  RTL_NAMING_MIXED      // Naming checks for Verilog and VHDL
  RTL_NAMING_ASSERTIONS         // SystemVerilog Assertion only Naming checks
}

category RTL_FILEFORMAT "Category of all the RTL File format checks" default_on
{
  RTL_FILEFORMAT_VERILOG        // Verilog only File format checks
  RTL_FILEFORMAT_VHDL   // VHDL only File format checks
  RTL_FILEFORMAT_MIXED          //  File format checks for Verilog and VHDL
}

category RTL_CODECOMMENT "Category of all the RTL Code comment checks" default_off
{
  RTL_CODECOMMENT_VERILOG       // Verilog only Code comment checks
  RTL_CODECOMMENT_MIXED         // Code comment checks for Verilog and VHDL
}

category RTL_CODINGSTYLE "Category of all the RTL coding style checks" default_on
{
  RTL_CODINGSTYLE_VERILOG       // Verilog only coding style checks
  RTL_CODINGSTYLE_VHDL          // VHDL only coding style checks
  RTL_CODINGSTYLE_MIXED         // coding style checks for Verilog and VHDL
  RTL_CODINGSTYLE_ASSERTIONS    // coding style checks for Assertions
}

category RTL_SIMRACE "Category of all the simulation race condition checks" default_on
{
  RTL_SIMRACE_VERILOG   // Verilog only simulation race condition checks
}

category RTL_SIMSYNTH "Category of pre and post-synthesis simulation mismatch checks" default_on
{
  RTL_SIMSYNTH_VERILOG          // Verilog only pre and post-synthesis simulation mismatch checks
  RTL_SIMSYNTH_MIXED    // Verilog/VHDL pre and post-synthesis simulation mismatch checks
}

category RTL_SYNTH "Category of all the synthesizability checks" default_on synth_only
{
  RTL_SYNTH_VERILOG     // Verilog only synthesizability checks
  RTL_SYNTH_VHDL        // VHDL only synthesizability checks
  RTL_SYNTH_MIXED       // Verilog and VHDL  synthesizability checks
}

category ALL_SYSTEMC "SystemC(r) specific checks" default_on
{
  BDSGIT  // Null value passed for the name argument of the SystemC %s '%s' 
  WTINMT  // Wait function called by the SystemC method '%s' of class '%s' 
  STINMT  // Function 'sc_start' called by the SystemC method '%s' of class '%s' 
  STINTD  // Function 'sc_start' called by the SystemC thread '%s' of class '%s' 
  CYINMT  // Function 'sc_cycle' called by the SystemC method '%s' of class '%s' 
  CYINTD  // Function 'sc_cycle' called by the SystemC thread '%s' of class '%s' 
  ITINMT  // Function 'sc_initialize' called by the SystemC method '%s' of class '%s' 
  ITINTD  // Function 'sc_initialize' called by the SystemC thread '%s' of class '%s' 
  BDMDCT  // Module name argument not declared in constructor '%s' as 'sc_module_name' 
  BDOBNM  // Bad value '%s' passed for the name argument of SystemC %s, '%s' 
  DFOBNM  // The value '%s' passed for the name argument of SystemC %s, '%s', is different from the field name 
  OBNONM  // The SystemC %s '%s' is initialized with no name 
  OBNOIT  // The SystemC %s '%s' is not explicitly named in the initializaton list of the module constructor 
  DFVWNM  // The value '%s' passed for the name argument of SystemC viewable object '%s' is different from the name of the field that it references: '%s' 
  OBISLV  // SystemC object '%s' is declared as a local variable 
  OBISGV  // SystemC object '%s' is declared as a global variable 
  OBISFP  // SystemC object '%s' is declared as a formal parameter of a function 
  PIINCT  // A port interface method called in the constructor of SystemC module '%s' 
  WTINCT  // Wait function called by the constructor of SystemC module '%s' 
  WTINMN  // Wait function called by the sc_main function 
  WTINUP  // Wait function called by the update method of SystemC primitive channel, '%s' 
  RUINUP  // request_update function called by the update method of SystemC primitive channel, '%s' 
  EFINWT  // A function call, returning sc_event_finder&, passed as an argument to the wait function 
  CYISDP  // The function sc_cycle is deprecated in SystemC 2.1. Use sc_start instead 
  BDSPRV  // Bad argument passed, for the return value of the spawned process, in the sc_spawn function call 
  SGPIRW  // %s->%s() called instead of %s.%s(). The latter is more efficient 
  MDINNM  // The SystemC module, '%s', is declared in the namespace '%s' 
  IFNOVB  // The sc_interface class is not a virtual base class of the SystemC interface '%s' 
  BDPORT  // The SystemC port, '%s', is passing an invalid template argument to base class, sc_port 
  OLCLDL  // Old style declaration found for SystemC clock '%s' 
  BDCLPR  // The SystemC clock, '%s', is initialized with a bad value for clock period. It should be > 0 
  BDCLDC  // The SystemC clock, '%s', is initialized with a bad value for duty cycle. It should be between 0 and 1 
  MDINLS  // The SystemC module, '%s', is declared in the inner (local) scope of a class or function 
  BDPRNM  // Bad value '%s' passed for the name argument of process created using sc_spawn 
  PRNONM  // The process created using sc_spawn was not initialized with a name 
  NOBSCN  // The macro SCV_BASE_CONSTRAINT(%s) not called in the constructor of constraint class '%s' 
  UCONMF  // The method use_constraint called on the member field '%s' of constraint class '%s' 
  BDHCAG  // The argument to method sc_hdl_task_handle::call_task has an unsupported type: '%s' 
  HCINCT  // The method sc_hdl_task_handle::%s called in the constructor of SystemC module '%s' 
  CBNOVB  // The scv_constraint_base class is not a virtual base class of constraint '%s' 
  BDRFFP  // The formal parameter #%d of function '%s' has an unsupported type: '%s' 
  PBINPR  // Port binding in SystemC Process '%s' of class '%s' is not allowed 
  BWDIFF  // Assigning %s to %s: bit widths are different 
  BDINAG  // Only the base class can be passed as an argument to macro, SCV_INIT 
  BDEXCT  // Only the base class can be passed as an argument to macro, SCV_EXTENSIONS_BASE_CLASS 
  STRSUB  // sc_string is typedef'd to std::string. The call to std::string::substr has different semantics than the call to sc_string::substr in previous versions of SystemC 
}

category BEH_CODINGSTYLE_VHDL "Behavioral level coding style checks" default_on
{
  WNBFLK {level="1"} // Port '%s' should not be of mode buffer or linkage 
  SYNCSL {level="1"} // The sensitivity list of a sequential process does not contain an asynchronous reset 
  BEHINI {level="2"} // A behavioral variable/signal '%s' is not initialized in its declaration 
  SUBTNM {level="2"} // Subtype name '%s' does not contain the type name '%s' 
  ENTDCL {level="2"} // A VHDL entity should only consist of generic and port interface lists 
  UNITNM {level="2"} // VHDL design-unit name '%s' is missing on the end line 
  SUBPNM {level="2"} // VHDL %s name '%s' is missing on the end line 
  NOLABL {level="2"} // Process label '%s' is missing as a closing label 
  ALOWID {level="2"} // Signal/variable name '%s' does not follow the active-low naming convention 
  MAXPRT {level="3"} // Entity '%s' must not have more than %d ports 
  PDFPKG {level="3"} // The standard/IEEE package '%s' should not be used 
  MLITNU {level="3"} // The enumeration type '%s' should not contain more than %d literals 
  DESULN {level="3"} // The length of design-unit '%s' should not exceed %d lines 
  FENAME {level="2"} // Identifier '%s' updated on negative edge of clock should have '_f' as suffix 
  USRATN {level="3"} // User-defined attribute '%s' is being used in architecture '%s' 
}

category RTL_NAMING_VERILOG "Verilog only Naming checks" default_off
{
  MODLNM {level="4"} // Module name '%s' does not follow the naming convention 
  SVIFNM {level="4"} // SystemVerilog interface name '%s' does not follow the recommended naming convention 
  INSTNM {level="4"} // Instance name '%s' does not follow the naming convention 
  BLKLNM {level="4"} // Begin/end block name '%s' does not follow the naming convention 
  FUNCNM {level="4"} // Function name '%s' does not follow the naming convention 
  TASKNM {level="4"} // Task name '%s' does not follow the naming convention 
  PARMNM {level="4"} // Parameter name '%s' does not follow the naming convention 
  INTGNM {level="4"} // Integer variable name '%s' does not follow the naming convention 
  REALNM {level="4"} // Real variable name '%s' does not follow the naming convention 
  MEMRNM {level="4"} // Memory name '%s' does not follow the naming convention 
  WIRENM {level="4"} // Wire name '%s' does not follow the naming convention 
  REGRNM {level="4"} // Register name '%s' does not follow the naming convention 
  VLFLNM {level="4"} // File name '%s' does not follow the recommended naming convention%s 
}

category RTL_NAMING_ASSERTIONS "SystemVerilog Assertion only Naming checks" default_off
{
  LOCVNM {level="4"} // Local variable '%s' in %s does not follow the recommended naming convention 
  ASTMNM {level="4"} // Assert statement '%s' does not follow the recommended naming convention 
  COVRNM {level="4"} // Cover statement '%s' does not follow the recommended naming convention 
  ASUMNM {level="4"} // Assume statement '%s' does not follow the recommended naming convention 
  PROPNM {level="4"} // Property '%s' does not follow the recommended naming convention 
  SEQNNM {level="4"} // Sequence '%s' does not follow the recommended naming convention 
}

category RTL_NAMING_VHDL "VHDL only Naming checks" default_off
{
  ARCHNM {level="4"} // Architecture name '%s' does not follow the naming convention 
  ENTYNM {level="4"} // Entity name '%s' does not follow the naming convention 
  PCKGNM {level="4"} // Package name '%s' does not follow the naming convention 
  CMPPKG {level="4"} // Package name %s does not follow the recommended naming convention 
  SUBRNM {level="4"} // Subprogram name '%s' does not follow the naming convention 
  ACCSNM {level="4"} // Access-type name '%s' does not follow the naming convention 
  CNSTNM {level="4"} // Constant name '%s' does not follow the naming convention 
  FILENM {level="4"} // File name '%s' does not follow the naming convention 
  LIBRNM {level="4"} // Library name '%s' does not follow the naming convention 
  SIGLNM {level="4"} // Signal name '%s' does not follow the naming convention 
  VARLNM {level="4"} // Variable name '%s' does not follow the naming convention 
  CONFNM {level="4"} // Configuration name '%s' does not follow the recommended naming convention 
  CONFIL {level="4"} // Configuration file name '%s' does not follow the naming convention 
}

category RTL_NAMING_MIXED "Naming checks for Verilog and VHDL" default_off
{
  PORTNM {level="4"} // Port name '%s' does not follow the naming convention 
  TBCHNM {level="4"} // File name '%s' does not follow the recommended testbench naming convention%s 
  OUTPNM {level="4"} // Output port name '%s' does not follow the naming convention 
  INPTNM {level="4"} // Input port name '%s' does not follow the naming convention 
  IOPTNM {level="4"} // Inout port name '%s' does not follow the naming convention 
  CLKSNM {level="4"} // Clock signal name '%s' does not follow the naming convention 
  RSTNAM {level="4"} // Reset signal name '%s' does not follow the recommended naming convention 
  DIFCLK {level="2"} // Clock '%s' is being renamed to '%s' 
  DIFRST {level="2"} // Set/Reset '%s' is being renamed to '%s' 
  RENAME {level="4"} // Signal '%s' renamed as '%s' 
  UCOPNM {level="4"} // Unconnected output signal name '%s' does not follow the recommended naming convention 
  NTACHR {level="4"} // Identifier '%s' contains characters that are not allowed 
  FCNLTR {level="4"} // First character of identifier '%s' is not a letter 
  ESCNTA {level="4"} // Identifier '%s' contains escaped names, which should not be used 
  RGOPNM {level="4"} // Output register name '%s' does not follow the recommended naming convention 
  TESTNM {level="4"} // Test mode signal '%s' does not follow the recommended naming convention 
  HIMPNM {level="4"} // High impedance signal name '%s' does not follow the recommended naming convention 
  STMCNM {level="4"} // State machine's state '%s' does not follow the recommended naming convention 
  LTCHNM {level="4"} // Latch '%s' does not follow the recommended naming convention 
  MULSNO {level="4"} // Signal name '%s' does not follow the multiple suffix naming order 
  DIFSIG {level="4"} // Actual port name '%s' of instance '%s' does not follow the recommended naming convention 
}

category RTL_FILEFORMAT_VERILOG "Verilog only File format checks" default_on
{
  VERREP {level="3"} // Repeated usage of identifier or label name '%s' 
  KEYWOD {level="3"} // VHDL reserved word '%s' used as an identifier or label 
  MULTMF {level="3"} // More than one design-unit definition in file '%s' 
  PRTODR {level="4"} // Port declaration '%s' does not follow the port layout order or/and does not match the port list 
  PRTLYO {level="4"} // Ports declared in module '%s' do not follow the port layout order 
}

category RTL_FILEFORMAT_VHDL "VHDL only File format checks" default_on
{
  CASMIS {level="2"} // VHDL object '%s' has case mismatch between instantiation and declaration 
  COMDIF {level="2"} // VHDL object '%s' has mismatch between component and its entity declaration 
  VHDREP {level="3"} // Repeated usage of identifier or label name '%s' 
  STYSUL {level="3"} // Type std_ulogic used for identifier '%s'. Use std_logic to avoid portability issues 
  STYSUV {level="3"} // Type std_ulogic vector used for identifier '%s'. Use std_logic_vector to avoid portability issues 
  STYBIT {level="3"} // Type bit used for identifier '%s'. Use std_logic to avoid portability issues 
  STYBTV {level="3"} // Type bit_vector used for identifier '%s'. Use std_logic_vector to avoid portability issues 
  GENUSD {level="3"} // Generate statement used. This will create portability issues 
  STYBLK {level="3"} // Block statement used. This will create portability issues 
  MXPROC {level="3"} // The architecture '%s' contains more than %d process statements 
  ONELIB {level="2"} // Single library declaration clause used to declare multiple library names 
  INPPRT {level="4"} // Input port '%s' does not follow the layout convention 
  CLKPRT {level="4"} // Clock port '%s' does not follow the layout convention 
  RSTPRT {level="4"} // Reset port '%s' does not follow the layout convention 
  INOPRT {level="4"} // Inout/Buffer port '%s' does not follow the layout convention 
  ARCHID {level="3"} // Architecture name '%s' does not follow recommended naming convention 
}

category RTL_FILEFORMAT_MIXED " File format checks for Verilog and VHDL" default_on
{
  VERCAS {level="2"} // Identifier, label, instance, or module name '%s' reused with a case difference 
  DIRRNG {level="2"} // Inconsistent ordering of bits in range declarations -- should be all %s ranges 
  KYEDIF {level="2"} // EDIF reserved word '%s' used as an identifier or label 
  NEEDIO {level="2"} // Top-level %s '%s' has no inputs/outputs/inouts 
  IDLENG {level="2"} // Identifier name '%s' is not of appropriate length (%d to %d characters) 
  ALOWNM {level="2"} // Identifier '%s' does not follow the recommended naming convention 
  KVHWOD {level="3"} // Verilog reserved word '%s' used as an identifier or label 
  STYVAL {level="3"} // Numeric value '%d' used for identifier '%s'. Use constants to avoid portability issues 
  SUBPLN {level="3"} // The length of subprogram '%s' should not exceed %d lines 
  SYSVKW {level="3"} // SystemVerilog reserved word '%s' used as an identifier or label 
  AMSKWD {level="3"} // AMS reserved word '%s' used as an identifier or label 
  CTLCHR {level="4"} // HDL source line contains one or more control characters 
  UPCLBL {level="4"} // Label '%s' should be written in uppercase 
  DIFFMN {level="4"} // %s name '%s' differs from file name '%s' 
  NOBLKN {level="4"} // Each block should be labeled with a meaningful name 
  SEPLIN {level="4"} // Use a separate line for each HDL statement 
  LCVARN {level="4"} // %s name '%s' uses uppercase characters 
  UCCONN {level="4"} // Lowercase characters used for identifier '%s'. Use uppercase characters for names of constants and user-defined types 
  NOINSN {level="4"} // Each module/gate/primitive instance should be labeled with a meaningful name 
  FILSUF {level="4"} // The file name '%s' is missing a valid HDL file name extension 
  DECLIN {level="4"} // Use a separate line for each HDL declaration 
  MAXLEN {level="4"} // The HDL source line is %d characters, which exceeds the recommended length of %d characters 
  SIGLEN {level="4"} // Signal name '%s' is not of appropriate length (%d to %d characters) 
}

category RTL_CODECOMMENT_VERILOG "Verilog only Code comment checks" default_off
{
  COMSTY {level="4"} // Do not use '%s' comment style in code 
  COMINS {level="4"} // Instantiated cells should have a comment on the same or preceding line 
  COMDIR {level="4"} // Compiler directive '%s' should have a comment on the same or preceding line 
  COMEND {level="4"} // Verilog end/endcase statement should have a comment on the same line 
  COMLTH {level="4"} // Latch declarations should have a comment on the same or preceding line 
}

category RTL_CODECOMMENT_MIXED "Code comment checks for Verilog and VHDL" default_off
{
  COMBLK {level="4"} // Always/process block should have a comment on the same or preceding line 
  COMIOP {level="4"} // Port declarations should have a comment on the same or preceding line 
  COMDEC {level="4"} // Net/signal declarations should have a comment on the same or preceding line 
  COMGTD {level="4"} // Gated clocks should have a comment on the same or preceding line 
  FHDRFT {level="4"} // File header format does not follow the template 
  SHDRFT {level="4"} // Sub-header format for %s does not follow the template 
}

category RTL_CODINGSTYLE_VERILOG "Verilog only coding style checks" default_on
{
  NBCOMB {level="1"} // Non-blocking assignment encountered in a combinational block 
  IFDDEF {level="1"} // Macro '%s' is defined using `define statement in the same verilog file 
  BLKSQB {level="1"} // Blocking assignment encountered in a sequential block 
  CDEFCV {level="1"} // The case items of the case statement cover all the numerical values of the case expression. The default clause is not required 
  BLNBLK {level="1"} // Signal '%s' is assigned via both blocking and non-blocking assignments 
  EVUNTR {level="1"} // Event variable '%s' is never triggered 
  LOGAND {level="1"} // Bit-wise AND in a conditional expression.  Logical AND may have been intended 
  LOGORP {level="1"} // Bit-wise OR in a conditional expression.  Logical OR may have been intended 
  LOGNEG {level="1"} // Bit-wise negation in a conditional expression.  Logical NOT may have been intended 
  MULOPR {level="1"} // Logical %s operator applied to multi-bit operand %s 
  CDEFNC {level="1"} // Case statement %s 
  INCMPC {level="1"} // Not all cases are covered in the parallel case (%d of possible %d covered) 
  CASEZX {level="1"} // Case item expression contains 'x' for a casez statement (useful only in casex statements) 
  OBMEMI {level="1"} // Memory word '%s[%s]' has an index of size %d, which may reference a memory word, which is outside the defined range of the memory (%d words) 
  DIFRNG {level="1"} // Port '%s' with range (%d to %d) is re-declared with a different range (%d to %d) 
  CONSLC {level="1"} // Module '%s' contains a loop with a constant termination conditional expression 
  OOMCAL {level="1"} // Use of an out-of-module task call to %s 
  INPOUT {level="1"} // Primary input port %s of module %s may be driven inside the module 
  SIZMIS {level="1"} // Port '%s' has size mismatch between module instantiation and declaration 
  PRTSYN {level="1"} // Port '%s' is declared using a mix of VLOG95 and VLOG2001 declaration styles 
  UELASG {level="1"} // Unequal length operand in assignment 
  CONDSZ {level="1"} // Expression in condition does not result in a single bit value 
  OPLVNC {level="1"} // '%s' operation between loop variable '%s' and non constant value '%s' 
  PRMVAL {level="1"} // Bit width not specified for parameter '%s' 
  PRMBSE {level="1"} // Base not specified for parameter '%s' 
  MULCAS {level="1"} // Overlapping case item %s 
  NBFUNC {level="2"} // Non-blocking assignment encountered in function '%s' 
  BADSYS {level="2"} // System task %s in %s %s is ignored 
  RTLNOG {level="2"} // Gate instances are not expected in an RTL design 
  RTLNOP {level="2"} // Primitive instances are not expected in an RTL design 
  RTLINI {level="2"} // A variable/signal '%s' in an RTL description is initialized in its declaration 
  PLIFTN {level="2"} // PLI 1.0 function %s in module '%s' is ignored 
  EMPSTM {level="2"} // %s '%s' contains an empty statement 
  EMPBLK {level="2"} // Module %s has an empty block 
  IGNSTR {level="2"} // Signal strength values are being ignored 
  LIBIMP {level="2"} // '%s' is supported only in library cells 
  NOSPEC {level="2"} // Specify block in module %s is ignored 
  INIMEM {level="2"} // Initialization of memory %s in module %s is ignored 
  NOGATE {level="2"} // Module %s contains unsupported gate type %s 
  NOSWTC {level="2"} // Module '%s' contains non-synthesizable switch type '%s' 
  NOWIRE {level="2"} // Module %s contains node %s of unsupported trireg type 
  FSETGV {level="2"} // Function '%s' in module '%s' assigns a value to global variable '%s' 
  FTNNAS {level="2"} // HDL statement after function assignment return statement in function '%s' in module '%s' 
  FUSEGV {level="2"} // Function '%s' in module '%s' uses global variable '%s' 
  TSETGV {level="2"} // Task '%s' in module '%s' assigns a value to global variable '%s' 
  TUSEGV {level="2"} // Task '%s' in module '%s' uses global variable '%s' 
  USEPAR {level="2"} // %s '%s' defined in %s '%s' is unused 
  USEENM {level="2"} // Enum variable '%s' defined in %s '%s' is unused 
  USEWIR {level="2"} // Wire '%s' defined in module '%s' is unused 
  USEREG {level="2"} // Local register variable '%s' defined in %s '%s' is unused 
  USETSK {level="2"} // %s '%s' defined in %s '%s' is unused 
  INTEGD {level="2"} // Delay expression is not an integer 
  CONSTD {level="2"} // Delay is not a constant expression 
  DLNBLK {level="2"} // Delay in non-blocking assignment; delay will be ignored 
  NULPRT {level="2"} // Module '%s' has null formal port(s) 
  UASWIR {level="2"} // Wire '%s' defined in %s '%s' is unassigned, but drives at least an object 
  UASREG {level="2"} // Local register variable '%s' is unassigned, but is read at least once in %s '%s' 
  URDWIR {level="2"} // Wire '%s' defined in %s '%s' does not drive any object, but is assigned at least once 
  URDREG {level="2"} // Local register variable '%s' is not read, but is assigned at least once in %s '%s' 
  URAWIR {level="2"} // Wire '%s' defined in %s '%s' is unused (neither read nor assigned) 
  URAREG {level="2"} // Local register variable '%s' defined in %s '%s' is unused (neither read nor assigned) 
  IMPNET {level="2"} // Net '%s' has an implicit declaration of type '%s' 
  IMPDTC {level="2"} // Expression '%s' implicitly converted to type 'unsigned' from type 'signed' 
  IMPTYP {level="2"} // Expression '%s' implicitly converted to type '%s' from type '%s' 
  IPUFSE {level="2"} // Expression '%s' implicitly converted to type 'signed' from type 'unsigned' 
  IPSFOU {level="2"} // Signal/Constant '%s' implicitly converted to type 'signed' from type 'unsigned' 
  CXZSIG {level="2"} // In module '%s', assignment statements corresponding to '%s' item has a non-constant driver 
  RDBFAS {level="2"} // Register '%s', assigned using blocking assignment, is being read before getting assigned 
  REVROP {level="2"} // Register '%s' is being read/assigned outside the process in which it was assigned using a blocking assignment 
  PRMNAM {level="2"} // Passing of parameters to instance '%s' of module '%s' should be done by name rather than by position 
  EXPIPC {level="2"} // Formal port '%s' of instance '%s' is connected to an expression 
  FORINT {level="2"} // Variable '%s' is not initialized before being incremented/decremented in the for loop 
  FINBLK {level="2"} // The final block of module '%s' does not contain any display statement 
  STRREL {level="2"} // String %s is used in the relational operation '%s' 
  PRMSZM {level="2"} // Parameter '%s' has a size mismatch between module instantiation and declaration 
  POIASG {level="2"} // The result of %s operation may lead to a potential overflow 
  FCWDEF {level="2"} // Redundant case expression -- full_case has a default case 
  SGNUSG {level="2"} // Negative value '%s' assigned to an unsigned variable '%s' 
  OVRDRT {level="2"} // The return statement will override the value assigned to the function name 
  CAFDEF {level="2"} // 'default' is not the last item of case statement 
  BITUNS {level="2"} // Not all bits of constant '%s' are explicitly specified 
  RDNTCX {level="3"} // Casex usage is redundant as none of the case item expression contains 'x', 'z', or '?' 
  RDNTCZ {level="3"} // Casez usage is redundant as none of the case item expression contains 'z' or '?' 
  NOINCD {level="3"} // Compiler directive `include should not be used 
  FNAVPC {level="1"} // Function %s 
  MLPSGS {level="2"} // Multiple %s signals used in flip-flop '%s' 
  RDOPND {level="3"} // Expression contains redundant %s 
  IOPNTA {level="2"} // Port '%s' should not be of mode inout 
  NSTIFD {level="2"} // The ifdef directive has exceeded three levels of nesting 
  SNOROP {level="2"} // Logical/Bitwise OR operator used in the sensitivity list 
  INDXOP {level="2"} // An operator is used in the index of the array '%s' 
  LMULOP {level="2"} // The result of the multiplication operation exceeds '%d' bits 
  NCASEX {level="3"} // 'casex' statement used in module '%s' 
  NFCASE {level="3"} // 'full_case' synthesis directive used in module '%s' 
  NOUNDF {level="3"} // Macro defined using `define statement is not undefined using `undef statement in module '%s' 
  NODEFD {level="3"} // Compiler directive `define should not be used 
  NETDCL {level="3"} // %s '%s' is not declared prior to non-declarative statement(s) or does not follow the recommended declaration sequence 
  BUSREV {level="3"} // Formal '%s[%d:%d]' port is connected in opposite order with the actual port(s) 
  INCLDR {level="4"} // Absolute or relative path specified with the `include compiler directive 
  PIMBIT {level="2"} // Primitive input port (port index : %d ) is connected to signal/expression with multiple bits. Reduction OR logic is being applied 
  IFMULT {level="2"} // Conditional expression '%s' completely overlaps one or more branches of the 'if-else' block 
  LOOPTM {level="2"} // Logic or Relational operation between a loop variable and a non-constant value is repeated more than %d times 
}

category RTL_CODINGSTYLE_VHDL "VHDL only coding style checks" default_on
{
  NOSHFT {level="1"} // Shift operator %s with signed shift count is not synthesizable 
  INTCON {level="1"} // VHDL signal '%s' of type integer is not constrained 
  NEGRNG {level="1"} // Index range of integer signal '%s' is '%d' 
  ENBFLK {level="1"} // Port '%s' should not be of mode buffer or linkage 
  SYNCSL {level="1"} // The sensitivity list of a sequential process does not contain an asynchronous reset 
  MLTCLK {level="1"} // The sequential process contains more than one clock signal 
  CLKEDG {level="1"} // Both edges of clock signal '%s' are used in a sequential process 
  GATCLK {level="1"} // Gated clock signal '%s' is not properly formed/used 
  BADCON {level="1"} // Bad VHDL construct '%s' is being used 
  FTNRET {level="1"} // Function '%s' declared in architecture '%s' does not return a value 
  INVBAS {level="1"} // Invalid base (%d) used in VHDL based literal 
  ENTDCL {level="2"} // A VHDL entity should only consist of generic and port interface lists 
  RTLINI {level="2"} // A variable/signal '%s' in an RTL description is initialized in its declaration 
  GENTYP {level="0"} // The generic '%s' is not of an authorized type 
  PRTTYP {level="2"} // Port '%s' is not of an authorized type (std_logic, std_logic_vector, signed, unsigned) 
  SEQVAS {level="2"} // VHDL variable '%s' is used to register data 
  UNITNM {level="2"} // VHDL design-unit name '%s' is missing on the end line 
  SUBPNM {level="2"} // VHDL %s name '%s' is missing on the end line 
  NOLABL {level="2"} // Process label '%s' is missing as a closing label 
  ALOWID {level="2"} // Signal/variable name '%s' does not follow the active-low naming convention 
  NOALIA {level="2"} // Aliases should not be used 
  SPSIGA {level="2"} // Subprogram assigns a value to signal '%s' 
  SUBTNM {level="2"} // Subtype name '%s' does not contain the type name '%s' 
  NRTLWT {level="2"} // Sensitivity lists should be used instead of wait statements 
  CECONC {level="2"} // Concatenation operation used in conditional expression 
  FENAME {level="2"} // Identifier '%s' updated on negative edge of clock should have '_f' as suffix 
  POIASG {level="2"} // The result of %s operation may lead to a potential overflow 
  GLBSIG {level="2"} // Global signal '%s' is being used in architecture '%s' 
  USRATW {level="2"} // User-defined attribute '%s' is being used in architecture '%s' 
  ONELIB {level="2"} // Single library declaration clause used to declare multiple library names 
  PROSIG {level="2"} // Signal '%s' defined in architecture '%s' is used inside only one process. Use variable instead 
  PRTMOD {level="2"} // Port mode mismatch in '%s' component declaration for port '%s'. Declaration is of mode %s, entity port declaration is of mode %s 
  PUSEGV {level="2"} // Procedure '%s' in design-unit '%s' uses global variable '%s' 
  WRKLIB {level="2"} // Library '%s' should not be referenced in the design 
  CALABL {level="2"} // Concurrent signal assignment used to express behavior requires a label 
  FTNPMC {level="2"} // Parameter '%s' of function '%s' has missing/incorrect mode and/or object class 
  PROPMC {level="2"} // Parameter '%s' of procedure '%s' has missing/incorrect mode and/or object class 
  ENTPMC {level="2"} // No mode specified for port '%s' in entity declaration 
  COMPMC {level="2"} // No mode specified for port '%s' in component declaration 
  LPEXIT {level="2"} // Loop contains an exit or next statement 
  RECTYP {level="2"} // Record type '%s' should not be used 
  USELIB {level="2"} // Library '%s' is declared, but no object is used from it 
  LINPRT {level="2"} // Port '%s' of mode linkage does not form part of the layout convention 
  GLBRES {level="2"} // Global signal '%s' is of resolved type 
  IDXMIS {level="2"} // Port '%s' has index bounds mismatch between component instantiation '%s' and entity declaration '%s' 
  UASVAR {level="2"} // Variable '%s' is unassigned, but is read at least once in %s '%s' 
  URAVAR {level="2"} // Variable '%s' defined in %s '%s' is unused (neither read nor assigned) 
  URDVAR {level="2"} // Variable '%s' is not read, but assigned at least once in %s '%s' 
  UASSIG {level="2"} // Signal '%s' is unassigned, but is read at least once in %s '%s' 
  URASIG {level="2"} // Signal '%s' defined in %s '%s' is unused (neither read nor assigned) 
  URDSIG {level="2"} // Signal '%s' is not read, but assigned at least once in %s '%s' 
  USCNST {level="2"} // Constant '%s' defined in %s is unused 
  FILTXT {level="2"} // File specified with file variable '%s' is not of type TEXT 
  ABSPAT {level="2"} // Absolute path specified for file variable '%s' 
  MAXPRT {level="3"} // Entity '%s' must not have more than %d ports 
  MLITNU {level="3"} // The enumeration type '%s' should not contain more than %d literals 
  STDPKG {level="3"} // The IEEE package '%s' should not be used 
  DESULN {level="3"} // The length of design-unit '%s' should not exceed %d lines 
  INSTLB {level="3"} // Component instance label '%s' exceeds %d characters 
  MISUSC {level="3"} // Library '%s' is used without a 'use' clause 
  PWTHWT {level="2"} // Process block with no sensitivity list is without a wait statement 
  CDNWOT {level="1"} // Case statement without 'when others' clause 
}

category RTL_CODINGSTYLE_MIXED "coding style checks for Verilog and VHDL" default_on
{
  TFARGT {level="1"} // %s/function call argument %d is of wrong type (%s vs. %s) 
  TFARGN {level="1"} // Task/function call has wrong number of arguments 
  UNCONN {level="1"} // %s port '%s' defined in design-unit '%s' is not connected in its instance '%s' 
  UNCONI {level="1"} // Input port '%s' of entity/module '%s' is being used inside architecture/module, but not connected (either partially or completely) in its instance '%s' 
  UNCONO {level="1"} // Port '%s' (which is being used as an output) of entity/module '%s' is being driven inside the design, but not connected (either partially or completely) in its instance '%s' 
  CONSTC {level="1"} // Constant conditional expression encountered 
  CNSTCN {level="1"} // Conditional expression is statically evaluated to %s 
  SHFTNC {level="1"} // Shift by non-constant 
  UELCIT {level="1"} // Unequal length in case item comparison (selector is %d bits, case tag expression is %d bits) 
  UELOPR {level="1"} // Unequal length operand in bit/arithmetic operator %s 
  INTTOB {level="1"} // Assigning a 0 or 1 (32 bits) to a single-bit variable 
  CNSTCI {level="1"} // Case item expression is not a constant 
  TRUNCC {level="1"} // Truncation of bits in a constant.  The most significant bits are lost 
  TRUNCZ {level="1"} // Truncation in constant conversion without a loss of bits 
  ULRELE {level="1"} // Unequal length operands in relational operator (padding produces incorrect result) -- LHS operand is %d bits, RHS operand is %d bits 
  ULCMPE {level="1"} // Unequal length operands in equality operator encountered (padding produces incorrect result). LHS operand is %d bits, RHS operand is %d bits 
  CEXPOR {level="1"} // Case item expression out of range 
  CIMULT {level="1"} // Case item expression covered more than once (covers same case item expression as in line %d) 
  DNGLEL {level="1"} // Ambiguous else statement in the nested if statement. It is recommended to enclose the inner if statement in a begin/end block 
  OOBIDX {level="1"} // %s '%s' (%s) is outside the defined range (%d to %d) 
  NULLRG {level="0"} // In design-unit/module %s, %s %s has null range defined 
  IDXRNG {level="1"} // Loop index is too small for the values it should take 
  CNREAL {level="1"} // Real variable %s is used in %s %s. Real variables are not synthesizable 
  CNINTB {level="1"} // Converting integer to a single-bit constant 
  INFLOP {level="1"} // %s %s possibly contains an infinite loop 
  MISSEL {level="1"} // Signal '%s' missing from sensitivity list of a sequential process/block 
  USESEL {level="1"} // Signal '%s' should not be used in the sensitivity list of a sequential process/block 
  NOTECH {level="1"} // Instance '%s' is instantiating a technology cell. Avoid using technology cells in the design 
  POOBID {level="1"} // Variable index/range selection of '%s' is potentially outside the defined range 
  IDXTSM {level="1"} // Variable index/range selection of '%s' is too small to access its defined range completely 
  NEQPRM {level="1"} // Size mismatch between formal %s parameters of function '%s' 
  ASNRST {level="1"} // %s '%s' has '%s' asynchronous set/reset '%s' as against the recommended '%s' style 
  SNCRST {level="1"} // %s '%s' has '%s' synchronous set/reset '%s' as against the recommended '%s' style 
  CBYNAM {level="1"} // Port connections for instance '%s' of %s '%s' should be made by name rather than by positional ordered list 
  SYNPRT {level="1"} // Output port '%s' is assigned asynchronously 
  CDEATF {level="1"} // Conditional expression always evaluates to %s 
  PBYNAM {level="2"} // Named association should be used in the parameter list for %s call '%s' 
  TIESUP {level="2"} // The output/inout '%s' is tied to supply0/supply1 
  TIELOG {level="2"} // The output/inout '%s' is assigned a constant logic value 
  TFWARG {level="2"} // Too few arguments passed to switch/gate 
  BOUINC {level="2"} // Lower bound of '%s' is not '%d' 
  INPASN {level="2"} // Assignment to a %s %s '%s' is not supported 
  DCLSCP {level="2"} // Variable '%s' defined in scope '%s' is also defined in parent scope '%s' 
  UNDRIV {level="2"} // Primary output/inout '%s'  is not driven in the %s '%s' 
  PUNDRV {level="2"} // Primary output/inout '%s'  is not fully driven in the %s '%s' 
  CNSTLT {level="2"} // Literal '%s' should be replaced with a constant 
  USEFTN {level="2"} // Function '%s' defined in %s '%s' is unused 
  USEPRT {level="2"} // The input/inout port '%s' defined in the %s '%s' is unused (neither read nor assigned) 
  UASPRT {level="2"} // The input/inout port '%s' defined in the %s '%s' is unassigned, but read 
  URDPRT {level="2"} // The input/inout port '%s' defined in the %s '%s' is unread, but assigned 
  SHFTOF {level="2"} // Shift overflow, some bits will be lost 
  REALCM {level="2"} // Real operand used in logical comparison 
  BSINTT {level="2"} // Bit/part select of integer or time variable '%s' encountered 
  EXTEND {level="2"} // Extension of '0' bits in a constant 
  PADMSB {level="2"} // Constant '%s' will be left-padded by %d '0' bits 
  NULCSE {level="2"} // Null statement should not be used in 'when others' clause in the case statement 
  REALCT {level="2"} // Real comparison in case expression 
  WIDSEL {level="2"} // Case statement with no default. Case is too wide to check if all cases are covered 
  NESTIF {level="2"} // Nested ifs. Consider using a %s statement instead 
  MEMSIZ {level="2"} // Memory declaration for '%s' defines a single-bit memory word. Check for error in register declaration 
  OUTINP {level="2"} // Primary output port %s of module %s may be driven outside the module 
  RDREAL {level="2"} // Real literal is rounded to the nearest integer 
  CNTIME {level="2"} // Time variable %s is used in %s %s. Time variables are not synthesizable 
  FTNEXT {level="2"} // Function '%s' must have only one return statement, which is the last statement in the function 
  UNRCHC {level="2"} // Code written after an unconditional return, break or continue statement is not reachable 
  FFASMX {level="2"} // In the specified always/process block, descriptions of flip-flops with and without asynchronous set/reset are mixed. Flip-flops without asynchronous set/reset are: %s 
  AVDREC {level="2"} // Function '%s' is called recursively in %s '%s' 
  LMTSTS {level="2"} // The number of states %d should be limited to %d 
  NUMSUF {level="2"} // Identifier '%s' has a numeric value suffix 
  STYVAL {level="3"} // Numeric value '%d' used for identifier '%s'. Use constants to avoid portability issues 
  SYNSCU {level="3"} // Embedded synthesis script used in the design 
  MPCMPE {level="3"} // Expression uses '%d' operands without parentheses, which exceeds the recommended limit of '%d' operands 
  LDFFPI {level="1"} // The logic depth between %s '%s' and %s '%s' is more than %s 
  DFLDER {level="0"} // Parameters specified are incorrect, check LDFFPI will be ignored 
  TRIWAR {level="2"} // Tristate logic inferred in %s block 
  TBNNAM {level="2"} // Testbench module/entity '%s' does not follow the recommended naming convention 
  TBNSTP {level="2"} // '$stop' used in testbench module/entity '%s' 
  IPRTEX {level="2"} // %s is used in a port expression 
  PRMEXP {level="2"} // %s '%s' used in a port expression 
  USEPKG {level="2"} // Package '%s' is declared but no object is used from it 
}

category RTL_CODINGSTYLE_ASSERTIONS "coding style checks for Assertions" default_off
{
  OOMRNM {level="4"} // Hierarchical reference '%s' passed as the DUT signal to %s '%s' 
  LABMIS {level="4"} // %s identifier '%s' not specified in the corresponding %s statement 
}

category RTL_SIMRACE_VERILOG "Verilog only simulation race condition checks" default_on
{
  RWRACE {level="0"} // A read/write race exists between '%s' and '%s' 
  WWRACE {level="0"} // '%s' is written in more than one process 
  TRRACE {level="0"} // A trigger-propagation race exists between '%s' and '%s' 
  NBCOMB {level="1"} // Non-blocking assignment encountered in a combinational block 
  BLKSQB {level="1"} // Blocking assignment encountered in a sequential block 
  BLNBLK {level="1"} // Signal '%s' is assigned via both blocking and non-blocking assignments 
}

category RTL_SIMSYNTH_VERILOG "Verilog only pre and post-synthesis simulation mismatch checks" default_on
{
  EVTRIG {level="0"} // Always block with no event trigger at the start of the block in module '%s' 
  LPVRMA {level="0"} // The loop variable '%s' is used in multiple always blocks 
  METAEQ {level="0"} // In module %s, %s comparison is treated as %s 
  METACX {level="1"} // In %s '%s', case/casez item expressions evaluating to 'x' are ignored 
  METACZ {level="1"} // In %s '%s', case item expressions evaluating to 'z' are ignored 
  CODNCR {level="2"} // Signal '%s' used in conditional expression has don't care value 
  EXLTRS {level="2"} // Expression used in the conditional logic of tristate buffer '%s' 
}

category RTL_SIMSYNTH_MIXED "Verilog/VHDL pre and post-synthesis simulation mismatch checks" default_on
{
  SYNTXZ {level="0"} // Synthesizing 'x'/'z' values in %s '%s' 
  INCSEL {level="0"} // '%s' missing from sensitivity list 
  METACO {level="0"} // In module %s, %s having 'x'/'z' statically evaluated to false 
  EXTENX {level="1"} // Extension of 'x' bits in a constant 
  EXTENZ {level="1"} // Extension of 'z' bits in a constant 
  SLVMOD {level="1"} // Identifier '%s' appearing in the sensitivity list is modified inside the block 
  SLRANG {level="1"} // Range '%s' used in the sensitivity list is not complete. This could lead to differences in simulation/synthesis 
  SLVUSE {level="1"} // Variable '%s' appearing in the sensitivity list is not used in the %s block 
  MXTSBC {level="1"} // Node '%s' has '%d' tri-state buffers connected, which exceeds the recommended limit of '%d' 
  TSBNTH {level="1"} // Logic driven by tri-state buffer '%s' is not in a separate module 
  XZDVAL {level="2"} // Delay value contains an x/z 
  IGNDLY {level="2"} // Lumped delay in %s '%s' is ignored 
  BITUSD {level="2"} // The bus variable '%s' appears in the sensitivity list, but all the bits are not used within the block 
  HASLEX {level="2"} // The design contains 'synthesis_off/synthesis_on' pragmas 
  MDLDCL {level="2"} // Signal '%s' is declared as '%s'. Use of '%s' can lead to simulation/synthesis mismatch 
  HASPGM {level="2"} // The design contains pragma directives 
  LEXPGM {level="2"} // File contains lexical pragmas, however it is not compiled with pragma/lexpragma command-line option 
  PRBULT {level="2"} // Pragma '%s' is being applied to function 
  FASNSR {level="1"} // In module/design-unit '%s', flip-flop has both asynchronous set and reset signals 
}

category RTL_SYNTH_VERILOG "Verilog only synthesizability checks" default_on synth_only
{
  EVTINV {level="0"} // The specified event expression cannot be synthesized 
  EVTDCL {level="0"} //  
  EVTCTL {level="0"} // Module %s contains non-synthesizable named event control %s 
  NOFREL {level="0"} // %s %s contains non-synthesizable force/release constructs 
  NOWAIT {level="0"} // %s %s contains non-synthesizable wait construct 
  NOFORE {level="0"} // Module '%s' contains non-synthesizable forever construct 
  NOFKJN {level="0"} // %s %s contains non-synthesizable fork-join constructs 
  NFOREV {level="0"} // Module %s contains unsupported forever construct 
  USGTSW {level="0"} // "%s" not supported 
  PTYPUS {level="0"} // In design-unit %s, ports of type "%s" are not supported 
  NONOWF {level="0"} // 'now' function in design-unit %s is not synthesizable 
  AMODNS {level="0"} // Aliased modules are not supported by default. Module %s has duplicate input/inout ports which has effect of aliasing (shorting) two nets 
  INIEVN {level="0"} // Module %s contains non-synthesizable initial block with event control 
  NODSBL {level="0"} // Module %s contains unsupported disable construct 
  NSLOOP {level="0"} // %s %s contains non-static loop 
  NOEVRP {level="0"} // Module '%s' contains non-synthesizable repeat event specification 
  NEVREP {level="0"} // %s %s contains non-synthesizable repeat event specification 
  DPRUSP {level="0"} // Module %s has non-synthesizable defparam statement 
  MULWIR {level="0"} // Module '%s' has wire '%s%s' multi-driven 
  MUDREG {level="0"} // In module '%s', register '%s' is driven in more than one block or process 
  PCAUSP {level="0"} // Module %s has non-synthesizable assign/deassign statements 
  OOMRUS {level="0"} // %s %s has unsynthesizable OOMRs (Out-Of-Module Reference) 
  INAEVT {level="0"} // Module '%s' contains an unsupported intra-assignment event specification 
  USINEV {level="0"} // %s %s contains unsupported intra-assignment event specification 
  INTEVN {level="0"} // Module %s contains unsupported inter-statement event specification 
  CLKMIX {level="0"} // Always block has both level and edge sensitive nodes in its sensitivity list 
  HDLBND {level="0"} // Module '%s' specified through the 'bind_top' option has constructs other than bind statements specified in it. Only bind statements present in this module will be recognized and all other constructs will be ignored by the tool 
  NOIVAL {level="0"} // The initial value is missing in the declaration of constant '%s' 
  UNSINI {level="0"} // Increment/Decrement operators in the port connection of an instance are not supported by the tool. Remodel the design without using these operators 
  VLPMWL {level="0"} // Value of loop variable '%s' modified within the loop 
  TCLKED {level="0"} // %s of signal '%s' used in task '%s' 
  CELVEC {level="1"} // No re-timing will be done for %s cell 
  INFREC {level="1"} // %s %s possibly contains unbounded subprogram recursions 
  LRGARR {level="1"} // The given assignment has a very large variably indexed node on the left hand side, processing the statement may be very time-consuming 
  NOASLD {level="1"} // In module %s, asynchronous load is not inferred for node %s%s 
  MULNBA {level="1"} // In module '%s', register '%s' has multiple non-blocking assignments%s 
  MULBAS {level="2"} // In module '%s', register '%s' has multiple blocking assignments%s 
  UCLPNS {level="1"} // In design-unit '%s', an unconditional loop statement is encountered 
  MULIFF {level="1"} // Always block has multiple event controls with associated 'iff' qualifiers 
  ASNIFF {level="1"} // Always block has an asynchronous control with associated 'iff' qualifier 
  NOCOMB {level="1"} // The node '%s' models a %s in an 'always_comb' block 
  NLATCH {level="1"} // The node '%s' models a %s in an 'always_latch' block 
  NOFLOP {level="1"} // The node '%s' models a %s in an 'always_ff' block 
  MTCOND {level="1"} // The specified case statement with a 'unique' keyword has more than one case item that matches the case expression 
  NTCOND {level="1"} // The specified case statement with a 'unique' or 'priority' keyword does not have any case item that matches the case expression 
  IGPRAG {level="1"} // The tool does not support unique/priority constructs in edge sensitive sequential blocks. This construct will be ignored by the tool 
  NOLOCL {level="2"} // In %s %s, local nodes of task/function %s are initialized 
  INIUSP {level="2"} // %s %s has an initial block or a variable declaration assignment, which is ignored by synthesis tools 
  FINUSP {level="2"} // Module '%s' has a final block, which is ignored by synthesis tools 
  IGNIFF {level="2"} // The 'iff' qualifier, associated with the event expression with no edge specification, is ignored 
  FFLRFR {level="1"} // Flip-flop '%s' has reset/set and logic section in the same '%s' loop 
  FFALWR {level="1"} // The 'if' statement specifying an asynchronous %s '%s' is not the first statement of the always block 
  FFRSTV {level="1"} // The %s signal '%s' is inferred as a vector 
}

category RTL_SYNTH_VHDL "VHDL only synthesizability checks" default_on synth_only
{
  GENTYP {level="0"} // The generic '%s' is not of an authorized type 
  SHRVNS {level="0"} // Shared variables are not synthesizable 
  SHFTOP {level="0"} // In design-unit %s, non-synthesizable shift operation %s is encountered 
  GRDASN {level="0"} // In design-unit %s, non-synthesizable guarded assignments are encountered 
  WAITML {level="0"} // In design-unit %s, multiple edges are specified after wait-until statement 
  SLDIRW {level="0"} // Inconsistent direction in slice discrete range 
  NOEXPN {level="0"} // Exponentiation operator is not synthesizable 
  EXPCHR {level="1"} // Expecting character strings for encoding of user-defined enumeration types in VHDL 
  STDMBC {level="1"} // Call to STD_MATCH will result in boolean-value comparison 
  RECATT {level="1"} // Invalid use of attributes. Incorrect modeling style used 
  NONGEN {level="2"} // No default value specified for generic %s in design-unit %s 
  TOPGEN {level="2"} // Top-level design-unit '%s' has generic '%s' without a default value 
}

category RTL_SYNTH_MIXED "Verilog and VHDL  synthesizability checks" default_on synth_only
{
  RECFLE {level="0"} // No combinational circuit or sequential element could be recognized for %s.%s%s. The sensitivity list will be used as the trigger 
  AMSDES {level="0"} // Analog constructs detected in design %s 
  ARCONV {level="0"} // Array size/shape mismatch in explicit type conversion 
  NULLRG {level="0"} // In design-unit/module %s, %s %s has null range defined 
  NLCRNG {level="0"} // Range evaluates to a null range 
  LPNTEX {level="0"} // The loop range of the specified "for" loop is a null range 
  NSLOOP {level="0"} // %s %s contains non-static loop 
  VARRNG {level="0"} // Left and right bounds must be constant valued expressions 
  IMPFSM {level="0"} // %s %s contains implicit finite-state machine 
  SENCMW {level="0"} // Sensitivity list incomplete for node %s%s in %s. Missing signal(s): %s 
  OUTRNG {level="0"} // Bit/part select %s is outside the defined range %s 
  AWNDEL {level="0"} // %s block with no event trigger at the start in %s %s 
  CLKASY {level="0"} // For node %s in design-unit/module %s, clock signal %s is used in asynchronous control 
  CLKATR {level="0"} // For node %s in design-unit %s, non-synthesizable use of attribute event on %s 
  CLKBED {level="0"} // In module/design-unit %s, clock signal %s, for node %s, is driving data on both edges. Wrong polarity specified 
  CLKEXP {level="0"} // In module/design-unit '%s', for flip-flop '%s', clock is an expression 
  CLKMUL {level="0"} // In module %s, node %s has multiple clocks specified 
  CLKNED {level="0"} // In module/design-unit %s, clock signal %s for node %s does not drive any data. Wrong polarity specified 
  CLKOUT {level="0"} // In module/design-unit '%s', for flip-flop '%s', clock signal '%s' is used as the output 
  CLKSRD {level="0"} // In module/design-unit '%s', clock signal '%s', for flip-flop '%s', is used as %s 
  OPRUSP {level="0"} // Module %s has unsynthesizable '%s' operation 
  RSTEXP {level="0"} // In module/design-unit '%s', for flip-flop '%s', reset is an expression 
  OUTORG {level="0"} // Range constraint violation in design-unit %s 
  PRTNLL {level="0"} // A port of this instance is considered as undriven due to the presence of unsupported construct(s) 
  DRPBLK {level="0"} // The %s is being ignored due to the presence of unsupported construct(s) 
  SFNUNS {level="0"} // System function calls are not synthesizable 
  LOCOFA {level="0"} // Loop condition is false 
  XINASN {level="0"} // In module/design-unit '%s', asynchronous set/reset signals of the flip-flop has value x 
  LATBAS {level="0"} // In module/design-unit %s, latch is assigned by blocking assignments 
  MISNOD {level="0"} // '.*' could not infer any implicit port connection corresponding to port %s. This port will be left unconnected. 
  TXTPNS {level="0"} // In design-unit %s, unsupported procedure call %s from text packages encountered 
  UNSCON {level="0"} // Unsupported declaration/construct, will be ignored: %s 
  USATYP {level="0"} // In design-unit %s, objects of unsupported access type are encountered 
  INTTAG {level="0"} // In module %s, integer tags have been re-sized. This can cause a simulation mismatch 
  NOACCD {level="0"} // In design-unit %s, unsupported access type declaration encountered 
  NOALLD {level="0"} // In design-unit %s, unsupported allocator/deallocate is encountered 
  NOASST {level="0"} // In design-unit %s, unsupported assertion statement is encountered 
  PHYSNS {level="0"} // Literal physical data in design-unit %s is not supported 
  NOCASS {level="0"} // In design-unit %s, unsupported concurrent assertion statement is encountered 
  USFTYP {level="0"} // In design-unit %s, objects of unsupported file type are encountered 
  NODSCN {level="0"} // Disconnect specification in design unit %s not supported 
  USUPTE {level="0"} // Unsupported Table Entry 
  FILENS {level="0"} // File type declarations are not synthesizable and will be ignored 
  FILEOP {level="0"} // In design-unit %s, file operation %s is not synthesizable 
  BOXERR {level="0"} // Module/Design-unit %s is being blackboxed with option %s and simultaneously being glassboxed with the -GB_LIST option 
  TBBERR {level="0"} // Specified top %s is not available in the design hierarchy because instance %s of module %s is blackboxed under option %s 
  TBXERR {level="0"} // Specified top %s is also blackboxed under option %s; therefore this tool is unable to process the specified sub-design 
  IFINST {level="0"} // SystemVerilog Interface instance '%s' is connected to instance '%s' defined as a user-defined top 
  IGNINS {level="0"} // The instance '%s' in module/DU '%s' has been dropped because of errors on the formal ports of the module it is instantiating 
  INVCOE {level="0"} // Expression with invalid concatenation repeat count is being ignored 
  INVGEN {level="0"} // The specified generic/parameter does not have a valid value 
  MNTPMX {level="0"} // The (minimum, typical, maximum) delay expression is ignored, because delays are not considered during functional verification 
  LANERR {level="0"} // Design has wrong language construct for %s package 
  LRGMOD {level="0"} // The total size of the module %s is greater than that can be processed by the tool 
  NCMNOA {level="0"} // Actual argument of type attribute to nc_mirror is not supported. The nc_mirror procedure will be ignored 
  NCMNOD {level="0"} // The %s %s you have passed to nc_mirror call does not exist. The nc_mirror procedure will be ignored 
  NCMOMR {level="0"} // OOMR is not supported for destination in nc_mirror. The procedure will be ignored 
  NCMSLC {level="0"} // Indexed/Slice expressions are not supported as destination or source in nc_mirror 
  NULSLC {level="0"} // Null slice range of slice expression encountered 
  SLDIRE {level="0"} // Inconsistent direction in slice discrete range 
  STMISM {level="0"} // There is a mismatch between the size of connecting variable and the instaniated module port. The instance with the implicit port connection will be ignored. Use explicit named or positional connection syntax 
  UNSPTP {level="0"} // Top-level module/entity has ports of unsupported types 
  UNSYNT {level="0"} // The statement has an unsynthesizable expression and will be ignored by the tool. Modify the design for proper functioning of the tool 
  LHSCON {level="0"} // A constant expression has been encountered on the left hand side of an assignment. The instances of this module will be ignored 
  USTYPE {level="0"} // In design-unit %s, "%s" type is not supported 
  ARSHMM {level="1"} // Array size/shape mismatch 
  COMBLP {level="1"} // In %s %s, combinational loop detected for node %s 
  PACSIG {level="1"} // In design-unit %s, read/write operation is performed on signal "%s" which is declared in package "%s" 
  FNORET {level="1"} // Function has no return value and function return type is unconstrained 
  WNORET {level="1"} // Function has no return value 
  ASNCLD {level="1"} // In module %s, asynchronous load is inferred for node %s%s. A synchronous reset may also be generated, if there is an error in the polarity of the reset signal 
  CELLOP {level="1"} // Cell %s may have combinational loops. Node %s is one of the nodes contributing to this potential loop 
  CLKINP {level="1"} // In %s '%s', clock signal '%s' for flip-flop '%s' is not an input 
  CLKLST {level="1"} // For node %s in design-unit/module %s, assignment under the clock single-edge condition expression must be the last assignment at this level and there must not be any assignment when this condition is false after this assignment 
  CLKMBT {level="1"} // In %s '%s', multi-bits '%s' used as clock for flip-flop '%s' 
  CLKMED {level="1"} // Node %s in design-unit/module %s, is being driven at %s 
  RSTINP {level="1"} // In %s '%s', reset signal '%s', for flip-flop '%s', is not an input 
  BLKBOX {level="1"} // %s %s automatically blackboxed 
  RLRINT {level="1"} // Real literal is rounded to the nearest integer 
  IGNENC {level="1"} // Enum encoding of the enum type is being ignored 
  EMTFNC {level="2"} // Function definition has an empty body 
  PGMENB {level="2"} // Statements from lines %d to %d, in the source file "%s", are under "verification_on/off" pragma. These statements will be processed 
  PGMIGR {level="2"} // Statements from lines %d to %d, in the source file "%s", are under "synthesis_off/on" pragma. The semantics of the design may differ from simulation semantics 
  PGMTSO {level="2"} // Basetype/subtype of "%s" has declaration under "synthesis_off/on" pragma 
  PGMUSO {level="2"} // "%s" has declaration under "synthesis_off/on" pragma 
  SKPSUP {level="2"} // Assignment to a supply0/supply1 net %s in %s %s is ignored 
  EMPBLK {level="2"} // Module %s has an empty block 
  RSTOUT {level="2"} // In module/design-unit %s, for flip-flop %s, reset signal %s is used as the output 
  EMPMOD {level="2"} // Module/Design-unit '%s' is empty 
  IGNATP {level="2"} // Ignoring attribute parameter on attribute %s 
  EXPBBX {level="3"} // Design contains explicitly blackboxed design units 
  EXPGBX {level="3"} // Design contains explicitly glassboxed design units 
  AUTOBX {level="3"} // Design contains automatically blackboxed design units/memories 
}

category FSM "Verilog and VHDL, FSM coding style checks" default_on synth_only
{
  FSMIDN {level="0"} // In module/design-unit '%s', FSM for state register '%s' has been recognized 
  TERMST {level="0"} // In module/design-unit '%s', FSM for state register '%s' has terminal states %s 
  UNRCHS {level="0"} // In module/design-unit '%s', FSM for state register '%s' has unreachable states %s 
  BADFSM {level="1"} // In module/design-unit '%s', FSM for state register '%s' does not adhere to modeling style guidelines 
  PTRMST {level="1"} // In module/design-unit '%s', FSM for state register '%s' has potentially terminal states %s 
  PUNRCS {level="1"} // In module/design-unit '%s', FSM for state register '%s' has potentially unreachable states %s 
  VARTAG {level="1"} // The specified FSM contains a variable case expression in the combinatorial logic 
  VARTRN {level="1"} // The specified FSM contains state transitions expressed as assignments of variables to the state register 
  EXTSEQ {level="1"} // Extraneous logic is present in the sequential portion of the FSM 
  PRMFSM {level="1"} // Parameter is not used to encode state of the FSM 
  EXTFSM {level="2"} // Extraneous logic present in module/design-unit '%s' that encodes an FSM%s 
  TRNMBT {level="2"} // For the specified state '%s', the state value changes by more than one bits on transition to state(s): %s 
}

category DFT "Verilog and VHDL DFT checks" default_on synth_only
{
  CMBPAU {level="0"} // Combinational path detected through '%s' in module/design-unit '%s' 
  ASNCFL {level="0"} // Asynchronous feedback loop detected through set/reset of flip-flop(s) and '%s' in module/design-unit '%s' 
  MULMCK {level="1"} // Multiple master clocks found. Clock '%s' for flip-flop '%s' is derived from master input '%s' while the previously detected clocks were derived from '%s' for flip-flop '%s' 
  FFCKNP {level="0"} // Flip-flop '%s' has clock '%s' which is not derived from master input 
  GTDCLK {level="0"} // Clock gating detected for clock '%s' of flip-flop '%s' 
  FFWASR {level="0"} // Flip-flop '%s' does not have any %s %s 
  FFWNSR {level="0"} // Flip-flop '%s' does not have any set or reset 
  FFASRT {level="0"} // Flip-flop '%s' has %s %s %s 
  ACNCPI {level="0"} // Asynchronous %s '%s' of latch/flip-flop '%s' is not controllable from primary inputs 
  LENCPI {level="0"} // Enable of latch '%s' is not controllable from primary inputs 
  CLKINF {level="0"} // Clock '%s' has associated DFT violations. It was inferred as clock because it drives the %s pin of %s '%s' 
  CLKDAT {level="0"} // Clock signal '%s' drives the data pin of flip-flop '%s' 
  CLKLDT {level="0"} // Clock signal '%s' drives the data pin of latch '%s' 
  CDFDAT {level="0"} // Clock signal '%s' drives the data pin and clock pin %s of flip-flop '%s' 
  CDLDAT {level="0"} // Clock signal '%s' drives the data pin and clock pin %s of latch '%s' 
  CAAFSR {level="0"} // Clock signal '%s' drives a set or reset pin of flip-flop '%s' 
  CACSRF {level="0"} // Clock signal '%s' drives set/reset and clock pin %s of flip-flop '%s' 
  CACSRL {level="0"} // Clock signal '%s' drives set/reset and clock pin %s of latch '%s' 
  CAALSR {level="0"} // Clock signal '%s' drives a set or reset pin of latch '%s' 
  RSTDAT {level="0"} // Reset signal '%s' drives the data pin of %s '%s' 
  LATINF {level="0"} // Process/always block models a latch, or signal '%s' is not assigned a value in all branches 
  LCNSTD {level="0"} // Inferred latch '%s' has constant data 
  FFCSTD {level="1"} // Inferred flip-flop '%s' has a constant data input 
  MRSTDT {level="1"} // Mix of synchronous and asynchronous set/reset found. Synchronous set/reset detected in '%s' and asynchronous set/reset detected in '%s' 
  TPOUNR {level="1"} // Output '%s' of top-level module is not a register 
  NEFLOP {level="1"} // Flip-flop '%s' is triggered at the negative edge of clock '%s' 
  SLNOTP {level="1"} // Enable pin '%s' of the tristate buffer (driving inout pin '%s') is not directly controllable by primary input(s) 
  JKFFDT {level="2"} // Flip-flop '%s' models a JK flip-flop 
  LATRAN {level="2"} // Latch '%s' is %s enable while its driving flip-flop '%s' is also sensitive at %s edge of the clock 
  TCDFDT {level="0"} // In test mode, clock signal '%s' drives the data pin and clock pin %s of flip-flop '%s' 
  TCDLDT {level="0"} // In test mode, clock signal '%s' drives the data pin and clock pin %s of latch '%s' 
  TCKDAT {level="0"} // In test mode, clock signal '%s' drives the data pin of flip-flop '%s' 
  TCKLDT {level="0"} // In test mode, clock signal '%s' drives the data pin of latch '%s' 
  TMSCFF {level="0"} // Test mode signal '%s' is directly connected to %s '%s' of %s '%s' 
  ASRTSC {level="0"} // In test mode, asynchronous set/reset%s of flip-flop/latch '%s' is not controllable during scan capture 
  ASRTCL {level="0"} // In test mode, asynchronous set/reset%s of flip-flop/latch '%s' is active during scan shift 
  ASRTCK {level="0"} // Test clock '%s' drives asynchronous set/reset%s of flip-flop/latch '%s' 
  SEICLK {level="0"} // Clock '%s', not bypassed in scan shift mode, is connected to clock pin of following flip-flop(s) 
  SCICLK {level="0"} // Clock '%s', not bypassed in scan capture mode, is connected to clock pin of following flip-flop(s) 
  SMTCLK {level="0"} // Clock '%s', driven by %d test clock(s) in scan mode, is connected to clock pin of following flip-flop(s) 
  TXCNOP {level="0"} // Output '%s' of tie-x cell '%s' is connected to '%s' during scan mode 
  MEMNOP {level="0"} // Output '%s' of memory cell '%s' is connected to '%s' during scan mode 
  OUTMNR {level="0"} // Output '%s', of memory cell '%s', is not registered 
  INPMNR {level="0"} // Input '%s', of memory cell '%s', is not registered 
  MCKNDB {level="0"} // Write clock '%s' of memory cell '%s' is not disabled during test mode 
  WENNDB {level="0"} // Write enable '%s' of memory cell '%s' is not disabled during test mode 
  TENNOD {level="0"} // In test mode, tristate buffer '%s' does not drive 'Z' during scan shift operation 
  TENNOC {level="0"} // In test mode, enable of tristate buffer '%s' is not controllable during scan shift operation 
  RSTEDG {level="0"} // In test mode, signal '%s' is acting as active high set/reset as well as active low set/reset 
  NOTCLK {level="0"} // The following flip-flops, in clock domain '%s', are not controlled by any test clock 
  MULTCK {level="0"} // In test mode, test domain '%s' drives multiple clock domains 
  LTCHNT {level="1"} // Latch '%s' is not transparent in test mode 
  NOTSCN {level="0"} // Flip-flop '%s' is not scannable 
}

category STRUCTURAL "Verilog/VHDL structural checks" default_on synth_only
{
  LFLTSE {level="0"} // Latch '%s' is feeding latch '%s' having same enable%s 
  LFFTNE {level="0"} // Latch '%s' is feeding flip-flop '%s' which is triggered at the negative edge of latch enable%s 
  MLTDRV {level="0"} // Signal/register '%s' has multiple drivers 
  SUTHRU {level="0"} // Possible shoot-through due to this assignment 
  GLTASR {level="0"} // Combinatorial logic present in the path of asynchronous %s '%s' may lead to a glitch. One such affected flip-flop is '%s' 
  FDTHRU {level="1"} // Feedthrough detected from input '%s' to output '%s' 
  DFDRVS {level="1"} // Drivers of sub-parts of vector '%s' are not of same type 
  INFNOT {level="1"} // Ignoring %s '%s' with no fanout to module/design-unit outputs or child instances 
  CBPAHI {level="2"} // Combinatorial path crossing multiple units drives '%s' 
  DALIAS {level="2"} // Aliased constructs found. %s '%s' and '%s' have same drivers 
  NUMDFF {level="2"} // Number of single-bit D flip-flops present in the hierarchy is %s 
  PRTDUP {level="2"} // There are ports with the same name '%s' in module '%s' 
  ATLGLC {level="1"} // Glue logic inferred in top-level module/design-unit '%s' 
  EDGMIX {level="1"} // Both edges of clock signal '%s' used in %s 
  SYNASN {level="2"} // The module/design-unit '%s' contains synchronous as well as asynchronous logic 
  MCKDMN {level="2"} // In instance '%s', clocks belong to different clock domains 
  CLKGNP {level="2"} // The clock generation logic is placed in module/design-unit '%s', which also contains extraneous logic 
  CLKGNH {level="2"} // The clock generation logic for clock '%s' is not at the same or a higher hierarchical level as the module/design-unit to which the clock applies 
}

category CLOCKDOMAIN "Verilog/VHDL clock domain checks" default_on synth_only
{
  CLKDMN {level="0"} // Signal from clock domain '%s' is crossing into domain of clock '%s' at flip-flop '%s' without proper synchronization 
  INSYNC {level="1"} // %s based synchronizer detected at '%s' synchronizing from clock domain '%s' to clock domain '%s' 
  NSYLAT {level="1"} // Some instances of latch '%s' are not used as synchronizer 
}

category SCANCHAIN "Verilog/VHDL Netlist level scan chain checks" default_on
{
  PCNOTC {level="0"} // Partial scan chain (with formal '%s') in instance '%s', is not part of any of the complete scan chains of its parent scope 
  SLENEX {level="0"} // Scan chain (from '%s' to '%s') length is '%d' which exceeds the limit '%d' 
  SCNLEN {level="2"} // Scan chain (from '%s' to '%s') has length '%d' 
  WRSCNL {level="0"} // 'scanlengthlimit' is incorrectly specified in local.def file, taking its default value 
  DSCNCK {level="0"} // A part of scan chain starting from port '%s' is found to have clock '%s' in instance '%s', which is different from scan clock '%s' 
  DSCNEN {level="0"} // A part of scan chain starting from port '%s' is found to have scan enable '%s' in instance '%s', which is different from scan enable '%s' 
  NONSCN {level="0"} // All the instances of module/design-unit '%s' are not scannable 
}

category PD_NONSYNTH "Category of all the checks which are a cause of non-synthesizability of DU on Palladium, hence redirection to NC-Sim (simulator)" default_off synth_only
{
  ARSHMM {level="1"} // Array size/shape mismatch 
  AORAGG  // Array of record aggregates are not currently supported for arrays of unconstrained types. Remodel the design 
  AORCON  // Array of record created using concatenation of arrays of records is not supported. Remodel the design 
  DOMRNS  // Disable OOMR not supported 
  EMTFNC {level="2"} // Function definition has an empty body 
  GRDASN {level="0"} // In design-unit %s, non-synthesizable guarded assignments are encountered 
  NONOWF {level="0"} // 'now' function in design-unit %s is not synthesizable 
  MOMRNS  // OOMR assignment to an element of a multi-dimensional array or a verilog memory is not supported. Remodel your design 
  MUSOMR  // Memory has unsupported OOMR assignments in the design 
  NOPATT  // Pre-defined attribute %s in design-unit %s is not synthesizable 
  NULSTR  // Null strings are not supported 
  RNGEXP  // Type range has unsupported expressions. Only static constant expressions are allowed in the range 
  SFNUNE  // System function calls are not supported 
  SOMRNE  // OOMR subprogram (function/task) call is not supported 
  UNCMDL  // Unbound components exist with same name %s and different number of ports/port size 
  UNKGEN  // Design-unit/Module %s has Generic/Parameter of unsupported type 
  UXUASR  // Use of 'X' in assertions is not supported 
  UZUASR  // Use of 'Z' in assertions is not supported in scenarios other than bus-float checks 
  WAVFRM  // Multiple waveform elements are not supported. Existing in %s %s, node %s 
  INFLOP {level="1"} // %s %s possibly contains an infinite loop 
  INFREC {level="1"} // %s %s possibly contains unbounded subprogram recursions 
  NLCRNG {level="0"} // Range evaluates to a null range 
  RECATT {level="1"} // Invalid use of attributes. Incorrect modeling style used 
  UNOMSU  // OOMR on function/task %s using nodes outside the subprogram scope is not supported 
  VARRNG {level="0"} // Left and right bounds must be constant valued expressions 
  IMPFSM {level="0"} // %s %s contains implicit finite-state machine 
  CELLOP {level="1"} // Cell %s may have combinational loops. Node %s is one of the nodes contributing to this potential loop 
  AMODNS {level="0"} // Aliased modules are not supported by default. Module %s has duplicate input/inout ports which has effect of aliasing (shorting) two nets 
  CNREAL {level="1"} // Real variable %s is used in %s %s. Real variables are not synthesizable 
  INIEVN {level="0"} // Module %s contains non-synthesizable initial block with event control 
  TFWARG {level="2"} // Too few arguments passed to switch/gate 
  CLKATR {level="0"} // For node %s in design-unit %s, non-synthesizable use of attribute event on %s 
  CLKLST {level="1"} // For node %s in design-unit/module %s, assignment under the clock single-edge condition expression must be the last assignment at this level and there must not be any assignment when this condition is false after this assignment 
  CLKMED {level="1"} // Node %s in design-unit/module %s, is being driven at %s 
  ARCONV {level="0"} // Array size/shape mismatch in explicit type conversion 
  NSLOOP {level="0"} // %s %s contains non-static loop 
  EVTCTL {level="0"} // Module %s contains non-synthesizable named event control %s 
  USINEV {level="0"} // %s %s contains unsupported intra-assignment event specification 
  NEVREP {level="0"} // %s %s contains non-synthesizable repeat event specification 
  NFOREV {level="0"} // Module %s contains unsupported forever construct 
  NODSBL {level="0"} // Module %s contains unsupported disable construct 
  NOWAIT {level="0"} // %s %s contains non-synthesizable wait construct 
  UNDSBL  // Module %s contains unsupported style of disable construct 
  USGTSW {level="0"} // "%s" not supported 
  USSTRG  // Nodes of composite data types, having std_ulogic type or types derived from std_ulogic in array ranges is currently not supported 
  NULRGE  // Node of null range is encountered 
  NOGATE {level="2"} // Module %s contains unsupported gate type %s 
  UUSTYP  // In design-unit %s, use of "%s" type is not synthesizable 
  NBFUNC {level="2"} // Non-blocking assignment encountered in function '%s' 
  SYSVNC  // SystemVerilog construct: '%s' is unsupported by HDL-ICE, the RTL compiler of Palladium and the corresponding module would be redirected to NC-Sim 
}

category HDLICE_NOSUPP "Category of all the checks which are unsupported by HDL-ICE hence lead to redirection to SA Bin" default_off synth_only
{
  MUDREG {level="0"} // In module '%s', register '%s' is driven in more than one block or process 
  MULWIR {level="0"} // Module '%s' has wire '%s%s' multi-driven 
  HISTUS  // The System task/function '%s' is not supported by HDL-ICE, the RTL compiler of Palladium 
  SPDCLK  // Module 'SPDclkgen2' should be directed to SA 
  HIINIT  // The initial blocks are not supported by HDL-ICE, the RTL compiler of Palladium 
  NOFREL {level="0"} // %s %s contains non-synthesizable force/release constructs 
  UNDASS  // Deassign statements are not supported by HDL-ICE, the RTL compiler of Palladium 
  SYSVAP  // SystemVerilog construct: '%s' is not supported by HDL-ICE, the RTL compiler of Palladium 
  NOFKJN {level="0"} // %s %s contains non-synthesizable fork-join constructs 
}

category PALLADIUM "Category of all the checks to qualify design to run on Palladium" default_off synth_only
{
  MEMHIR  // A hierarchical reference to the design memory '%s' found in the testbench 
  OOMRDT  // OOMR '%s' from synthesizable module '%s' to non-synthesizable module '%s' found 
  OOMRTD  // OOMR '%s' from non-synthesizable module '%s' to synthesizable module '%s' found 
  NOSPEC {level="2"} // Specify block in module %s is ignored 
  TIMCHK  // Timing checks done in the testbench on the design input/output '%s' 
  DLYWIR  // Delayed net '%s' which is connected to input port '%s' is being driven through timing check '%s' 
  UNSSTR  // Unsupported %s strength '%s' passed between testbench and design '%s' through input/inout port '%s' 
  TRISTR  // For an interface net, all tristate drivers must have both 'strong' values 
  INTCLK  // An internal clock '%s' is detected in the design 
  CKFREQ  // The testbench generated a clock '%s' with Time Period '%d.%02d' '%s' 
  TBZCON  // Net '%s', driven by the output interface net '%s' of the design, is tested for 'Z' 
  TBXZDV  // The input/inout port '%s' of the design '%s' is driven by 'X' or 'Z' %s '%s' 
  TBZOMR  // The signal '%s' of design '%s' is driven by 'X' or 'Z' through out of module reference from the testbench 
  BADKWD  // Usage of the keyword "QTSACELL" in the module/DU name is incorrect 
  CNREAL {level="1"} // Real variable %s is used in %s %s. Real variables are not synthesizable 
  MEMLOP  // Memory '%s' is read or written within a loop in the design 
  SHFLAR  // The shift register has large shift_by operator '%s' in the design 
  HISTIG  // A System Task/Function '%s' in module '%s' will be ignored by HDL-ICE, the RTL compiler of Palladium 
  NSDTOP  // The DUV top '%s' is non-synthesizable 
  NSSCDT  // The SystemC DUV top '%s' is non-synthesizable 
  SYNTNC  // While doing partitioning for Co-simulation flow, the synthesizable %s '%s' is directed to NC-Sim because its hierarchical path has behavioral source 
  ICEVHD  // Module '%s' is directed to HDL-ICE despite the presence of constructs which are unsupported by HDL-ICE, because its hierarchical path contains VHDL entity 
  VLOGSA  // Module '%s' is directed to sa bin because a module below its hierarchy was redirected to sa bin 
  SAFORC  // %s '%s' cannot be forced to SA bin because it is in VHDL hierarchy 
  HDLFRC  // Module '%s' cannot be forced to HDL-ICE because a module under its hierarchy was directed to sa bin 
  SPDVHD  // Module 'SPDclkgen2' is found beneath VHDL. Redirected to HDL-ICE 
  NODLPD  // Interface signal '%s' between NC and Palladium has no driver or load in the palladium emulator 
  NNSNMD  // Non-synthesizable module/DU '%s' encountered in DUV 
  FCDTOP  // The synthesizable module/DU top '%s' is forced to NC-Sim (simulator) bin 
  FRCDUV  // The synthesizable %s '%s' under DUV top is forced to NC-Sim (simulator) bin 
  PGMIGR {level="2"} // Statements from lines %d to %d, in the source file "%s", are under "synthesis_off/on" pragma. The semantics of the design may differ from simulation semantics 
  PGMTSO {level="2"} // Basetype/subtype of "%s" has declaration under "synthesis_off/on" pragma 
  PGMUSO {level="2"} // "%s" has declaration under "synthesis_off/on" pragma 
  CONSTD {level="2"} // Delay is not a constant expression 
  DLNBLK {level="2"} // Delay in non-blocking assignment; delay will be ignored 
  IGNDLY {level="2"} // Lumped delay in %s '%s' is ignored 
  SYNTXZ {level="0"} // Synthesizing 'x'/'z' values in %s '%s' 
  XZDVAL {level="2"} // Delay value contains an x/z 
  METACX {level="1"} // In %s '%s', case/casez item expressions evaluating to 'x' are ignored 
  METACZ {level="1"} // In %s '%s', case item expressions evaluating to 'z' are ignored 
  METACO {level="0"} // In module %s, %s having 'x'/'z' statically evaluated to false 
  CASEZX {level="1"} // Case item expression contains 'x' for a casez statement (useful only in casex statements) 
  V2CONF  // Configuration file '%s' found for module '%s' is not supported by HDL-ICE, the RTL compiler of Palladium 
  VHDOMR  // The OOMR '%s' pass through VHDL instance '%s' 
  TESDLY  // %s '%s' contains delay statement in initial block. '%s' might be a part of testbench 
  DIFBIN  // The file '%s' comprises of modules/DUs/UDPs which are partitioned in different bins 
  MISTOP  // Instance top not specified on the command-line for performing Acceleration Policy checks 
  NOEXMT  // %s '%s' specified in the input file '%s' does not exist 
  NONBIN  // %s '%s' specified in the input file '%s' is directed to a non-existing  bin '%s' 
  MISFLD  // The '%s' field is missing for the %s '%s' in the input file '%s' 
  EXTCHR  // Extra characters found for %s '%s' at the end of the line in input file '%s' 
  VHDLSA  // The VHDL design-unit '%s' has been forced to Palladium simulation acceleration compiler (sa) in input file '%s' 
  MULENT  // Multiple entries for redirection are found for %s '%s' in the input file '%s' 
  MULOPT  // The option %s has been specified multiple times on the command line. Only the first %d specification(s) will be considered 
  MUINSD  // There are multiple instances of the same module/DU '%s' being used as the design top 
  SHRVNS {level="0"} // Shared variables are not synthesizable 
  SHVUNS  // In design-unit %s, use of shared variables is not synthesizable 
  PD_NONSYNTH   // Category of all the checks which are a cause of non-synthesizability of DU on Palladium, hence redirection to NC-Sim (simulator)
  HDLICE_NOSUPP         // Category of all the checks which are unsupported by HDL-ICE hence lead to redirection to SA Bin
  RTL_SIMRACE_VERILOG   // Verilog only simulation race condition checks
}

category ALL_TOOL "HAL usage errors" default_on
{
  SYSTMC  // Design contains SystemC(r) objects. HAL performs only linting checks on SystemC(r) objects 
  CMDNIM  // %s is not yet implemented 
  BADDEF  // Error reading message definitions file: %s 
  BADINF  // %s 
  BADARG  // Incorrect argument '%s' specified with command-line option '%s' 
  BADINP  // Tool cannot proceed further due to above errors in input files 
  NOCARG  // %s 
  ONPARM  // %s 
  LDFAIL  // Unable to load dynamic library %s:%s 
  LDLOOK  // Unable to locate startup routines in %s: %s 
  BBFAIL  // Unable to write to %s 
  FILOPE  // Unable to open "%s" for %s 
  BADTOP  // Unable to locate instance '%s' (specified by %s) in the design. This option will be ignored 
  NOTCMP  // Scope specified by -TOP '%s' is not a %s instance 
  TOOMNC  // More than one cell specified 
  BDARGF  // Command-line argument file '%s' could not be opened for reading (%s) 
  MISSCL  // Missing cell name for the build process 
  NOSNAP  // Snapshot '%s' does not exist in the libraries 
  NOWORK  // %s work library not found/defined 
  PRTSNP  // Design is partially elaborated. Connectivity information may not be complete 
  NOLICI  //  
  NOLICN  //  
  REARGF  // Command-line argument file '%s' included more than once 
  DUPARG  // Snapshot name provided by both ncverilog and the command-line. The snapshot name provided by command-line will be ignored 
  NOARGX  // Missing command-line argument file after -FILE option 
  BADCAT  // Category name '%s' is not recognized 
  REGEXB  // The naming convention pattern %s is not a legal regular expression 
  NOREGX  // The pattern parameter for message %s is null. Any name will match 
  BADRNG  // markSensListVarBits: ERROR -- range could not be determined for variable %s[%d:%d] 
  BADNAM  // %s: ERROR -- unsupported type '%s' 
  BDDUSP  // Badly formed design-unit specification %s 
  NLVSUF  // The hdl.var variable VERILOG_SUFFIX is defined, but is not a list 
  NOTEMP  // Cannot open/create temporary file '%s' for writing 
  CSTUDS  // Stack size has been limited 
  NOROOT  // Unable to locate Cadence installation root directory 
  NOHDLF  // No valid HDL source files provided 
  CNOTPR  // %s in file '%s' has multi-line comment, which does not end anywhere 
  COFILE  // Cannot open source file '%s' 
  MISAGO  // A '%s' option was found without an argument and will be ignored 
  NOSUPP  // HAL does not work in combination with 64-bit NC binaries 
  OBSOPT  //  
  UODIFW  // Unable to open design info file '%s' for writing 
  BLKERR  // Blackbox unit '%s' is not present in the design 
  LNTERR  //  
  NORUCY  // The argument '%s' in lint pragma does not map to any rule or category 
  PROTEC  // Protected design-unit '%s' encountered in the hierarchy and will not be processed by the tool 
  PLSNAP  // Snapshot '%s' does not exist (platform mismatch), rebuild 
  RVSNAP  // Snapshot '%s' does not exist (version mismatch), rebuild 
  SSNFND  // Snapshot '%s' does not exist in the libraries 
  SSNTRD  // %s not read 
  MULTOP  // The snapshot contains multiple top-level modules. Use the -TOP option to specify the hierarchy to be processed 
  AORAGG  // Array of record aggregates are not currently supported for arrays of unconstrained types. Remodel the design 
  AORCON  // Array of record created using concatenation of arrays of records is not supported. Remodel the design 
  BLKPAT  // Unsupported regular expression %s specified in blackbox file %s 
  DOMRNS  // Disable OOMR not supported 
  GBXERR  // Glassbox unit %s is not present in the design 
  IGNASR  // Expression creation error. The assertion/sequence/group in the module/design-unit %s will be ignored 
  IMPFNS  // Impure functions are not supported. The keyword impure will be ignored and the function will be treated as a pure function 
  INVASP  // Ignoring invalid enum encoding specification 
  INVCON  // Expression with invalid concatenation repeat count is being ignored 
  MOMRNS  // OOMR assignment to an element of a multi-dimensional array or a verilog memory is not supported. Remodel your design 
  NCDRNG  // In design-unit %s, unsupported non-constant discrete range is encountered 
  NMDINS  // Unable to find module for instance %s 
  NOBBFL  // Unable to open explicitly specified blackbox file for reading: %s 
  NOGBFL  // Unable to open explicitly specified glassbox file for reading: %s 
  NOCACC  // Design not compiled with connectivity access information. Pass -access +C flag to ncelab 
  NOFILO  // Unable to open file for writing %s 
  NOIDEN  // The actual parameter of the subprogram call on the formal part of the component instantiation statement is not an identifier 
  NOPATT  // Pre-defined attribute %s in design-unit %s is not synthesizable 
  NULRGW  // In design-unit/module %s, node %s has a null range defined. This node is being turned to dummy node because this design-unit/module is explicitly blackboxed 
  NULSTR  // Null strings are not supported 
  PERCIN  // The tool has encountered error(s) while processing instance %s. This instance will be ignored. 
  RNGEXP  // Type range has unsupported expressions. Only static constant expressions are allowed in the range 
  SHVUNS  // In design-unit %s, use of shared variables is not synthesizable 
  SOMRNE  // OOMR subprogram (function/task) call is not supported 
  SOMRNF  // OOMR subprogram (function/task) call is not supported 
  TOPERR  // The specified top-level instance: %s, is not present in the design 
  TOUTDE  // Design timed out after %s seconds 
  SUDPNS  // Modeling style of sequential UDP in module %s is not supported 
  UNHNDL  // Unhandled case in module/design-unit %s 
  UNKCIN  // Component instance is not fully bound (%s) 
  UNCINW  // Component instance is not fully bound (%s) 
  UNKGEN  // Design-unit/Module %s has Generic/Parameter of unsupported type 
  UNKLNG  // %s : Unknown language 
  UNKPEX  // addVerilogPortExpr : Unknown Port Expression %s 
  UNKWND  // findFormalType : Unknown node %s 
  UNSOMR  // OOMR on unsupported construct 
  UNSOPR  // Unsupported operator encountered %s. This expression will be ignored 
  UNSUPF  // An internal error occurred (may be due to an unsupported feature/function/operator): %s : %s 
  UNSVLG  // Unsupported Verilog 2001 feature: %s 
  USDUNT  // Unsupported design-unit %s encountered 
  USFDEC  // findFormalDecl: Unsupported call %s 
  USFENA  // Unsupported formal expression in named association 
  USRATR  // User-defined attribute in design-unit %s is not synthesizable 
  USRECR  // Recursive records are not supported 
  USTCOV  // In design-unit %s, type conversion %s is not supported 
  UUSCON  // Unsupported declaration/construct used. Cannot proceed further: %s 
  UUSTYP  // In design-unit %s, use of "%s" type is not synthesizable 
  WAVFRM  // Multiple waveform elements are not supported. Existing in %s %s, node %s 
  UNOMSU  // OOMR on function/task %s using nodes outside the subprogram scope is not supported 
  IGNCIN  // In %s '%s', initialization to node '%s' is ignored 
  CEVTNS  // Event on complex expression not supported. Complex expression %s in the event expression is replaced by %s, which is assigned the original complex expression 
  IGNCON  // Due to the above-mentioned error/warning, the design construct ( %s ) in which this error occurred will be ignored 
  FMLPDR  // Due to the above-mentioned error the formal port list of the %s is being dropped 
  NOSUBP  // Subprogram body not found 
  USENAR  // Array types using encoded enumeration type to specify range bounds are unsupported 
  USENRG  // Nodes of composite data types, having encoded enumeration type in array ranges is currently not supported 
  VHDRCE  // Race condition checks in HAL are supported for Verilog designs only, -RACES option is being ignored 
  BLDSTP  // Further processing stopped because of synthesizability errors 
  UNOPNF  // Unable to open %s file '%s' 
  PGMSSO  // The subprogram body of "%s" is under "synthesis_off/on" pragma 
  PGMCIG  // The design construct is under "synthesis_off/on" pragma. The semantics of the design may differ from simulation semantics 
  MULOPT  // The option %s has been specified multiple times on the command line. Only the first %d specification(s) will be considered 
  IPROTC  // Design contains protected HDL code. This tool does not analyze designs having protected HDL 
  PROTCT  // Ignoring instance '%s' as its module/design-unit is protected 
  TOPROE  // Design will not be analyzed because top-level module/design-unit is completely protected 
  NOSTAN  // The specified FSM cannot be analyzed for terminal and unreachable states 
  MIXGEN  // HAL does not support VHDL instantiation in a Verilog for-generate loop 
  UNSV2K  // The verilog-2001 construct : "%s" is not supported by the tool 
  SYSMOR  // Processing stopped because virtual memory limit exceeded 
  HALSIG  // Unable to proceed further due to a critical error. Contact Cadence Design Systems for resolution to this problem 
  CFESIG  // Unable to proceed further due to a critical error while processing %s '%s'. Contact Cadence Design Systems for resolution to this problem 
  SCPNFD  // Scope '%s' not found 
  PINNFD  // Pin '%s' not found in scope '%s' 
  MISVAL  // %s value not specified or is incorrect for pin '%s' in '%s' 
  NCDOMN  // Pin '%s' has '%s' specified as clock domain, but it is not specified as a clock or test clock 
  NOTSMD  // In scope '%s', pin '%s' set as 'logic_dbist', but not as test_mode pin 
  LOOPSZ  // Loop has more than %d iterations. Processing of loop may take some time, kindly wait 
  VLGMEM  // Module %s has Verilog memories. For large memories, processing may take some time 
  DISCAT  // The category '%s' in lint pragma attached to the above line, is disabled, which was earlier enabled 
  DISRUL  //  The rule '%s' in lint pragma attached to the above line, is disabled, which was earlier enabled 
  ENARUL  //  The rule '%s' in lint pragma attached to the above line, is enabled, which was earlier disabled 
  ENACAT  //  The category '%s' in lint pragma attached to the above line, is enabled, which was earlier disabled 
  NOCELL  // Cell corresponding to module '%s' is not found in synthesis library 
  UNLLIB  // Unable to load synthesis library '%s' 
  NOPORT  // No port is found in the design for pin '%s' in cell '%s' in synthesis library '%s' 
  NOPINL  // No pin is found in synthesis library '%s' for port '%s' of module/design-unit '%s' 
  NOCONW  // %s condition is not found for flip-flop/latch in the cell '%s' in synthesis library '%s' 
  NOCONF  // %s condition is not found for flip-flop/latch in the cell '%s' in synthesis library '%s' 
  UNSUOP  // Unable to determine the operator type in expression '%s' in cell '%s' in synthesis library '%s' 
  MAPLIB  // %s '%s' is mapped from library '%s' 
  FORGEN  // The instances in the given for-generate block will be unrolled %d times. Such processing takes time, kindly wait 
  GLSBOX  // %s %s automatically glassboxed 
  RULREP  // %s %s 
  SENNOT  // Test mode checks will not be performed as scan enable pin is not present in the design info file 
  UNKNRL  // Rule/message tag '%s' is not known to hal 
  STPUNK  // Definition file contains unknown rules. Either remove these rules or set parameter 'allow_only_hal_and_custom_rules' to 'no' 
  SYSIGN  // SystemVerilog '%s' construct is not supported by the tool. This will be ignored 
  SYSVIG  // SystemVerilog '%s' construct is not supported by the tool. This will be ignored 
  SYSVPS  // SystemVerilog construct: '%s' is not fully supported by HAL 
  BGOLAP  // Design-unit/Module '%s' specified for blackboxing overlaps with design-unit/module '%s' specified for glassboxing 
  LPNOFL  // -lps_verbose option will be ignored because -lps_cpf option is not specified 
}

category RMM "All checks complying to Reuse Methodology Manual" default_on
{
  CMBPAU {level="0"} // Combinational path detected through '%s' in module/design-unit '%s' 
  ASNCFL {level="0"} // Asynchronous feedback loop detected through set/reset of flip-flop(s) and '%s' in module/design-unit '%s' 
  GTDCLK {level="0"} // Clock gating detected for clock '%s' of flip-flop '%s' 
  LATINF {level="0"} // Process/always block models a latch, or signal '%s' is not assigned a value in all branches 
  MULMCK {level="1"} // Multiple master clocks found. Clock '%s' for flip-flop '%s' is derived from master input '%s' while the previously detected clocks were derived from '%s' for flip-flop '%s' 
  MRSTDT {level="1"} // Mix of synchronous and asynchronous set/reset found. Synchronous set/reset detected in '%s' and asynchronous set/reset detected in '%s' 
  TPOUNR {level="1"} // Output '%s' of top-level module is not a register 
  MISSEL {level="1"} // Signal '%s' missing from sensitivity list of a sequential process/block 
  USESEL {level="1"} // Signal '%s' should not be used in the sensitivity list of a sequential process/block 
  CBYNAM {level="1"} // Port connections for instance '%s' of %s '%s' should be made by name rather than by positional ordered list 
  NOTECH {level="1"} // Instance '%s' is instantiating a technology cell. Avoid using technology cells in the design 
  DIFCLK {level="2"} // Clock '%s' is being renamed to '%s' 
  DIFRST {level="2"} // Set/Reset '%s' is being renamed to '%s' 
  VERCAS {level="2"} // Identifier, label, instance, or module name '%s' reused with a case difference 
  DIRRNG {level="2"} // Inconsistent ordering of bits in range declarations -- should be all %s ranges 
  KYEDIF {level="2"} // EDIF reserved word '%s' used as an identifier or label 
  STYVAL {level="3"} // Numeric value '%d' used for identifier '%s'. Use constants to avoid portability issues 
  STYBLK {level="3"} // Block statement used. This will create portability issues 
  VHDREP {level="3"} // Repeated usage of identifier or label name '%s' 
  VERREP {level="3"} // Repeated usage of identifier or label name '%s' 
  MULTMF {level="3"} // More than one design-unit definition in file '%s' 
  KEYWOD {level="3"} // VHDL reserved word '%s' used as an identifier or label 
  KVHWOD {level="3"} // Verilog reserved word '%s' used as an identifier or label 
  STYSUL {level="3"} // Type std_ulogic used for identifier '%s'. Use std_logic to avoid portability issues 
  STYSUV {level="3"} // Type std_ulogic vector used for identifier '%s'. Use std_logic_vector to avoid portability issues 
  STYBIT {level="3"} // Type bit used for identifier '%s'. Use std_logic to avoid portability issues 
  STYBTV {level="3"} // Type bit_vector used for identifier '%s'. Use std_logic_vector to avoid portability issues 
  CKEYWD {level="3"} // C/C++ reserved word '%s' used as an identifier or label 
  UPCLBL {level="4"} // Label '%s' should be written in uppercase 
  DIFFMN {level="4"} // %s name '%s' differs from file name '%s' 
  NOBLKN {level="4"} // Each block should be labeled with a meaningful name 
  SEPLIN {level="4"} // Use a separate line for each HDL statement 
  NOINSN {level="4"} // Each module/gate/primitive instance should be labeled with a meaningful name 
  LCVARN {level="4"} // %s name '%s' uses uppercase characters 
  UCCONN {level="4"} // Lowercase characters used for identifier '%s'. Use uppercase characters for names of constants and user-defined types 
  ACNCPI {level="0"} // Asynchronous %s '%s' of latch/flip-flop '%s' is not controllable from primary inputs 
  ATLGLC {level="1"} // Glue logic inferred in top-level module/design-unit '%s' 
  SYNSCU {level="3"} // Embedded synthesis script used in the design 
}

category LOW_POWER "All checks related to low power design" default_on
{
  SRENSL {level="0"} // State retention element/cell '%s' is not inferred as a flip-flop. It is %s 
  SRPDDC {level="1"} // Retention flip-flops in the power domain '%s' are controlled by different %s 
  ISPDDC {level="1"} // Isolation rules from power domain '%s' are controlled by different control pins 
  LPISCS {level="1"} // The isolation controlling signal '%s' is not an output of a module or primary input 
  LPSRCS {level="1"} // The %s edge signal '%s' is not an output of a module or primary input 
  LOW_POWER_SYNTH       // All checks related to low power due to synthesizability errors
}

category LOW_POWER_SYNTH "All checks related to low power due to synthesizability errors" default_on
{
  CNREAL {level="1"} // Real variable %s is used in %s %s. Real variables are not synthesizable 
  GRDASN {level="0"} // In design-unit %s, non-synthesizable guarded assignments are encountered 
  INIMEM {level="2"} // Initialization of memory %s in module %s is ignored 
  INITBI  // Initial block in primitive is ignored 
  FINUSP {level="2"} // Module '%s' has a final block, which is ignored by synthesis tools 
  INIUSP {level="2"} // %s %s has an initial block or a variable declaration assignment, which is ignored by synthesis tools 
  LATINF {level="0"} // Process/always block models a latch, or signal '%s' is not assigned a value in all branches 
  FNAVPC {level="1"} // Function %s 
  COMBLP {level="1"} // In %s %s, combinational loop detected for node %s 
  CMBPAU {level="0"} // Combinational path detected through '%s' in module/design-unit '%s' 
  CBPAHI {level="2"} // Combinatorial path crossing multiple units drives '%s' 
  IGNDLY {level="2"} // Lumped delay in %s '%s' is ignored 
}


    // ---------------- //
    //  HAL Parameters  //
    // ---------------- //


params HAL {allow_error_suppression="yes"}
// params HAL {allow_error_suppression="no"}
// params HAL {allow_error_suppression="yes"}

params HAL {allow_intern_gen_sync_reset="no"}
params HAL {allow_only_hal_and_custom_rules="no"}
params HAL {check_verilog_reg_as_vhdl_var="no"}
params HAL {clock_list="APPEND"}
// params HAL {clock_list="append"}
// params HAL {clock_list="overwrite"}

params HAL {code_comment_style_verilog="single-line"}
params HAL {controllability_observability_threshold="15"}
params HAL {convention_for_control_type="mixed"}
params HAL {convention_for_set_reset_style="asynchronous"}
params HAL {disable_unclassified_rules="yes"}
// params HAL {disable_unclassified_rules="no"}
// params HAL {disable_unclassified_rules="yes"}

params HAL {display_rule_control="no"}
// params HAL {display_rule_control="no"}
// params HAL {display_rule_control="yes"}

params HAL {divided_clock_domain_same_as_master="yes"}
params HAL {gated_clock_domain_same_as_master="no"}
params HAL {header_case_sensitive="no"}
params HAL {header_field_separator=":"}
params HAL {header_section_separator="-"}
params HAL {ignore_empty_line_for_comment="no"}
params HAL {internally_generated_clock_as_clock="no"}
params HAL {issue_noblkn="both"}
params HAL {pragma_control="strict"}
params HAL {preserve_unused_elements="no"}
params HAL {regex_style="csh"}
// params HAL {regex_style="csh"}
// params HAL {regex_style="full"}

params HAL {severity_downgradable="no"}
// params HAL {severity_downgradable="no"}
// params HAL {severity_downgradable="yes"}

params HAL {suppress_synthesizability_errors="no"}
params HAL {unsized_literal="size_as_per_type"}


    // ----------------------- //
    //  Rule Severity Changes  //
    // ----------------------- //

params UNRCHS {ERROR}
params WAITML {ERROR}
params AWNDEL {ERROR}
params TERMST {ERROR}
params OUTRNG {ERROR}
params TOPGEN {ERROR}

    // ----------------- //
    //  Rule Parameters  //
    // ----------------- //

params TSBNTH {mask_cell_hierarchical="yes"}
params TSBNTH {mask_cells="and:nand:mux"}
params PBYNAM {num_params="5"}
params LDFFPI {logic_depth_adder="1"}
params LDFFPI {logic_depth_and="1"}
params LDFFPI {logic_depth_divide="1"}
params LDFFPI {logic_depth_inverter="1"}
params LDFFPI {logic_depth_multiply="1"}
params LDFFPI {logic_depth_mux="1"}
params LDFFPI {logic_depth_nand="1"}
params LDFFPI {logic_depth_nor="1"}
params LDFFPI {logic_depth_or="1"}
params LDFFPI {logic_depth_reference="1"}
params LDFFPI {logic_depth_subtract="1"}
params LDFFPI {logic_depth_threshold="10"}
params LDFFPI {logic_depth_xnor="1"}
params LDFFPI {logic_depth_xor="1"}
params IDLENG {exception_list=""}
params IDLENG {max_length="16"}
params IDLENG {min_length="4"}
params SVIFNM {pattern="*_bus"}
params SVIFNM {text=": should end with '_bus'"}
params NULCSE {allow_vhdl_two_state_logic="no"}
params MPCMPE {expression_complexity="5"}
params COMEND {min_line_count="0"}
params SIGLNM {pattern="*"}
params SIGLNM {text=""}
params RECTYP {allow_record_declaration="yes"}
params TIELOG {output_testing_mode="relax"}
params LOOPTM {max_operation="10"}
params RENAME {check_part_select_rename="disallow"}
params DFDRVS {ff_latch_set_reset_check="yes"}
params RSTNAM {local_regex_style="full"}
// params RSTNAM {local_regex_style="csh"}
// params RSTNAM {local_regex_style="full"}

params RSTNAM {pattern="_rst$|^rst_|^rst$"}
params RSTNAM {text=": should end with '_rst' or start with 'rst_' or just be 'rst'"}
params MEMRNM {pattern="*_mem"}
params MEMRNM {text=": should end with '_mem'"}
params REGRNM {pattern="*"}
params REGRNM {text=""}
params WIRENM {pattern="*"}
params WIRENM {text=""}
params SNCRST {sync_reset_style="either"}
params CTLCHR {off}
// params CTLCHR {off}
// params CTLCHR {on}

params DESULN {max_lines="400"}
params PCKGNM {pattern="*_pkg"}
params PCKGNM {text=": should end with '_pkg'"}
params LOCVNM {pattern="^l_.*$"}
params LOCVNM {text=": should start with 'l_'"}
params INSTNM {pattern="*"}
params INSTNM {text=""}
params ARCHID {local_regex_style="full"}
// params ARCHID {local_regex_style="csh"}
// params ARCHID {local_regex_style="full"}

params ARCHID {suffix_list="rtl|^rtl_|_rtl$|beh|^beh_|_beh$|syn|^syn_|_syn$|ppr|^ppr_|_ppr$|logic|^logic_|_logic$|hls|^hls_|_hls$|vit|^vit_|_vit$|tst|^tst_|_tst$"}
params KEYWOD {off}
// params KEYWOD {off}
// params KEYWOD {on}

params ASUMNM {pattern="^assume_.*$"}
params ASUMNM {text=": should start with 'assume_'"}
params EXTFSM {allow_fsm_output="yes"}
params ARCHNM {pattern="*_arch"}
params ARCHNM {text=": should end with '_arch'"}
params HIMPNM {pattern="*_z"}
params HIMPNM {text=": should end with '_z'"}
params RGOPNM {pattern="*_reg"}
params RGOPNM {text=": should end with '_reg'"}
params BEH_ARCHNM {pattern="^(TB|SIM|BEH)"}
params BEH_ARCHNM {text=""}
params PRTODR {layout_order=""}
params BLKLNM {pattern="*_blk"}
params BLKLNM {text=": should end with '_blk'"}
params DIFSIG {pattern="*"}
params CBYNAM {check_tech_cells="yes"}
params NTACHR {local_regex_style="full"}
// params NTACHR {local_regex_style="csh"}
// params NTACHR {local_regex_style="full"}

params NTACHR {pattern="^([_]?([a-zA-Z0-9:]+_?[a-zA-Z0-9:]*)*)$"}
params NTACHR {reserved_keyword_list=""}
params NTACHR {text=""}
params FILSUF {local_regex_style="full"}
// params FILSUF {local_regex_style="csh"}
// params FILSUF {local_regex_style="full"}

params FILSUF {pattern="(vhd$|vhdl$|v$|cpp$|cxx$|c++$|cc$|c$)"}
params POIASG {ignore_poiasg="no"}
params CLKSNM {pattern="*_CK"}
params CLKSNM {text=": should end with '_CK'"}
params NOINCD {mode="relax"}
params SUBPLN {max_lines="300"}
params NETDCL {Constant_Section_Ordering="no_order"}
params NETDCL {IO_Decl_Section_Ordering="no_order"}
params NETDCL {Internal_Signal_Section_Ordering="no_order"}
params COVRNM {pattern="^cover_.*$"}
params COVRNM {text=": should start with 'cover_'"}
params OUTPNM {pattern="*_O"}
params OUTPNM {text=": should end with '_O'"}
params MEMNOP {output_bypass_mode="strict"}
params INSTLB {max_length="8"}
params CMPPKG {pattern="*_cmp_pkg"}
params CMPPKG {text=": should end with '_cmp_pkg'"}
params RTL_ARCHNM {pattern="^(RTL|STR)"}
params RTL_ARCHNM {text=""}
params LENCPI {controllable_thru_comb_logic="no"}
params RULREP {report_successfull="yes"}
params RULREP {report_unchecked="yes"}
params RULREP {report_unclassified="no"}
params RULREP {report_violated="yes"}
params LOGNEG {mode="strict"}
params ASNRST {async_reset_style="active_low"}
params SUBRNM {pattern="*_proc"}
params SUBRNM {text=": should end with '_proc'"}
params EXPIPC {allow_concat_operation="no"}
params LIBRNM {pattern="*"}
params LIBRNM {text=""}
params ASRTSC {controllable_thru_comb_logic="no"}
params MULNBA {mulnba_reset_mode="no"}
params MODLNM {pattern="*_mod"}
params MODLNM {text=": should end with '_mod'"}
params MODLNM {top_only="no"}
params EDGMIX {hierarchical="no"}
params ALOWNM {local_regex_style="full"}
// params ALOWNM {local_regex_style="csh"}
// params ALOWNM {local_regex_style="full"}

params ALOWNM {pattern=".*(VSS|VDD|GND|VCC).*|.*(vss|vdd|gnd|vcc).*"}
params ALOWNM {text=""}
params LMTSTS {max_states="40"}
params DIFRST {setreset_type="async_and_sync"}
params LTCHNM {issue_for_ports="yes"}
params LTCHNM {pattern="*_l"}
params LTCHNM {text=": should end with '_l'"}
params ALOWID {pattern="*_n"}
params ALOWID {text=": should end with '_n'"}
params VARLNM {pattern="*"}
params VARLNM {text=""}
params UNCONO {check_on_std_cells="yes"}
params UNCONO {ignore_explicitly_unconnected_port="no"}
params UNCONO {ignore_port_with_no_load="no"}
params UNCONN {allow_explicitly_unconnected="no"}
// params UNCONN {allow_explicitly_unconnected="no"}
// params UNCONN {allow_explicitly_unconnected="yes"}

params UNCONI {ignore_explicitly_unconnected_port="no"}
params UNCONI {ignore_port_with_no_load="no"}
params FILENM {pattern="*_F"}
params FILENM {text=": should end with '_F'"}
params PRTLYO {layout_order=""}
params INSYNC {ff_sync_combi_logic_ok="yes"}
params INSYNC {ff_sync_mixed_clock_edge_ok="no"}
params INSYNC {lockup_latch_sync_allowed="yes"}
params INTGNM {pattern="*"}
params INTGNM {text=""}
params MULSNO {order=""}
params IGNDLY {allow_delay_in_ff_data="no"}
params FSMIDN {fsm_states_in_default_clause="no"}
params DIRRNG {direction="descending"}
// params DIRRNG {direction="ascending"}
// params DIRRNG {direction="descending"}

params MAXLEN {off}
// params MAXLEN {off}
// params MAXLEN {on}

params MAXLEN {max_line_length="80"}
params TESTNM {pattern="*_test"}
params TESTNM {text=": should end with '_test'"}
params SIGLEN {exception_list=""}
params SIGLEN {max_length="32"}
params SIGLEN {min_length="1"}
params TRUNCZ {off}
// params TRUNCZ {off}
// params TRUNCZ {on}

params TXCNOP {output_bypass_mode="strict"}
params REALNM {pattern="*"}
params REALNM {text=""}
params TASKNM {pattern="task*"}
params TASKNM {text=": should start with 'task'"}
params CNSTLT {vhdl_multibit_null_literal="disallow"}
params CNSTLT {vlog_multibit_null_literal="allow"}
params FUNCNM {pattern="func*"}
params FUNCNM {text=": should start with 'func'"}
params PROPNM {pattern="^p_.*$"}
params PROPNM {text=": should start with 'p_'"}
params MXPROC {max_processes="10"}
params INPTNM {pattern="*_I"}
params INPTNM {text=": should end with '_I'"}
params PORTNM {pattern="*"}
params PORTNM {text=""}
params PORTNM {top_only="no"}
params ASTMNM {pattern="^assert_.*$"}
params ASTMNM {text=": should start with 'assert_'"}
params CBPAHI {report_path_till_top_level="no"}
params CBPAHI {report_paths="all"}
// params CBPAHI {report_paths="all"}
// params CBPAHI {report_paths="nocell"}

params TBCHNM {pattern="$MODNAME"}
params CDEFNC {case_default_specification="relax"}
params CDEFNC {combinational_block_only="no"}
params CDEFNC {full_case_with_no_default_allowed="yes"}
params MAXPRT {max_ports="25"}
params UELOPR {ignore_addition="no"}
params UELOPR {ignore_subtraction="no"}
params STMCNM {pattern="*_state"}
params STMCNM {text=": should end with '_state'"}
params PARMNM {pattern="*"}
params PARMNM {text=""}
params SEQNNM {pattern="^s_.*$"}
params SEQNNM {text=": should start with 's_'"}
params ACCSNM {pattern="*_P"}
params ACCSNM {text=": should end with '_P'"}
params ENTYNM {pattern="*_ent"}
params ENTYNM {text=": should end with '_ent'"}
params SLENEX {scanlengthlimit="200"}
params NUMSUF {vector_only="yes"}
params TBNNAM {pattern="*_tb"}
params TBNNAM {text=": should end with '_tb'"}
params CNSTNM {pattern="*_C"}
params CNSTNM {text=": should end with '_C'"}
params SYNASN {asynchronous_reset_is_synchronous="yes"}
params CLKDMN {delayed_clock_as_clock="no"}
params UCOPNM {pattern="*_nc"}
params UCOPNM {text=": should end with '_nc'"}
params BOUINC {lower_bound="0"}
params LMULOP {multiplication_result_limit="64"}
params MXTSBC {max_tri_state_buff_connect_limit="5"}
params MLITNU {max_literals="20"}
params CONFNM {local_regex_style="full"}
// params CONFNM {local_regex_style="csh"}
// params CONFNM {local_regex_style="full"}

params CONFNM {pattern="^$ENTNAME.*$"}
params CONFNM {text=": should start with the name of the entity to which configuration is bound"}
params NOBLKN {check_nested_blocks="no"}
params NOBLKN {off}
// params NOBLKN {off}
// params NOBLKN {on}

params FFCSTD {output_of_blackbox="variable"}
params FFCSTD {output_of_latch="variable"}
params MULTCK {flipflop_reporting_limit="10"}
params MULBAS {mulbas_quick_check="yes"}
params IOPTNM {pattern="*_IO"}
params IOPTNM {text=": should end with '_IO'"}
params VLFLNM {pattern="$MODNAME"}

    // --------------- //
    //  Rule Renaming  //
    // --------------- //


Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.