



## DW\_asymdata\_inbuf

### Asymmetric Data Input Buffer

Version, STAR, and myDesignWare Subscriptions: IP Directory

### **Features and Benefits**

# Parameterized asymmetric input and output data widths (in\_width < out\_width with integer multiple relationship) init push in

- Parameterized byte (sub-word) ordering within a word
- Parameterized flush\_value
- Word integrity flag
- Parameterized error status mode
- Registered push error (overflow)

# init\_push\_n data\_in data\_out push\_req\_n push\_wd\_n flush\_n fifo\_full push\_wd\_n push\_error clk\_push rst\_push\_n

**Revision History** 

### **Description**

This component buffers up input data stream sub-words and assembles them into output words predicated on the input data width being less than and an integer multiple of the output data width. Once the number of input sub-words received completes a full data word, the data output is presented along with a push word enable signal.

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 "push" 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_push    | 1        | Input     | Clock source                               |  |
| rst_push_n  | 1        | Input     | Asynchronous reset (active low)            |  |
| init_push_n | 1        | Input     | Synchronous reset (active low)             |  |
| push_req_n  | 1        | Input     | Push request (active low)                  |  |
| data_in     | in_width | Input     | Input data (word)                          |  |
| flush_n     | 1        | Input     | Flush the partial word (active low)        |  |
| fifo_full   | 1        | Input     | Full indication connected RAM/FIFO         |  |
| push_wd_n   | 1        | Output    | Ready to write full data word (active low) |  |

Table 1-1 Pin Description (Continued)

| Pin Name   | Width     | Direction | Function                                             |
|------------|-----------|-----------|------------------------------------------------------|
| data_out   | out_width | Output    | Output data (sub-word)                               |
| inbuf_full | 1         | Output    | Input registers all contain active data_in sub-words |
| part_wd    | 1         | Output    | Partial word pushed flag                             |
| push_error | 1         | Output    | Overrun of RAM/FIFO (includes input registers)       |

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

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

### 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_INBUF_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw03/src/DW_asymdata_inbuf_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_asymdata_inbuf.v        | Verilog simulation model source code |

Table 1-5 lists all the combinations of flush\_n and push\_req\_n in relation to part\_wd, inbuf\_full, and fifo\_full and the resulting action that is performed.

Table 1-5 Flush and Push scenarios and results

| flush_n    | push_req_n                                              | part_wd | inbuf_full | fifo_full | Result/Action                                                  |
|------------|---------------------------------------------------------|---------|------------|-----------|----------------------------------------------------------------|
| 1          | 0                                                       | х       | 0          | х         | push only, no error                                            |
| 0          | 0                                                       | 0       | 0          | х         | push only, no error                                            |
| 1          | 0                                                       | 1       | 1          | 0         | generate push_wd_n, reset counters, no error                   |
| х          | 0                                                       | 1       | 1          | 1         | push error, last subword lost, hold counters                   |
| 0          | 1                                                       | 1       | х          | 0         | flush only, reset counters, no error *                         |
| 0          | 1                                                       | 0       | 0          | х         | do nothing                                                     |
| 0          | 0                                                       | 1       | х          | 0         | flush and push (data_in into sub-word1 input reg.), no error * |
| 0          | 1                                                       | 1       | х          | 1         | push error, no other action                                    |
| 0          | 0                                                       | 1       | 0          | 1         | push error, no flush, push data                                |
| 1          | 1                                                       | х       | х          | х         | do nothing                                                     |
| х          | х                                                       | 0       | 1          | х         | not possible                                                   |
| * During a | During a valid flush condition, push, wd, n is asserted |         |            |           |                                                                |

<sup>\*</sup> During a valid flush condition, push\_wd\_n is asserted

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

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

# Asymmetric Data Input Buffer: DW\_asymdata\_inbuf



Note: (out\_width / in\_width) is an integer and ≥ 2

SolvNetPlus

Figure 1-2 shows how the input registers are organized and routed to data out (based on the value of byte order) to a RAM element. Note that the number of sub-word input registers is equal to (out width /  $in\_width$ ) - 1.

Figure 1-2 Data Flow Based on 'byte order' Value





### **Partial Words**

