



# DW\_cntr\_gray

## **Gray Code Counter**

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Features and Benefits**

- Gray encoded output
- Asynchronous and synchronous reset
- Count enable
- Includes a low-power implementation that has power benefits from minPower optimization (for details, see Table 1-3 on page 2)

# **Description**

DW\_cntr\_gray is a Gray code counter. The counter is *width* bits wide and has 2<sup>width</sup> states. The counter is clocked on the positive edge of the clk input. Because the count sequence is Gray code, only one counter bit changes value between successive states. DW\_cntr\_gray also has optional low power benefits.

# data count cen load\_n init\_n clk rst\_n

**Revision History** 

Table 1-1 Pin Description

| Pin Name | Width      | Direction | Function                                |
|----------|------------|-----------|-----------------------------------------|
| clk      | 1 bit      | Input     | Clock                                   |
| rst_n    | 1 bit      | Input     | Reset, asynchronous, active low         |
| init_n   | 1 bit      | Input     | Reset, synchronous, active low          |
| load_n   | 1 bit      | Input     | Enable data load to counter, active low |
| data     | width bits | Input     | Counter load input                      |
| cen      | 1 bit      | Input     | Count enable, active high               |
| count    | width bits | Output    | Gray coded counter output               |

**Table 1-2** Parameter Description

| Parameter | Values | Description            |
|-----------|--------|------------------------|
| width     | ≥ 1    | Word length of counter |

Table 1-3 Synthesis Implementations

| Implementation Name | Function                  | License Feature Required           |  |
|---------------------|---------------------------|------------------------------------|--|
| str                 | Synthesis model           | DesignWare                         |  |
| lpwr <sup>a</sup>   | Low Power synthesis model | ■ DesignWare (P-2019.03 and later) |  |
|                     |                           | ■ DesignWare-LP (before P-2019.03) |  |

a. Requires that you enable minPower; for details, see "Enabling minPower" on page 5. When minPower is enabled, the lpwr implementation is always chosen during synthesis.

Table 1-4 Simulation Models

| Model                            | Function                             |
|----------------------------------|--------------------------------------|
| DW03.DW_chtr_gray_cfg_sim        | Design unit name for VHDL simulation |
| dw/dw03/src/DW_cntr_gray_sim.vhd | VHDL simulation model source code    |
| dw_sim_ver/DW_cntr_gray.v        | Verilog simulation model source code |

The active-low rst\_n signal provides for an asynchronous reset of the counter to "000...0". The active-low init\_n signal provides a synchronous reset of the counter to "000...0".

When the count enable pin cen is high, the counter is active. When cen is low, the counter is disabled and count remains unchanged.

The counter operates according to the following truth table:

| rst_n | init_n | load_n | cen | Operation            |
|-------|--------|--------|-----|----------------------|
| 0     | Х      | Х      | Х   | Reset (asynchronous) |
| 1     | 0      | Х      | Х   | Reset (synchronous)  |
| 1     | 1      | 0      | Х   | Load                 |
| 1     | 1      | 1      | 0   | Standby              |
| 1     | 1      | 1      | 1   | Count                |

# **Suppressing Warning Messages During Verilog Simulation**

The Verilog simulation model includes macros that allow you to suppress warning messages during simulation.

To suppress all warning messages for all DWBB components, define the DW\_SUPPRESS\_WARN macro in either of the following ways:

Specify the Verilog preprocessing macro in Verilog code:

```
`define DW_SUPPRESS_WARN
```

• Or, include a command line option to the simulator, such as:

```
+define+DW SUPPRESS WARN (which is used for the Synopsys VCS simulator)
```

The warning messages for this model include the following:

■ If values other than 1 or 0 are present on a clock port, the following message is displayed:

```
WARNING: <instance_path>.<clock_name>_monitor:
    at time = <timestamp>, Detected unknown value, x, on <clock name> input.
```

To suppress only this warning message for all DWBB components, use the following macro:

- □ Define the DW\_DISABLE\_CLK\_MONITOR macro. You can define this macro in the following ways:
  - Specify the Verilog preprocessing macro in Verilog code:

```
`define DW_DISABLE_CLK_MONITOR
```

Or, include a command line option to the simulator, such as:

```
+define+DW DISABLE CLK MONITOR (which is used for the Synopsys VCS simulator)
```

This message is also suppressed using the DW\_SUPPRESS\_WARN macro explained earlier.

# **Timing Diagrams**

