



# DW\_sra

## Arithmetic Shifter with Preferred Right Direction (VHDL style)

Version, STAR, and myDesignWare Subscriptions: IP Directory

## **Features and Benefits**

## **Revision History**

- Parameterized data and shift coefficient word lengths
- Uses VHDL semantics for the arithmetic shift operation
- Capable of shifting in both directions



## **Description**

DW\_sra is an arithmetic shifter that has the same semantics as the sra operator in VHDL. A list of input and output pins is shown in Table 1-1. The component has the parameters shown in Table 1-2. Parameters control the number of bits used in the component's ports.

The DW\_sra may be configured to work as a bidirectional or unidirectional shifter. The SH\_TC input indicates if the shifting distance (SH) is positive or negative. When SH\_TC = 1 the input SH is interpreted as a signed integer represented in two's complement. The component has a preferred right direction for shifting, which means that when SH > 0 the right shift operation is performed. The input data A is always shifted to the right when SH\_TC = 0 (the SH input value is always positive) or when SH\_TC = 1 and SH > 0 (the SH input is signed and positive). Otherwise, input A is shifted to the left by  $(-2SH\_width + SH_{rep})$  bits, where SH\_rep is the unsigned integer value of SH.

The arithmetic right shift operation is executed the same way as other arithmetic shifters, the MS bit is copied to all positions that are made open. Differently from other shifters, when shifting to the left, the LS bit is copied to all the positions that are made open. For example, when  $SH_TC = 1$ , SH = -2, and  $A = (100101)_2$ , the output  $B = (010111)_2$ , where the LS bit of A was replicated on the rightmost positions during the left shift operation. Table 1-5 on page 2 illustrates other combinations of the input values for a small component.

Table 1-1 Pin Description

| Pin Name | Width    | Direction | Function                                                 |
|----------|----------|-----------|----------------------------------------------------------|
| А        | A_width  | Input     | Input data                                               |
| SH       | SH_width | Input     | Shift control                                            |
| SH_TC    | 1 bit    | Input     | Shift two's complement control  0 = Unsigned  1 = Signed |
| В        | A_width  | Output    | Shifted data out                                         |

**Table 1-2** Parameter Description

| Parameter | Values | Description            |
|-----------|--------|------------------------|
| A_width   | ≥ 2    | Word length of A and B |
| SH_width  | ≥ 1    | Word length of SH      |

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

| Implementation Name | Function                                      | License Feature Required |
|---------------------|-----------------------------------------------|--------------------------|
| mx2                 | Static implement using 2:1 multiplexers only. | DesignWare               |
| str                 | Synthesis model targeted for speed            | DesignWare               |
| astr                | Synthesis model targeted for area             | 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                             |
|----------------------------|--------------------------------------|
| dw/dw01/src/DW_sra_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_sra.v        | Verilog simulation model source code |

The following is a Truth Table for the parameter values  $A\_width = 8$  and  $SH\_width = 3$ .

Table 1-5 Truth Table (A\_width = 8, SH\_width = 3)

| SH(2:0) | SH_TC | B(7) | B(6) | B(5) | B(4) | B(3) | B(2) | B(1) | B(0) |
|---------|-------|------|------|------|------|------|------|------|------|
| 000     | Х     | A(7) | A(6) | A(5) | A(4) | A(3) | A(2) | A(1) | A(0) |
| 001     | х     | A(7) | A(7) | A(6) | A(5) | A(4) | A(3) | A(2) | A(1) |
| 010     | х     | A(7) | A(7) | A(7) | A(6) | A(5) | A(4) | A(3) | A(2) |
| 011     | х     | A(7) | A(7) | A(7) | A(7) | A(6) | A(5) | A(4) | A(3) |
| 100     | 0     | A(7) | A(7) | A(7) | A(7) | A(7) | A(6) | A(5) | A(4) |
| 101     | 0     | A(7) | A(7) | A(7) | A(7) | A(7) | A(7) | A(6) | A(5) |
| 110     | 0     | A(7) | A(6) |
| 111     | 0     | A(7) |
| 100     | 1     | A(3) | A(2) | A(1) | A(0) | A(0) | A(0) | A(0) | A(0) |

Table 1-5 Truth Table (A\_width = 8, SH\_width = 3) (Continued)

| SH(2:0) | SH_TC | B(7) | B(6) | B(5) | B(4) | B(3) | B(2) | B(1) | B(0) |
|---------|-------|------|------|------|------|------|------|------|------|
| 101     | 1     | A(4) | A(3) | A(2) | A(1) | A(0) | A(0) | A(0) | A(0) |
| 110     | 1     | A(5) | A(4) | A(3) | A(2) | A(1) | A(0) | A(0) | A(0) |
| 111     | 1     | A(6) | A(5) | A(4) | A(3) | A(2) | A(1) | A(0) | A(0) |

# **Related Topics**

- Logic Combinational Overview
- DesignWare Building Block IP User Guide

## **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 DW sra inst is
      generic (
        inst A width : POSITIVE := 8;
        inst SH width : POSITIVE := 3
        );
      port (
        inst A : in std logic vector(inst A width-1 downto 0);
        inst SH: in std logic vector(inst SH width-1 downto 0);
        inst_SH_TC : in std_logic;
        B inst : out std logic vector(inst A width-1 downto 0)
        );
    end DW sra inst;
architecture inst of DW sra inst is
begin
    -- Instance of DW sra
    U1 : DW sra
    generic map ( A width => inst A width, SH width => inst SH width )
    port map ( A => inst A, SH => inst SH, SH TC => inst SH TC, B => B inst );
end inst;
-- pragma translate off
configuration DW sra inst cfg inst of DW sra inst is
for inst
end for; -- inst
end DW sra inst cfg inst;
-- pragma translate on
```

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

```
module DW_sra_inst( inst_A, inst_SH, inst_SH_TC, B_inst );

parameter A_width = 8;
parameter SH_width = 3;

input [A_width-1 : 0] inst_A;
input [SH_width-1 : 0] inst_SH;
input inst_SH_TC;
output [A_width-1 : 0] B_inst;

// Instance of DW_sra
DW_sra #(A_width, SH_width)
U1 ( .A(inst_A), .SH(inst_SH), .SH_TC(inst_SH_TC), .B(B_inst) );
endmodule
```

# **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                                                                           |  |  |
|----------------|---------------|-----------------------------------------------------------------------------------|--|--|
| September 2018 | DWBB_201806.2 | ■ Updated example in "HDL Usage Through Component Instantiation - VHDL" on page 4 |  |  |
|                |               | ■ 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

Arithmetic Shifter with Preferred Right Direction (VHDL style)