



# DW\_asymdata\_outbuf

# Asymmetric Data Output Buffer

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Features and Benefits**

### **Revision History**

- Parameterized asymmetric input and output data widths (in\_width > out\_width with integer multiple relationship)
- Parameterized byte (sub-word) ordering within a word
- Parameterized flush value
- Word integrity flag
- Parameterized error status mode
- Registered push error (overflow)

# init\_pop\_n data\_in data\_out pop\_req\_n push\_wd\_n fifo\_empty part\_wd pop\_wd\_n pop\_error > clk\_pop rst\_pop\_n

# **Description**

This component multiplexes input data stream words and into output subwords predicated on the input data width being greater than and an integer multiple of the output data width. Once all of sub-words from the full word data input are presented to the data output, a pop word enable signal is asserted.

This component was initially conceived as a back-end piece to an asymmetric First-In-First-Out (FIFO) device as depicted in the data flow usage example shown in Figure 1-2 on page 5. Note that the interface naming of DW\_asymdata\_outbuf incorporates the "pop" nomenclature associated with a FIFO device.

A "flush" feature is available to force out a partially buffered word. This functionality is useful in clearing the input buffers and establishing word alignment.

Table 1-1 Pin Description

| Pin Name   | Width     | Direction | Function                                |
|------------|-----------|-----------|-----------------------------------------|
| clk_pop    | 1         | Input     | Clock source                            |
| rst_pop_n  | 1         | Input     | Asynchronous reset (active low)         |
| init_pop_n | 1         | Input     | Synchronous reset (active low)          |
| pop_req_n  | 1         | Input     | Pop request (active low)                |
| data_in    | in_width  | Input     | Input data (sub-word)                   |
| fifo_empty | 1         | Input     | Empty indication connected RAM/FIFO     |
| pop_wd_n   | 1         | Output    | Full data word transferred (active low) |
| data_out   | out_width | Output    | Output data (sub-word)                  |

# Table 1-1 Pin Description (Continued)

| Pin Name  | Width | Direction | Function                 |
|-----------|-------|-----------|--------------------------|
| part_wd   | 1     | Output    | Partial word popped flag |
| pop_error | 1     | Output    | Under-run of RAM/FIFO    |

### **Table 1-2** Parameter Description

| Parameter  | Values                   | Description                                                                                                                                                                                                |
|------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| in_width   | 1 to 2048<br>Default: 8  | Width of data_in  Must be greater than <i>out_width</i> and an integer multiple; that is, <i>in_width</i> = K * <i>out_width</i>                                                                           |
| out_width  | 1 to 2048<br>Default: 16 | Width of data_out Must be less than in_width and an integer multiple; that is, in_width = K * out_width                                                                                                    |
| err_mode   | 0 or 1<br>Default: 0     | <ul> <li>Error flag behavior mode</li> <li>■ 0: Sticky pop_error flag (hold on first occurrence, clears only on reset)</li> <li>■ 1: Dynamic pop_error flag (reports every occurrence of error)</li> </ul> |
| byte_order | 0 or 1<br>Default: 0     | Sub-word ordering into Word  0: The first byte (or sub-word) is in MSB of word  1: The first byte (or sub-word) is in LSB of word                                                                          |

# Table 1-3 Synthesis Implementations

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

### Table 1-4 Simulation Models

| Model                                  | Function                             |
|----------------------------------------|--------------------------------------|
| DW03.DW_ASYMDATA_OUTBUF_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw03/src/DW_asymdata_outbuf_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_asymdata_outbuf.v        | Verilog simulation model source code |

Figure 1-1 is a block diagram of the DW\_asymdata\_outbuf component.

Figure 1-1 DW\_asymdata\_outbuf Basic Block Diagram



Figure 1-2 on page 4 shows how the output multiplexer routes data\_in to data\_out (based on the value of byte\_order) from a RAM element.

Figure 1-2 Data Flow Based on 'byte\_order' Value



### **Partial Words**

When the sub-words are being multiplexed to data\_out before the full word of data\_in is traversed, the output flag part\_wd is active (high). After K pops, where K = in\_width / out\_width, K sub-words are presented to the data\_out output. When all sub-words for a particular word from the RAM/FIFO are sent out, part\_wd goes inactive (low) on the following cycle. The order of how the sub-words are retrieved from a word is determined by the byte\_order parameter (as shown in Figure 1-2).

### **Popping Complete Words**

As the Kth sub-word is being popped (pop\_req\_n asserted low) to data\_out, the data\_in complete word has then been traversed, then pop\_wd\_n asserts for a single clk\_pop cycle. The pop\_wd\_n output is a non-registered single-clock pulse and is a combinational result derived directly from pop\_req\_n. So, there must be an awareness of the timing characteristics of pop\_req\_n.

### Pop Errors

A pop error occurs if pop\_req\_n asserts during active fifo\_empty. The pop\_error output is registered and its behavior can either be 'sticky' or 'dynamic' based on the *err\_mode* parameter. See Table 1-2 on page 2 for the *err\_mode* definition.

# **Suppressing Warning Messages During Verilog Simulation**

The Verilog simulation model includes macros that allow you to suppress warning messages during simulation.

To suppress all warning messages for all DWBB components, define the DW\_SUPPRESS\_WARN macro in either of the following ways:

Specify the Verilog preprocessing macro in Verilog code:

```
`define DW_SUPPRESS_WARN
```

• Or, include a command line option to the simulator, such as:

```
+define+DW SUPPRESS WARN (which is used for the Synopsys VCS simulator)
```

The warning messages for this model include the following:

■ If values other than 1 or 0 are present on a clock port, the following message is displayed:

```
WARNING: <instance_path>.<clock_name>_monitor:
    at time = <timestamp>, Detected unknown value, x, on <clock name> input.
```

To suppress only this warning message for all DWBB components, use the following macro:

- □ Define the DW\_DISABLE\_CLK\_MONITOR macro. You can define this macro in the following ways:
  - Specify the Verilog preprocessing macro in Verilog code:

```
`define DW DISABLE CLK MONITOR
```

Or, include a command line option to the simulator, such as:

```
+define+DW DISABLE CLK MONITOR (which is used for the Synopsys VCS simulator)
```

This message is also suppressed using the DW\_SUPPRESS\_WARN macro explained earlier.

# **Timing Waveforms**

Figure 1-3 depicts, after an asynchronous reset, a sequence that pops a complete word. The data widths configurations are *in\_width* of 24 and *out\_width* of 8 which makes the integer multiple of *in\_width* to *out\_width*, K, equal to 3. On the third active pop\_req\_n, pop\_wd\_n goes active (low) indicating that a complete word have been popped. The *byte\_order* parameter in this case is set to 1, which means that the first sub-word popped is taken from the least significant sub-word of data\_in.

Figure 1-3 Pop a Complete Word (Parameter Set 1)



Figure 1-4 shows a pop error condition. The pop\_error signal is asserted on the next clock cycle after pop\_req\_n and fifo\_empty are asserted. The *err\_mode* parameter is set to 1, which means the pop\_error assertion only lasts as longer as the error condition is present. Thus, after fifo\_empty de-asserts, pop\_error also de-asserts on the next cycle. If *err\_mode* was 0, pop\_error would have remained asserted until a reset to the component was initiated.

Figure 1-4 Pop a Complete Word and Error (Parameter Set 2)



# **Related Topics**

- Memory FIFO Overview
- DesignWare Building Block IP User Guide

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

```
library IEEE, DWARE;
use IEEE.std logic 1164.all;
use DWARE.DW Foundation comp.all;
entity DW asymdata outbuf inst is
      generic (
        inst in width : INTEGER := 16;
        inst out width : INTEGER := 8;
        inst err mode : INTEGER := 0;
        inst byte order : INTEGER := 0
        );
      port (
        inst clk pop : in std logic;
        inst rst pop n : in std logic;
        inst init pop n : in std logic;
        inst pop req n : in std logic;
        inst data in : in std logic vector(inst in width-1 downto 0);
        inst fifo empty: in std logic;
        pop wd n inst : out std logic;
        data out inst : out std logic vector(inst out width-1 downto 0);
        part wd inst : out std logic;
        pop error inst : out std logic
        );
    end DW asymdata outbuf inst;
architecture inst of DW asymdata outbuf inst is
begin
    -- Instance of DW asymdata outbuf
    U1 : DW asymdata outbuf
    generic map ( in width => inst in width, out width => inst out width, err mode =>
inst err mode, byte order => inst byte order )
    port map ( clk pop => inst clk pop, rst pop n => inst rst pop n, init pop n =>
inst init pop n, pop req n => inst pop req n, data in => inst data in, fifo empty =>
inst fifo empty, pop wd n => pop wd n inst, data out => data out inst, part wd =>
part wd inst, pop error => pop error inst );
end inst:
-- Configuration for use with a VHDL simulator
-- pragma translate off
library DW03;
configuration DW asymdata outbuf inst cfg inst of DW asymdata outbuf inst is
  for inst
  end for; -- inst
```

```
end DW_asymdata_outbuf_inst_cfg_inst;
-- pragma translate on
```

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

```
module DW asymdata outbuf_inst( inst_clk_pop, inst_rst_pop_n,
    inst init pop n, inst pop req n, inst data in, inst fifo empty,
    pop wd n inst, data out inst, part wd inst, pop error inst );
parameter inst in width = 16;
parameter inst out width = 8;
parameter inst err mode = 0;
parameter inst byte order = 0;
input inst clk pop;
input inst rst pop n;
input inst init pop n;
input inst pop req n;
input [inst in width-1 : 0] inst data in;
input inst fifo empty;
output pop wd n inst;
output [inst_out_width-1 : 0] data_out_inst;
output part wd inst;
output pop error inst;
    // Instance of DW asymdata outbuf
    DW asymdata outbuf #(inst in width, inst out width, inst err mode, inst byte order)
U1 (
                 .clk pop(inst clk pop),
                 .rst pop n(inst rst pop n),
                 .init pop n(inst init pop n),
                 .pop req n(inst pop req n),
                 .data in(inst data in),
                 .fifo empty(inst fifo empty),
                 .pop wd n(pop wd n inst),
                 .data out (data out inst),
                 .part wd(part wd inst),
                 .pop error(pop error 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                                                                                                                                                                                                       |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| July 2020    | DWBB_201912.5 | <ul> <li>Adjusted content and title of "Suppressing Warning Messages During<br/>Verilog Simulation" on page 5 and added the DW_SUPPRESS_WARN<br/>macro</li> </ul>                                             |
| October 2019 | DWBB_201903.5 | ■ Added the "Disabling Clock Monitor Messages" section                                                                                                                                                        |
| April 2018   | DWBB_201709.5 | <ul> <li>For STAR 9001317257, updated the maximum value for in_width and out_width parameter in Table 1-2 on page 2</li> <li>Added this Revision History table and the document links on this page</li> </ul> |

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