Figure 1-1 Functional Operation with Asynchronous Reset



Figure 1-2 Functional Operation with Synchronous Reset



### **Enabling minPower**

You can instantiate this component without enabling minPower, but to achieve power savings from the low-power implementation "lpwr" (see Table 1-3 on page 2), you must enable minPower optimization, as follows:

- Design Compiler
  - □ Version P-2019.03 and later:

```
set power_enable_minpower true
```

□ Before version P-2019.03 (requires the DesignWare-LP license feature):

```
set synthetic_library {dw_foundation.sldb dw_minpower.sldb}
set link library {* $target library $synthetic library}
```

Fusion Compiler

Optimization for minPower is enabled as part of the total\_power metric setting. To enable the total\_power metric, use the following:

```
set qor strategy -stage synthesis -metric total power
```

## **Related Topics**

- Math Arithmetic Overview
- DesignWare Building Blocks User Guide

# **HDL Usage Through Component Instantiation - VHDL**

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DW Foundation comp arith.all;
entity DW cntr gray inst is
 generic (inst width : positive := 8);
 port (inst clk : in std logic;
        inst rst n : in std logic;
       inst init n : in std logic;
        inst load n : in std logic;
        inst_data : in std_logic_vector(inst_width-1 downto 0);
        inst cen
                 : in std logic;
        count inst : out std logic vector(inst width-1 downto 0));
end DW cntr gray inst;
architecture inst of DW cntr gray inst is
 -- instance of DW cntr gray
 U1 : DW cntr gray
   generic map (width => inst width)
   port map (clk
                  => inst clk,
             rst n => inst rst n,
             init n => inst init n,
             load n => inst load n,
             data => inst data,
                  => inst cen,
              cen
             count => count inst);
end inst;
-- pragma translate off
configuration DW cntr gray inst cfg inst of DW cntr gray inst is
 for inst
 end for;
end DW_cntr_gray_inst_cfg_inst;
-- pragma translate on
```

### **HDL Usage Through Component Instantiation - Verilog**

```
module DW cntr gray inst (inst clk, inst rst n, inst init n, inst load n,
                          inst data, inst cen, count inst);
 parameter inst_width = 8;
  input inst clk;
  input inst rst n;
  input inst init n;
  input inst load n;
  input [inst width-1 : 0] inst data;
  input inst cen;
  output [inst_width-1 : 0] count_inst;
  // Please add +incdir+$SYNOPSYS/dw/sim ver+ to your verilog simulator
  // command line (for simulation).
  // instance of DW cntr gray
 DW cntr gray #(inst width)
   U1 (.clk(inst clk),
        .rst n(inst rst n),
        .init n(inst init n),
        .load n(inst load n),
        .data(inst data),
        .cen(inst cen),
        .count(count inst));
endmodule
```

# **Revision History**

For notes about this release, see the *DesignWare Building Block IP Release Notes*.

For lists of both known and fixed issues for this component, refer to the STAR report.

For a version of this datasheet with visible change bars, click here.

| Date         | Release       | Updates                                                                                                                                                                                                                   |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| July 2020    | DWBB_201912.5 | <ul> <li>Adjusted content and title of "Suppressing Warning Messages During<br/>Verilog Simulation" on page 3 and added the DW_SUPPRESS_WARN<br/>macro</li> </ul>                                                         |  |
| October 2019 | DWBB_201903.5 | ■ Added the "Disabling Clock Monitor Messages" section                                                                                                                                                                    |  |
| March 2019   | DWBB_201903.0 | <ul> <li>Clarified implementations and license requirements in Table 1-3 on page 2</li> <li>Added "Enabling minPower" on page 5</li> <li>Added this Revision History table and the document links on this page</li> </ul> |  |

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

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

### **Destination Control Statement**

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

### **Disclaimer**

SYNOPSYS, INC., AND ITS LICENSORS MAKE NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

### **Trademarks**

Synopsys and certain Synopsys product names are trademarks of Synopsys, as set forth at https://www.synopsys.com/company/legal/trademarks-brands.html.

All other product or company names may be trademarks of their respective owners.

### Free and Open-Source Software Licensing Notices

If applicable, Free and Open-Source Software (FOSS) licensing notices are available in the product installation.

### **Third-Party Links**

Any links to third-party websites included in this document are for your convenience only. Synopsys does not endorse and is not responsible for such websites and their practices, including privacy practices, availability, and content.

Synopsys, Inc. www.synopsys.com