



# DWF\_dp\_mult\_comb\_sat function

## Combined Unsigned/Signed Multiply and Saturate

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Description**

The DWF\_dp\_mult\_comb\_sat function performs combined (switchable) unsigned/signed multiplication of the two arguments a and b, truncates the upper bits of the result to the width specified by argument  $p_width$  and returns a saturated value if an overflow (or underflow) occurs. Argument a (b) is interpreted as signed if argument a\_tc (b\_tc) is 1, otherwise as unsigned. The result must be interpreted as signed if argument a\_tc or b\_tc (or both) is 1 (= signed multiplication), otherwise as unsigned (= unsigned multiplication). A dedicated overflow detection (needed for saturation) is used to improve QoR of the multiplier.

Table 1-1 Function Names

| Function Name           | Description                                                                      |
|-------------------------|----------------------------------------------------------------------------------|
| DWF_dp_mult_comb_sat    | VHDL combined multiply and saturate (std_logic_vector/unsigned/signed arguments) |
| DWF_dp_mult_comb_sat    | Verilog combined multiply and saturate                                           |
| DWF_dp_mult_comb_sat_tc | Verilog combined multiply and saturate (signed arguments)                        |

Table 1-2 Argument Description

| Name                 | Туре    | Direction | Width / Values | Description                               |
|----------------------|---------|-----------|----------------|-------------------------------------------|
| a                    | Vector  | Input     | a_width        | Input multiplier                          |
| a_tc                 | Bit     | Input     | 1              | Two's complement control for multiplier   |
|                      |         |           |                | ■ 0 = Unsigned                            |
|                      |         |           |                | ■ 1 = Signed                              |
| b                    | Vector  | Input     | b_width        | Input multiplicand                        |
| b_tc                 | Bit     | Input     | 1              | Two's complement control for multiplicand |
|                      |         |           |                | ■ 0 = Unsigned                            |
|                      |         |           |                | ■ 1 = Signed                              |
| p_width              | Integer | Input     | ≥ 2            | Word length of return value               |
|                      |         |           |                | (VHDL only, constant)                     |
| DWF_dp_mult_comb_sat | Vector  | Output    | p_width        | Returned value                            |

Table 1-3 Parameter Description (Verilog)

| Parameter | Values | Description                   |  |
|-----------|--------|-------------------------------|--|
| a_width   | ≥ 2    | Word length of input a        |  |
| b_width   | ≥ 2    | Word length of input b        |  |
| p_width   | ≥ 2    | Word length of returned value |  |

**Verilog Include File:** DW\_dp\_mult\_comb\_sat\_function.inc

### **Functional Description**

```
z[p_width-1:0] = DWF_dp_mult_comb_sat (a[a_width-1:0], a_tc, b[b_width-1:0], b_tc, p_width)
p[a width+b width-1:0] (unsigned) = a (unsigned) * b (unsigned)
                                                                     if a tc = 0 and b tc = 0
p[a width+b width-1:0] (signed)
                                   = a (signed)
                                                   * b (unsigned)
                                                                    if a tc = 1 and b tc = 0
                                   = a (unsigned) * b (signed)
                                                                    if a tc = 0 and b tc = 1
                                   = a (signed)
                                                   * b (signed)
                                                                    if a_tc = 1 and b_tc = 1
z[p width-1:0] = 2p width-1
                                   if
                                             (a tc = 0 and b tc = 0) and
                                          (p[a width+b width-1:0] > 2p width-1)
               = 2p width-1-1
                                     else if (a tc = 1 or b tc = 1) and
                                          (p[a width+b width-1:0] > 2p width-1-1)
               = -2p_width-1
                                     else if (a_tc = 1 or b_tc = 1) and
                                          (p[a_width+b_width-1:0] < -2p_width-1)</pre>
               = p[p width-1:0] else
```

For more information about the DesignWare datapath functions, refer to the topic titled DesignWare Datapath Functions Overview.

# **Related Topics**

- DesignWare Datapath Functions Overview
- DesignWare Building Block IP User Guide

#### **VHDL Example**

### **Verilog Example**

```
module DWF_dp_mult_comb_sat_test (a, a_tc, b, b_tc, c, z);
input signed [7:0] a, b, c;
input a_tc, b_tc;
output signed [7:0] z;

// Passes the parameters to the function
parameter a_width = 8;
parameter b_width = 8;
parameter p_width = 8;

// add "$SYNOPSYS/dw/sim_ver" to the search path for simulation
include "DW_dp_mult_comb_sat_function.inc"

assign z = DWF_dp_mult_comb_sat (a, a_tc, b, b_tc) + c;
endmodule
```

### **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