



# DW02\_mult\_6\_stage

# Six-Stage Pipelined Multiplier

Version, STAR and Download Information: IP Directory

### **Features and Benefits**

- Parameterized word length
- Unsigned and signed (two's-complement) data operation
- Six-stage pipelined architecture
- Automatic pipeline retiming

# **Description**

DW02\_mult\_6\_stage is a six-stage pipelined multiplier. DW02\_mult\_6\_stage multiplies the operand A by B to produce a product (PRODUCT) with a latency of five clock (CLK) cycles.



#### Table 1-1 Pin Description

| Pin Name | Width                      | Direction | Function                                 |
|----------|----------------------------|-----------|------------------------------------------|
| Α        | A_width bit(s)             | Input     | Multiplier                               |
| В        | B_width bit(s)             | Input     | Multiplicand                             |
| TC       | 1 bit                      | Input     | Two's complement 0 = unsigned 1 = signed |
| CLK      | 1 bit                      | Input     | Clock                                    |
| PRODUCT  | $A_width + B_width$ bit(s) | Output    | Product (A × B)                          |

#### **Table 1-2** Parameter Description

| Parameter | Values | Description      |
|-----------|--------|------------------|
| A_width   | ≥ 1    | Word length of A |
| B_width   | ≥ 1    | Word length of B |

#### Table 1-3 Synthesis Implementations

| Implementation Name | Function                                   | License Feature Required |
|---------------------|--------------------------------------------|--------------------------|
| str                 | Booth-recoded Wallace-tree synthesis model | DesignWare               |

Table 1-4 Simulation Models

| Model                                 | Function                             |  |
|---------------------------------------|--------------------------------------|--|
| DW02.DW02_MULT_6_STAGE_CFG_SIM        | Design unit name for VHDL simulation |  |
| dw/dw02/src/DW02_mult_6_stage_sim.vhd | VHDL simulation model source code    |  |
| dw/dw02/src_ver/DW02_mult_6_stage.v   | Verilog simulation model source code |  |

The control signal TC determines whether the input and output data is interpreted as unsigned (TC=0) or signed (TC=0) numbers.

Automatic pipeline retiming ensures optimal placement of pipeline registers within the multiplier to achieve maximum throughput.

For more information about DesignWare Building Blocks pipelined multipliers, refer to Application Note AN 96-002.

Figure 1-1 Block Diagram



# **Related Topics**

- Math Arithmetic Overview
- DesignWare Building Block IP Documentation Overview

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

```
library IEEE, DWARE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DWpackages.all;
use DWARE.DW foundation comp.all;
entity DW02_mult_6_stage_inst is
  generic ( inst_A_width : POSITIVE := 8;
            inst_B_width : POSITIVE := 8 );
  port ( inst_A : in std_logic_vector(inst_A_width-1 downto 0);
         inst_B : in std_logic_vector(inst_B_width-1 downto 0);
         inst_TC : in std_logic;
         inst_CLK : in std_logic;
    PRODUCT_inst : out std_logic_vector(inst_A_width+inst_B_width-1 downto 0)
end DW02_mult_6_stage_inst;
architecture inst of DW02_mult_6_stage_inst is
begin
  -- Instance of DW02_mult_6_stage
  U1 : DW02_mult_6_stage
    generic map ( A_width => inst_A_width, B_width => inst_B_width )
    port map ( A => inst_A,  B => inst_B,
                                             TC => inst TC,
               CLK => inst_CLK, PRODUCT => PRODUCT_inst );
end inst;
-- pragma translate_off
configuration DW02_mult_6_stage_inst_cfg_inst of DW02_mult_6_stage_inst is
  for inst
  end for; -- inst
end DW02_mult_6_stage_inst_cfg_inst;
-- pragma translate_on
```

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

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

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

#### **Destination Control Statement**

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

#### **Disclaimer**

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

#### **Trademarks**

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

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

### **Third-Party Links**

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

Synopsys, Inc. 690 E. Middlefield Road Mountain View, CA 94043

www.synopsys.com