



# DW01\_mux\_any

## Universal Multiplexer

Version, STAR, and myDesignWare Subscriptions: IP Directory

#### **Features and Benefits**

### **Revision History**

- Parameterized word lengths
- Saves coding time by eliminating the need to code multiplexers (MUX's) explicitly
- Increases design abstraction
- Uses 8-to-1 MUX's where possible



## **Description**

DW01\_mux\_any is an universal multiplexer. This component selects a subrange of the input A, and places it on the output MUX. The select input, SEL, multiplexes the subrange of A to MUX. If necessary, A is padded with high order bits of zero. The widths of the inputs and outputs are fixed by the parameters A\_width, SEL\_width, and MUX\_width.

DW01\_mux\_any uses 8-to-1 MUX's whenever possible to get the fastest possible implementation with the lowest gate count.

Table 1-1 Pin Description

| Pin Name | Width     | Direction | Function             |
|----------|-----------|-----------|----------------------|
| Α        | A_width   | Input     | Data input bus       |
| SEL      | SEL_width | Input     | Select input         |
| MUX      | MUX_width | Output    | Multiplexed data out |

Table 1-2 Parameter Description

| Parameter            | Values               | Description                                                                                                           |
|----------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------|
| A_width              | ≥ 1                  | Word length of A                                                                                                      |
| SEL_width            | ≥ 1                  | Word length of SEL                                                                                                    |
| MUX_width            | ≥ 1                  | $A((SEL + 1) \times MUX\_width - 1 \text{ downto } SEL^*MUX\_width)$                                                  |
| bal_str <sup>a</sup> | 0 or 1<br>Default: 0 | Controls the symmetric structure of the 'str' implementation.  1 = Use symmetric structure with 'str" implementation. |

a. Prior to release 2007.12-SP2, this parameter is ignored.

#### Table 1-3 Synthesis Implementations

| Implementation Name | Function        | License Feature Required |
|---------------------|-----------------|--------------------------|
| str                 | Synthesis model | DesignWare               |

#### Table 1-4 Simulation Models

| Model                            | Function                             |  |
|----------------------------------|--------------------------------------|--|
| DW01.DW01_MUX_ANY_CFG_SIM        | Design unit name for VHDL simulation |  |
| dw/dw01/src/DW01_mux_any_sim.vhd | VHDL simulation model source code    |  |
| dw/sim_ver/DW01_mux_any.v        | Verilog simulation model source code |  |

## **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 DW01 mux any inst is
  generic (inst A width : POSITIVE := 8;
           inst SEL width : POSITIVE := 8;
           inst MUX width : POSITIVE := 8);
  port (inst A : in std logic vector(inst A width-1 downto 0);
        inst_SEL : in std_logic_vector(inst_SEL_width-1 downto 0);
        MUX inst : out std logic vector(inst MUX width-1 downto 0));
end DW01 mux any inst;
architecture inst of DW01 mux any inst is
begin
  -- Instance of DW01 mux any
  U1 : DW01 mux any
    generic map ( A width => inst A width, SEL width => inst SEL width,
                 MUX width => inst MUX width )
   port map ( A => inst A, SEL => inst SEL, MUX => MUX inst );
end inst;
-- pragma translate off
configuration DW01 mux any inst cfg inst of DW01 mux any inst is
  for inst
  end for; -- inst
end DW01 mux any inst cfg inst;
-- pragma translate on
```

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

```
module DW01_mux_any_inst( inst_A, inst_SEL, MUX_inst );

parameter A_width = 8;
parameter SEL_width = 8;

parameter MUX_width = 8;

input [A_width-1 : 0] inst_A;
input [SEL_width-1 : 0] inst_SEL;
output [MUX_width-1 : 0] MUX_inst;

// Instance of DW01_mux_any
DW01_mux_any #(A_width, SEL_width, MUX_width)
U1 ( .A(inst_A), .SEL(inst_SEL), .MUX(MUX_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                                                                           |
|--------------|---------------|-----------------------------------------------------------------------------------|
| January 2019 | DWBB_201806.5 | ■ Updated example in "HDL Usage Through Component Instantiation - VHDL" on page 3 |
|              |               | ■ 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