When a partial word is in the input registers, output flag part wd is active (high). After K pushes, where K = out\_width / in\_width, K sub-words are assembled into a full word (K-1 sub-words in the input register and the last sub-word on the data in bus). This full word is then presented for writing into RAM/FIFO. When a full word is sent from the input registers to RAM/FIFO, part wd goes inactive (low) on the following cycle. The order of sub-words within a word is determined by the byte\_order parameter (as shown in Figure 1-2).

### **Pushing Complete Words**

As the Kth sub-word is being pushed (push reg n asserted low), the complete word is presented to the data out output along with assertion of push wd n (low single clk push cycle). The push wd n output is non-registered single-clock pulse and is a combinational result derived directly from push req n. So, there must be an awareness of the timing characteristics of push req n.

### Flushing Input Registers

The flushing function, via flush\_n assertion, pushes a partial word to RAM/FIFO. The input registers are pre-set to the <code>flush\_value</code> value after a flush with the exception of one case. This case is when simultaneous assertion of flush\_n and push\_req\_n when part\_wd is asserted and fifo\_full is not asserted. Under this scenario, the sub-word from <code>data\_in</code> is placed into the sub-word1 input register with all other sub-word locations pre-set the <code>flush\_value</code> value.

A complete list of results caused by flush\_n assertion is shown in Table 1-5 on page 3.

### **Push Errors**

A push error occurs under either of these conditions:

- push req n active, part wd active, inbuf full active, and fifo full active OR
- flush n active, part wd active, and fifo full active

The push\_error output is registered and its behavior can either be 'sticky' or 'dynamic' based on the *err\_mode* parameter. For the definition of *err\_mode*, see Table 1-2 on page 2.

### **Example of non-FIFO Use**

Figure 1-3 depicts an example of the DW\_asymdata\_inbuf connected to a DesignWare synchronizing component called the DW\_data\_sync. The DW\_data\_sync synchronizes incoming data from one clock domain to another. Here, the DW\_asymdata\_inbuf provides the data from the source domain and the DW\_data\_sync which then passes it on to the destination domain.

Figure 1-3 Example of DW\_asymdata\_inbuf Used with DW\_data\_sync



### **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-4 depicts, after an asynchronous reset, a sequence of pushing a complete word followed by simultaneous push-flush assertion while part\_wd is active. The data widths configurations are <code>in\_width</code> of 4 and <code>out\_width</code> of 16 which makes the integer multiple of <code>in\_width</code> to <code>out\_width</code>, K, equal to 4. This implies that the number of input sub-word registers is 3 (K-1). So, after three pushes <code>inbuf\_full</code> goes active. On the fourth active <code>push\_req\_n</code>, <code>push\_wd\_n</code> goes active (low) which implies valid <code>data\_out</code>. Subsequently, the <code>inbuf\_full</code> output goes low on the next cycle after the <code>push\_wd\_n</code> active pulse. The <code>byte\_order</code> parameter in this case is set to 0 which means that the first sub-word pushed is placed to the most significant sub-word of <code>data\_out</code>.

Following the pushing of a complete word, two pushes (causes part\_wd to go active) occur then a simultaneous push and flush event. The flush is acted upon because fifo\_full is not asserted and part\_wd is asserted. So, the result of this simultaneous push-flush causes whatever is already in the input registers to be written to data\_out and any non pushed sub-words written to data\_out with a value based on the flush\_value parameter setting. In this case, flush\_value is set to 1. So, the resulting value of data\_out is '0xd5ff' where the 'd' and '5' were already stored in the input registers from the initial two pushes and the '0xff' is the flush\_value of all 1's for the non-pushed sub-words. Since this is a simultaneous push-flush without error and valid flush, the push causes the input register to store the data\_in value of '0x2' in the sub-word1 position.

Figure 1-4 Push Complete Word and Push/Flush (Parameter Set 1)



Figure 1-5 shows the same sequence as in Figure 1-4 on page 8 but with different parameter settings. In this case the 'K' is 3 (ratio of *out\_width / in\_width*), *byte\_order* is 1, and *flush\_value* is 0. So, inbuf\_full goes active after two pushes and the push\_wd\_n active pulse occurs during the third active push\_req\_n (because fifo\_full is not asserted). Since *byte\_order* is 1, the data\_in values pushed are placed in data\_out starting from the least significant sub-word.

The flushing result (which occurs coincident with a push in this case) places 0's on the most significant non-pushed sub-words of data\_out as seen by the result "0x00d" during the push\_wd\_n pulse derived from the flush\_n assertion.

