



# DWF\_dp\_simd\_mult functions

# SIMD multiply

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Description**

## **Revision History**

The DWF\_dp\_simd\_mult functions implement a configurable SIMD multiplier. They allow you to either multiply arguments a and b as full-width vectors (for example, one 32-bit multiplication) or to multiply smaller partitions of a and b using multiple parallel multipliers (for example, two 16-bit multiplications or four 8-bit multiplications). The argument no\_confs specifies the number of possible configurations, and argument conf dynamically selects one of the configurations. Configuration with number conf has 2<sup>conf</sup> partitions of size width/2<sup>conf</sup>. Arguments a and b and the return value are all either unsigned or signed (two's complement).

Table 1-1 Function Names

| Function Name        | Description                                     |
|----------------------|-------------------------------------------------|
| DWF_dp_simd_mult     | VHDL unsigned SIMD multiply                     |
| DWF_dp_simd_mult     | VHDL signed (two's complement) SIMD multiply    |
| DWF_dp_simd_mult_uns | Verilog unsigned SIMD multiply                  |
| DWF_dp_simd_mult_tc  | Verilog signed (two's complement) SIMD multiply |

Table 1-2 Argument Description

| Argument Name    | Туре                | Width / Values                    | Description                                                                           |
|------------------|---------------------|-----------------------------------|---------------------------------------------------------------------------------------|
| а                | Vector <sup>a</sup> | width                             | Input multiplier                                                                      |
| b                | Vector <sup>a</sup> | width                             | Input multiplicand                                                                    |
| no_confs         | Integer             | ≥ 2                               | Number of configurations (VHDL only, constant)                                        |
| conf             | Vector <sup>b</sup> | ceil(log <sub>2</sub> [no_confs]) | Configuration selection: 2 <sup>conf</sup> partitions of size width/2 <sup>conf</sup> |
| DWF_dp_simd_mult | Vector <sup>a</sup> | width                             | Return value                                                                          |

a. unsigned or signed in VHDL

Table 1-3 Parameter Description (Verilog)

| Parameter | Values                                             | Description              |
|-----------|----------------------------------------------------|--------------------------|
| width     | ≥ 2, must be a multiple of 2 <sup>no_confs-1</sup> | Word length              |
| no_confs  | ≥ 2                                                | Number of configurations |

b. std logic vector in VHDL

Verilog Include File: DW dp simd mult function.inc

#### **Functional Description**

```
z[2*width-1:0] = DWF_dp_simd_mult (a[width-1:0], b[width-1:0], no_confs,
                 conf[bit width(no confs)-1:0])
conf = 0:
 z[2*width-1:0]
                          = a[width-1:0]
                                                   * b[width-1:0]
conf = 1:
 z[2*width-1:2*width/2] = a[width-1:width/2]
                                                   * b[width-1:width/2]
                         = a[width/2-1:0]
                                                   * b[width/2-1:0]
 z[2*width/2-1:0]
conf = 2:
 z[2*width-1:2*width*3/4] = a[width-1:width*3/4] * b[width-1:width*3/4]
 z[2*width*3/4-1:2*width/2] = a[width*3/4-1:width/2] * b[width*3/4-1:width/2]
 z[2*width/2-1:2*width/4] = a[width/2-1:width/4] * b[width/2-1:width/4]
 z[2*width/4-1:0]
                         = a[width/4-1:0]
                                                   * b[width/4-1:0]
```

```
Example: width = 32, no_confs = 3

conf = 0:
    z[63: 0] = a[31: 0] * b[31: 0]

conf = 1:
    z[63:32] = a[31:16] * b[31:16]
    z[31: 0] = a[15: 0] * b[15: 0]

conf = 2:
    z[63:48] = a[31:24] * b[31:24]
    z[47:32] = a[23:16] * b[23:16]
    z[31:16] = a[15: 8] * b[15: 8]
    z[15: 0] = a[ 7: 0] * b[ 7: 0]
```

For more information about the DesignWare datapath functions, see to DesignWare Datapath Functions Overview.

## **Related Topics**

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

### **VHDL Example**

### **Verilog Example**

### **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 2021 | DWBB_202009.4 | ■ Corrected operator symbols in Example on page 2                       |  |
|            |               | ■ Added this Revision History table and the document links on this page |  |

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