



# DW01\_addsub

#### Adder-Subtractor

Version, STAR, and myDesignWare Subscriptions: IP Directory

#### **Features and Benefits**

### **Revision History**

- Parameterized word length
- Carry-in and carry-out signals

### **Description**

DW01\_addsub is a two-input adder-subtractor. DW01\_addsub adds or subtracts two operands A and B with a carry-in (CI) to produce the output SUM with a carry-out (CO).

The ADD\_SUB signal determines whether the operation to perform is an addition (ADD SUB = 0) or a subtraction (ADD SUB = 1).



Table 1-1 Pin Description

| Pin Name | Width      | Direction | Function                                    |
|----------|------------|-----------|---------------------------------------------|
| Α        | width bits | Input     | Input data                                  |
| В        | width bits | Input     | Input data                                  |
| CI       | 1 bit      | Input     | Carry/borrow-in                             |
| ADD_SUB  | 1 bit      | Input     | Addition/subtraction control                |
| SUM      | width bits | Output    | Sum (A + B + CI) or difference (A - B - CI) |
| СО       | 1 bit      | Output    | Carry/borrow-out                            |

**Table 1-2** Parameter Description

| Parameter | Values | Description                  |
|-----------|--------|------------------------------|
| width     | ≥ 1    | Word length of A, B, and SUM |

Table 1-3 Synthesis Implementations<sup>a</sup>

| Implementation Name | Implementation               | License Feature Required |  |
|---------------------|------------------------------|--------------------------|--|
| rpl                 | Ripple-carry synthesis model | none                     |  |

Table 1-3 Synthesis Implementations<sup>a</sup> (Continued)

| Implementation Name | Implementation                                                                                     | License Feature Required |
|---------------------|----------------------------------------------------------------------------------------------------|--------------------------|
| cla                 | Carry-look-ahead synthesis model                                                                   | none                     |
| pparch              | Delay-optimized flexible parallel-prefix                                                           | DesignWare               |
| apparch             | Area-optimized flexible architecture that can be optimized for area, for speed, or for area, speed | DesignWare               |

a. During synthesis, Design Compiler selects the appropriate architecture for your constraints. However, you may force Design Compiler to use one of the architectures described in this table.

**Table 1-4** Simulation Models

| Model                           | Function                             |
|---------------------------------|--------------------------------------|
| DW01.DW01_ADDSUB_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw01/src/DW01_addsub_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW01_addsub.v        | Verilog simulation model source code |

Table 1-5 Functional Description

| ADD_SUB | Α | В | CI | SUM       | СО        |
|---------|---|---|----|-----------|-----------|
| 0       | А | В | 0  | A + B     | Carry-out |
| 0       | Α | В | 1  | A + B + 1 | Carry-out |
| 1       | А | В | 0  | A - B     | Carry-out |
| 1       | Α | В | 1  | A - B - 1 | Carry-out |

# **Related Topics**

- Math Arithmetic Overview
- DesignWare Building Block IP User Guide

SolvNetPlus

#### **HDL Usage Through Operator Inferencing - VHDL**

```
library IEEE;
use IEEE.std logic 1164.all;
use IEEE.std logic arith.all;
entity DW01 addsub oper is
  generic(wordlength: integer := 8);
 port(in1, in2 : in STD LOGIC VECTOR(wordlength-1 downto 0);
       ctl
                 : in STD LOGIC;
                 : out STD LOGIC VECTOR (wordlength-1 downto 0));
       sum
end DW01 addsub oper;
architecture oper of DW01 addsub oper is
  signal in1 signed, in2 signed, sum signed: SIGNED(wordlength-1 downto 0);
  in1 signed <= SIGNED(in1);</pre>
  in2 signed <= SIGNED(in2);
 process (in1 signed, in2 signed, ctl)
 begin
    if (ctl = '0') then
      sum signed <= in1_signed + in2_signed;</pre>
      sum signed <= in1 signed - in2 signed;
    end if;
  end process;
  sum <= STD_LOGIC_VECTOR(sum_signed);</pre>
end oper;
```

# **HDL Usage Through Operator Inferencing - Verilog**

```
module DW01 addsub oper(in1,in2,ctl,sum);
 parameter wordlength = 8;
  input [wordlength-1:0] in1, in2;
  input ctl;
 output [wordlength-1:0] sum;
 reg [wordlength-1:0] sum;
 always @(in1 or in2 or ctl)
 begin
    if (ctl == 0)
      sum = in1 + in2;
    else
      sum = in1 - in2;
  end
endmodule
```

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

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DWpackages.all;
use DWARE.DW foundation comp.all;
entity DW01 addsub inst is
  generic ( inst width : NATURAL := 8 );
 port (inst A
                     : in std logic vector(inst width-1 downto 0);
         inst B
                      : in std logic vector(inst width-1 downto 0);
         inst CI
                   : in std logic;
         inst ADD SUB : in std logic;
         SUM inst
                   : out std logic vector(inst width-1 downto 0);
         CO inst
                      : out std logic );
end DW01 addsub inst;
architecture inst of DW01 addsub inst is
begin
  -- Instance of DW01 addsub
  U1 : DW01 addsub
    generic map ( width => inst_width )
    port map ( A => inst_A, B => inst B, CI => inst CI,
               ADD SUB => inst ADD SUB, SUM => SUM inst, CO => CO inst );
end inst;
-- pragma translate off
configuration DW01 addsub inst cfg inst of DW01 addsub inst is
  for inst
  end for; -- inst
end DW01 addsub inst cfg inst;
-- pragma translate on
```

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

## **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                                                                                                 |  |
|--------------|---------------|---------------------------------------------------------------------------------------------------------|--|
| March 2019   | DWBB_201903.0 | ■ Removed Table 1-4, "Obsolete Synthesis Implementations"                                               |  |
| January 2019 | DWBB_201806.5 | <ul> <li>Updated example in "HDL Usage Through Component Instantiation -<br/>VHDL" on page 4</li> </ul> |  |
|              |               | <ul> <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