Figure 1-5 Push Complete Word and Push/Flush (Parameter Set 2)



Figure 1-6 shows a push error condition. The configuration is the same as for Figure 1-5 on page 9 with the added note that *err\_mode* is set to 1. This meanings that the push\_error signal is dynamic and will report every occurrence of a push error as opposed to staying asserted on the first occurrence of an error (as when *err\_mode* equals 0).

In this timing diagram a push of a complete word is attempted while fifo\_full is asserted. That is, when inbuf\_full and push\_req\_n are asserted while fifo\_full is asserted. This causes a RAM/FIFO overrun error. The push\_error is registered. The sub-word sitting at the data\_in input for the push that caused the push error is not stored and is lost if not held constant at the input as shown in the waveform where '0x2' is dropped when data\_in changes to '0x1' on the next clock cycle. Because *err\_mode* is 1 the push\_error assertion only lasts as longer as the error condition is present. Thus, after push\_req\_n de-asserts, push\_error also de-asserts on the next cycle. If *err\_mode* was 0, push\_error would have remained asserted until a reset to the component was initiated.

Figure 1-6 Push 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 inbuf inst is
      generic (
        inst in width : INTEGER := 8;
        inst out width : INTEGER := 16;
        inst err mode : INTEGER := 0;
        inst byte order : INTEGER := 0;
        inst flush value : INTEGER := 0
        );
      port (
        inst clk push : in std logic;
        inst rst push n : in std logic;
        inst init push n : in std logic;
        inst push req n : in std logic;
        inst data in : in std logic vector(inst in width-1 downto 0);
        inst flush n : in std logic;
        inst fifo full : in std logic;
        push wd n inst : out std logic;
        data out inst : out std logic vector(inst out width-1 downto 0);
        inbuf full inst : out std logic;
        part wd inst : out std logic;
        push_error_inst : out std_logic
        );
    end DW asymdata inbuf inst;
architecture inst of DW asymdata inbuf inst is
begin
    -- Instance of DW asymdata inbuf
    U1 : DW asymdata inbuf
    generic map ( in width => inst in width, out width => inst out width, err mode =>
inst err mode, byte order => inst byte order, flush value => inst flush value )
    port map ( clk push => inst clk push, rst push n => inst rst push n, init push n =>
inst init push n, push req n => inst push req n, data in => inst data in, flush n =>
inst flush n, fifo full => inst fifo full, push wd n => push wd n inst, data out =>
data out inst, inbuf full => inbuf full inst, part wd => part wd inst, push error =>
push error inst );
end inst;
-- Configuration for use with a VHDL simulator
```

```
-- pragma translate_off
library DW03;
configuration DW_asymdata_inbuf_inst_cfg_inst of DW_asymdata_inbuf_inst is
  for inst
  end for; -- inst
end DW_asymdata_inbuf_inst_cfg_inst;
-- pragma translate_on
```

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

```
module DW asymdata inbuf inst( inst clk push, inst rst push n,
    inst init push n, inst push req n, inst data in,
    inst flush n, inst fifo full, push wd n inst, data out inst,
    inbuf full inst, part wd inst, push error inst );
parameter inst in width = 8;
parameter inst out width = 16;
parameter inst err mode = 0;
parameter inst byte order = 0;
parameter inst flush value = 0;
input inst clk push;
input inst rst push n;
input inst init push n;
input inst push req n;
input [inst in width-1 : 0] inst data in;
input inst flush n;
input inst fifo full;
output push wd n inst;
output [inst out width-1: 0] data out inst;
output inbuf full_inst;
output part wd inst;
output push error inst;
    // Instance of DW asymdata inbuf
    DW asymdata inbuf #(inst_in_width, inst_out_width, inst_err_mode, inst_byte_order,
inst flush value) U1 (
                 .clk push(inst clk push),
                 .rst push n(inst rst push n),
                 .init push n(inst init push n),
                 .push req n(inst push req n),
                 .data in(inst data in),
                 .flush n(inst flush n),
                 .fifo full(inst fifo full),
                 .push wd n (push wd n inst),
                 .data out (data out inst),
                 .inbuf full(inbuf full inst),
                 .part wd(part wd inst),
                 .push error (push 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 7 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 | ■ For STAR 9001317257, updated the maximum value for <i>in_width</i> and <i>out_width</i> parameter in Table 1-2 on page 2                                        |  |
|              |               | <ul> <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