



# DWF\_dp\_sign\_select functions

# Sign Selection / Conditional Two's Complement

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Description**

The DWF\_dp\_sign\_select functions return the positive or negative (two's complement) value of argument a controlled by sign argument s. Argument a and the return value are both either signed (two's complement) or unsigned.

A signed return value has overflow for the value  $DWF_dp_sign_select (-2^{width-1}, 1) = 2^{width-1}$ , which cannot be represented as a signed number of width bits. The complement of an unsigned number always results in underflow (that is, a negative number cannot be represented as an unsigned), but the unsigned  $DWF_dp_sign_select$  can be meaningful for the conditional addition/subtraction in a larger unsigned expression.

Table 1-1 Function Names

| Function Name          | Description                                   |
|------------------------|-----------------------------------------------|
| DWF_dp_sign_select     | VHDL unsigned sign select                     |
| DWF_dp_sign_select     | VHDL signed (two's complement) sign select    |
| DWF_dp_sign_select_uns | Verilog unsigned sign select                  |
| DWF_dp_sign_select_tc  | Verilog signed (two's complement) sign select |

Table 1-2 Argument Description

| Argument Name      | Туре   | Width | Description               |
|--------------------|--------|-------|---------------------------|
| a                  | Vector | width | Input data                |
| s                  | Bit    | 1     | Sign / complement control |
| DWF_dp_sign_select | Vector | width | Return value              |

Table 1-3 Parameter Description (Verilog)

| Parameter | Values | Description                             |
|-----------|--------|-----------------------------------------|
| width     | ≥ 1    | Word length of input a and return value |

Verilog Include File: DW\_dp\_sign\_select\_function.inc

### **Functional Description**

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

# **Related Topics**

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

### **VHDL Example**

```
library IEEE, DWARE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
use DWARE.DW_dp_functions.all;
-- DWARE.DW_dp_functions_arith package if IEEE.std_logic_arith is used

entity DWF_dp_sign_select_test is
   port (a, b, c : in signed(7 downto 0);
        s : in std_logic;
        z : out signed(15 downto 0));
end DWF_dp_sign_select_test;

architecture rtl of DWF_dp_sign_select_test is
begin
   z <= DWF_dp_sign_select (a * b, s) + c;
end rtl;</pre>
```

# **Verilog Example**

```
module DWF_dp_sign_select_test (a, b, c, s, z);
input signed [7:0] a, b, c;
input s;
output signed [15:0] z;

// Passes the parameter to the function
parameter width = 16;

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

assign z = DWF_dp_sign_select_tc (a * b, s) + 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