



# DW\_asymfifoctl\_s1\_df

Asym. I/O Synch. (One Clock) FIFO Controller - Dynamic Flags

Version, STAR, and myDesignWare Subscriptions: IP Directory

#### **Features and Benefits**

### **Revision History**

- Fully registered synchronous address and flag output ports
- All operations execute in a single clock cycle
- FIFO empty, half full, and full flags
- Asymmetric input and output bit widths (must be integer-multiple relationship)
- Word integrity flag for *data\_in\_width* < *data\_out\_width*
- Flushing out partial word for data\_in\_width < data\_out\_width
- Parameterized byte order within a word
- FIFO error flag indicating underflow, overflow, and pointer corruption
- Parameterized word depth
- Dynamically programmable almost full and almost empty flags
- Parameterized reset mode (synchronous or asynchronous)
- Interfaces to common hard macro or compiled ASIC dual-port synchronous RAMs
- Includes a low-power implementation (at a sub-level) that has power benefits from minPower optimization (for details, see Table 1-3 on page 3)

## **Description**

DW\_asymfifoctl\_s1\_df is a FIFO RAM controller designed to interface with a dual-port synchronous RAM.

Table 1-1 Pin Description

| Pin Name   | Width | Direction | Function                                                                                      |
|------------|-------|-----------|-----------------------------------------------------------------------------------------------|
| clk        | 1 bit | Input     | Input clock                                                                                   |
| rst_n      | 1 bit | Input     | Reset input, active low  Asynchronous if rst_mode = 0  Synchronous if rst_mode = 1            |
| push_req_n | 1 bit | Input     | FIFO push request, active low                                                                 |
| flush_n    | 1 bit | Input     | Flushes the partial word into memory (fills in 0's) (for data_in_width < data_out_width only) |



Table 1-1 Pin Description (Continued)

| Pin Name     | Width                                       | Direction | Function                                                                                                        |
|--------------|---------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------|
| pop_req_n    | 1 bit                                       | Input     | FIFO pop request, active low                                                                                    |
| diag_n       | 1 bit                                       | Input     | Diagnostic control, active low (for <i>err_mode</i> = 0, NC for other <i>err_mode</i> values)                   |
| data_in      | data_in_width bits                          | Input     | FIFO data to push                                                                                               |
| rd_data      | max (data_in_width,<br>data_out_width) bits | Input     | RAM data input to FIFO controller                                                                               |
| ae_level     | ceil(log <sub>2</sub> [depth]) bits         | Input     | Almost empty level (the number of words in the FIFO at or below which the almost_empty flag is active)          |
| af_thresh    | ceil(log <sub>2</sub> [depth]) bits         | Input     | Almost full threshold (the number of words stored in the FIFO at or above which the almost_full flag is active) |
| w_en         | 1 bit                                       | Output    | Write enable output for write port of RAM, active low                                                           |
| empty        | 1 bit                                       | Output    | FIFO empty output, active high                                                                                  |
| almost_empty | 1 bit                                       | Output    | FIFO almost empty output, active high, asserted when FIFO level ≤ ae_level                                      |
| half_full    | 1 bit                                       | Output    | FIFO half full output, active high                                                                              |
| almost_full  | 1 bit                                       | Output    | FIFO almost full output, active high, asserted when FIFO level ≥ af_thresh                                      |
| full         | 1 bit                                       | Output    | FIFO full output, active high                                                                                   |
| ram_full     | 1 bit                                       | Output    | RAM full output, active high                                                                                    |
| error        | 1 bit                                       | Output    | FIFO error output, active high                                                                                  |
| part_wd      | 1 bit                                       | Output    | Partial word, active high (for data_in_width < data_out_width only; otherwise, tied low)                        |
| wr_data      | max (data_in_width,<br>data_out_width) bits | Output    | FIFO controller output data to RAM                                                                              |
| wr_addr      | ceil(log <sub>2</sub> [depth]) bits         | Output    | Address output to write port of RAM                                                                             |
| rd_addr      | ceil(log <sub>2</sub> [depth]) bits         | Output    | Address output to read port of RAM                                                                              |
| data_out     | data_out_width bits                         | Output    | FIFO data to pop                                                                                                |

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

| Parameter      | Values                                                                    | Description                                                                                                 |  |
|----------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|
| data_in_width  | 1 to 256                                                                  | Width of the data_in bus; must be in an integer-multiple relationship with data_out_width. That is, either: |  |
|                |                                                                           | ■ data_in_width = K x data_out_width, or                                                                    |  |
|                |                                                                           | ■ data_out_width = K x data_in_width                                                                        |  |
|                |                                                                           | Where K is an integer.                                                                                      |  |
| data_out_width | 1 to 256                                                                  | Width of the data_out bus; must be in an integer-multiple relationship with data_in_width. That is, either: |  |
|                |                                                                           | ■ data_in_width = K x data_out_width, or                                                                    |  |
|                |                                                                           | ■ data_out_width = K x data_in_width                                                                        |  |
|                |                                                                           | Where K is an integer.                                                                                      |  |
| depth          | 2 to 2 <sup>24</sup>                                                      | Number of memory elements used in the FIFO                                                                  |  |
| err_mode       | 0 to 2                                                                    | Error mode                                                                                                  |  |
| Default: 1     |                                                                           | 0: underflow/overflow with pointer latched checking                                                         |  |
|                |                                                                           | ■ 1: underflow/overflow latched checking                                                                    |  |
|                |                                                                           | 2: underflow/overflow unlatched checking                                                                    |  |
| rst_mode       | 0 or 1                                                                    | Reset mode                                                                                                  |  |
|                | Default: 1                                                                | ■ 0: Asynchronous reset                                                                                     |  |
|                |                                                                           | ■ 1: Synchronous reset                                                                                      |  |
| byte_order     | rder 0 or 1 Order of bytes or subword [subword < 8 bits > subword] within |                                                                                                             |  |
|                | Default: 0                                                                | ■ 0: First byte is in most significant bits position                                                        |  |
|                |                                                                           | ■ 1: First byte is in the least significant bits position                                                   |  |

#### Table 1-3 Synthesis Implementations

| Implementation Name Function |                 | License Feature Required |  |
|------------------------------|-----------------|--------------------------|--|
| str <sup>a</sup>             | Synthesis model | DesignWare <sup>b</sup>  |  |

a. To achieve low-power benefits in sub-module implementations, you need to enable minPower; for details, see "Enabling minPower" on page 20.

b. For releases prior to P-2019.03, the DesignWare-LP license feature is required to achieve low-power benefits.

#### Table 1-4 Simulation Models

| Model                                    | Function                             |
|------------------------------------------|--------------------------------------|
| DW03.DW_ASYMFIFOCTL_S1_DF_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw03/src/DW_asymfifoctl_s1_df_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_asymfifoctl_s1_df.v        | Verilog simulation model source code |

#### Table 1-5 Error Mode Description

| error_mode | Error Types Detected                      | Error Output | diag_n    |
|------------|-------------------------------------------|--------------|-----------|
| 0          | Underflow/Overflow and Pointer Corruption | Latched      | Connected |
| 1          | Underflow/Overflow                        | Latched      | N/C       |
| 2          | Underflow/Overflow                        | Not Latched  | N/C       |

The input data bit width of DW\_asymfifoctl\_s1\_df can be different than its output data bit width, but must have an integer-multiple relationship (the input bit width being a multiple of the output bit width or vice versa). In other words, either of the following conditions must be true:

- The data\_in\_width =  $K \times data_out_width$ , or
- The data\_out\_width =  $K \times data_in_width$

where *K* is a positive integer.

The RAM must have:

- A synchronous write port,
- Either asynchronous or synchronous read port, and
- The bit width must be the maximum of *data\_in\_width* or *data\_out\_width*.

The asymmetric FIFO controller provides address generation, write-enable logic, flag logic, and operational error detection logic.

The almost empty and almost full flags are dynamically set by the ae level and af thresh inputs.

Parameterizable features include:

- FIFO depth (up to 24 address bits or 16,777,216 locations),
- Level of error detection, and
- Type of reset (asynchronous or synchronous).

You specify these parameters when the controller is instantiated in the design.

Figure 1-1 on page 5 shows a typical application of the asymmetric FIFO controller.

SolvNetPlus



Figure 1-1 Example Usage of DW\_asymfifoctl\_s1\_df

## Writing to the FIFO (Push) for data\_in\_width > data\_out\_width Case

For cases where  $data_in\_width > data_out\_width$  (assuming that  $data_in\_width = K \times data\_out\_width$ , where K is an integer larger than 1):

- The flush n input pin is not used (at the system level, this pin should not be connected so that it is removed upon synthesis),
- The part\_wd output pin is tied low, and
- The data in bus is connected directly to the wr data output bus.

For an example of this case, see Figure 1-2 on page 6.

The wr addr and we noutput ports of the FIFO controller provide the write address and synchronous write enable to the FIFO.

A push is executed when the push\_req\_n input is asserted (low) and the full flag is inactive (low) at the rising edge of clk.

Asserting push\_req\_n when the full flag is inactive causes the following events to occur:

- The we n is asserted immediately, preparing for a write to the RAM on the next clock, and
- On the next rising edge of clk, the wr\_addr signal is incremented.

Thus, the RAM is written, and wr\_addr (which always points to the address of the next word to be pushed) is incremented on the same rising edge of clk—the first clock after push\_req\_n is asserted. This means that push\_req\_n must be asserted early enough to propagate through the FIFO controller to the RAM before the next clock.

Figure 1-2 Example of Asymmetric FIFO Controller Operation



#### **Write Errors**

An error occurs if a push is attempted while the FIFO is full. That is, if:

- The push req n input is asserted (low),
- The full flag is active (high), and
- The pop\_req\_n input is inactive (high), or there is more than one byte (or subword) left in the output buffer.

You should not use the DW\_asymfifoctl\_s1\_df to perform a simultaneous push and pop when the RAM is full. For detailed information, see "Simultaneous Push and Pop for data\_in\_width > data\_out\_width Case" on page 11.

## Writing to the FIFO (Push) for data\_in\_width = data\_out\_width Case

In this case, the FIFO controller is a symmetric I/O FIFO controller. Its function is the same as DW\_fifoctl\_s1\_df, except for the part\_wd, flush, and ram\_full pins, which are unused.

The wr\_addr and we\_n output ports of the FIFO controller provide the write address and synchronous write enable to the FIFO.

The data\_in bus is connected directly to the wr\_data bus and the data\_out bus is connected directly to the rd data bus.

A push is executed when the push req n input is asserted (low), and either:

■ The full flag is inactive (low),

or:

- The full flag is active (high), and
- The pop req n input is asserted (low).

Thus, a push can occur even if the FIFO is full, as long as a pop is executed in the same cycle.

Asserting push\_req\_n in either of the above cases causes the following events to occur:

- The we\_n is asserted immediately, preparing for a write to the RAM on the next clock, and
- On the next rising edge of clk, wr addr is incremented.

Thus, the RAM is written, and wr\_addr (which always points to the address of the next word to be pushed) is incremented on the same rising edge of clk—the first clock after push\_req\_n is asserted. This means that push\_req\_n must be asserted early enough to propagate through the FIFO controller to the RAM before the next clock.

#### Write Errors

An error occurs if a push is attempted while the FIFO is full. That is, if:

- The push req n input is asserted (low),
- The full flag is active (high), and
- The pop req n input is inactive (high).

## Writing to the FIFO (Push) for data\_in\_width < data\_out\_width Case

For cases where  $data_in_width < data_out_width$  (assuming that  $data_out_width = K \times data_in_width$ , where K is an integer larger than 1), every byte (or subword) written to FIFO is first assembled into a full word with  $data_out_width$  bits. For an example of this case, see Figure 1-2 on page 6.

The wr\_addr and we\_n output ports of the FIFO controller provide the write address and synchronous write enable to the FIFO.

A push of the partial word is executed at the rising edge of clk when the push\_req\_n input is asserted (low), and either:

■ The full flag is inactive (low),

or,

- The full flag is active (high), and
- The pop req n input is asserted (low).

Thus, a push can occur even if the FIFO is full, as long as a pop is executed in the same cycle.

For every byte (or subword) to be written, push\_req\_n toggles. Asserting push\_req\_n K times in either of the cases that enables a push causes the word accumulated in the input buffer (the first K-1 bytes are registered, the last byte is not; see Figure 1-2 on page 6) to be written to the next available location in the FIFO memory. This write occurs on the clk following the assertion of push\_req\_n.

The order of the input bytes within a word is determined by the byte order parameter.

The data at the data\_in port of the RAM must be stable for a setup time before the rising edge of clk and push\_req\_n must be asserted early enough to propagate through the FIFO controller to the RAM before the next clock.

In this way, the RAM is written, and  $wr_addr$  (which always points to the address of the next word to be pushed) is incremented on the same rising edge of clk – the first clock after push req n is asserted K times.

#### **Partial Words**

When a partial word is in the input buffer register, output flag part\_wd is active (high). After K times pushing, K bytes (or subwords) are assembled into a full word (K-1 bytes in the input buffer register and the last byte on the data\_in bus) by a combinational circuit. This achieves single clock cycle operation for the asymmetric FIFO controller.

This full word is then written into memory. When a full word is sent from the input buffer into memory, part wd goes inactive (low).

The order of bytes within a word is determined by the byte order parameter.

### Flushing the RAM

A flush feature is provided for the *data\_in\_width* < *data\_out\_width* case. The flush feature pushes a partial word into memory when there are less than *K* bytes accumulated in the input buffer. The input buffer is cleared after a flush.

A flush is allowed:

- When *N* bytes have been read since the last complete word (where  $0 \le N \le K$ ), and
- The sender device has no byte (or subword) to send at this moment,

while

■ The higher level system requires that the receiver device be able to read these *N* bytes of data (from memory) without waiting,

or,

■ For data byte word alignment.

The sender device activates flush\_n so that the *N* bytes data are pushed into memory without waiting for a complete word to be assembled.

When the receiver reads the partial word from the memory, the "leftover" bytes of the partial word (K - N) are filled with 0s.

A flush is executed when the flush n input is asserted (low), and either:

■ The ram full flag is inactive (low),

or,

- The ram\_full flag is active (high), and
- The pop\_req\_n input is asserted (low)

at the rising edge of clk.

Asserting flush\_n in either of the above cases causes the partial word accumulated in the input buffer to be written to the next available location in the FIFO memory. This write occurs on the clk following the assertion of flush n.

Flushing the FIFO when the input buffer is empty (when the part\_wd flag is inactive) is a "null" operation and does not cause an error.

### Simultaneous Flush and Push, and Flush and Pop

Flush can occur at the same time as a push. When flush\_n and push\_req\_n are active at the same time, the FIFO:

- Flushes the partial word in the input buffer, if any, into the memory, and
- Pushes the byte in the data\_in bus into the input buffer

in the same clock cycle.

For a detailed description, see "Reading from the FIFO (Pop) for data\_in\_width < data\_out\_width Case" on page 11.

#### Write Errors

An error occurs if a push is attempted while the FIFO is full. That is, if:

- The push req n input is active (low),
- The empty flag is active (high), and
- The pop req n input is inactive (high).

## Reading from the FIFO (Pop) for data\_in\_width > data\_out\_width Case

For cases where data in width > data out width (assuming that data in width =  $K \times data$  out width, where Kis an integer larger than 1), the number of bits in a word stored in memory is *data\_in\_width*. The bit width for each out-going byte (or subword) is data\_out\_width.

For every byte (or subword) to be read, pop req n toggles. Each pop causes one byte (or subword) to be read. Toggling pop req n K times results in one full word (data\_in\_width bits) being read.

The order of the output bytes within a word is determined by the byte order parameter.

The read port of the memory can be either synchronous or asynchronous. In either case, the data out output port of the DW\_asymfifoctl\_s1\_df provides prefetchable data (the next byte of memory read data to be read) to the output logic.

For RAMs with a synchronous read port, the output data is captured in the output stage of the memory. For RAMs with an asynchronous read port, the output data is captured by the next stage of logic after the FIFO.

A pop operation occurs when pop req n is asserted (low) when the FIFO is not empty. Asserting pop req n when the output buffer is not empty causes the data out output port to be switched to the next byte (or subword) on the next rising edge of clk. Thus, memory read data must be captured on the clk following the assertion of pop req n.

For details of the pop operation, see "Timing Waveforms" on page 17.

#### **Read Errors**

An error occurs if:

- The pop req n input is active (low), and
- The empty flag is active (high).

## Reading from the FIFO (Pop) for data\_in\_width = data\_out\_width Case

In this case, the FIFO controller is a symmetric FIFO controller. Its function is the same as the DW\_fifoctl\_s1\_df, except for the part wd, flush, and ram full pins, which are unused.

The read port of the RAM can be either synchronous or asynchronous. In either case, the rd addr output port of the DW\_fifoctl\_s1\_sf provides the read address to the RAM. The rd addr output bus always points to, thus prefetches, the next word of RAM read data to be popped.

A pop operation occurs when pop req n is asserted (low), as long as the FIFO is not empty. Asserting pop req n causes the rd addr pointer to be incremented on the next rising edge of clk. Thus, the RAM read data must be captured on the clk following the assertion of pop req n. For RAMs with a synchronous read port, the output data is captured in the output stage of the RAM. For RAMs with an asynchronous read port, the output data is captured by the next stage of logic after the FIFO.

#### Read Errors

An error occurs if:

- The pop req n input is active (low), and
- The empty flag is active (high).

### Reading from the FIFO (Pop) for data\_in\_width < data\_out\_width Case

For cases where  $data_in_width < data_out_width$  (assuming that  $data_out_width = K \times data_in_width$ , where K is an integer larger than 1), the number of bits in a word stored in memory is  $data_out_width$ . The rd\_data bus is connected directly to the data out bus.

The read port of the RAM can be either synchronous or asynchronous. In either case, the byte (or subword) to be read is available for prefetching at the FIFO data\_out output port.

For RAMs with a synchronous read port, output data is captured in the output stage of the RAM. For RAMs with an asynchronous read port, output data is captured by the next stage of logic after the FIFO.

A pop operation occurs when pop\_req\_n is asserted (low) as long as the FIFO is not empty. The operation occurs on the next rising edge of clk. Thus, the RAM read data must be captured on the clk following the assertion of pop\_req\_n.

For details of the pop operation, see "Timing Waveforms" on page 17.

#### **Read Errors**

An error occurs if:

- The pop req n input is active (low), and
- The empty flag is active (high).

### Simultaneous Push and Pop for data\_in\_width > data\_out\_width Case

You should not use the DW\_asymfifoctl\_s1\_df to perform a simultaneous push and pop when the RAM is full.

For  $data_in\_width > data_out\_width$  ( $data_in\_width = K \times data\_out\_width$ ) cases, push and pop can occur at the same time if:

- The FIFO is neither full nor empty, or
- The FIFO is full but there is only one byte (or subword) in the output buffer.

With the FIFO neither full nor empty (both full and empty signals inactive), the byte to be read is available for prefetching at the FIFO data\_out output port.

When pop\_req\_n and push\_req\_n are both asserted, the following events occur on the next rising edge of clk:

- Pop data is captured by the next stage of logic after the FIFO, and
- Write data is pushed into the location pointed to by wr\_addr.

When the FIFO is full, a simultaneous push and pop can occur only if K-1 bytes of the word in the output buffer have been already read, and there is only one byte (or subword) left to be read in the output buffer; otherwise, simultaneous push and pop causes an overflow error; see Figure 1-2 on page 6.

There are no flags that indicate a valid or invalid condition for a simultaneous push and pop when the FIFO is full. Designers who want an indication of this condition should create the necessary logic external to the FIFO controller.

When the FIFO is empty, simultaneous push and pop causes an error, since there is no pop data to prefetch.

## Simultaneous Push and Pop for data\_in\_width = data\_out\_width Case

In this case, the FIFO controller is a symmetric FIFO controller. Its function is the same as DW\_fifoctl\_s1\_df, except for the part\_wd, flush, and ram\_full pins, which are unused. The data\_in bus is connected directly to wr\_data, and rd\_data is connected directly to the data\_out bus.

Push and pop can occur at the same time if there is data in the FIFO, even when the FIFO is full. With the FIFO not empty, rd\_addr is pointing to the next address to be popped, and the pop data is available to be prefetched at the RAM output.

When pop\_req\_n and push\_req\_n are both asserted, the following events occur on the next rising edge of clk:

- Pop data is captured by the next stage of logic after the FIFO, and
- The new data is pushed into the same location from which the data was popped.

Thus, there is no conflict in a simultaneous push and pop when the FIFO is full. A simultaneous push and pop cannot occur when the FIFO is empty, since there is no pop data to prefetch.

## Simultaneous Push and Pop for data\_in\_width < data\_out\_width Case

For  $data_in\_width < data_out\_width$  ( $data\_out\_width = K \times data_in\_width$ ) cases, a push (or flush) and pop can occur at the same time if the FIFO is not empty. With the FIFO not empty (empty active), pop data is available to be prefetched at the FIFO (and the RAM) output.

When pop\_req\_n and push\_req\_n are both asserted, the following events occur on the next rising edge of clk:

- Pop data is captured by the next stage of logic after the FIFO,
- Write data is pushed into the input buffer, which may in turn be pushed into the next available memory location after *K* pushes, and
- For a flush, the partial word in the input buffer is pushed into the next available memory location. The input buffer is cleared after the flush.

For *data\_in\_width* < *data\_out\_width* cases, there is no conflict in a simultaneous push and pop when the FIFO is full, because the bit width of the outgoing word is larger than that of the incoming byte (or subword), and the incoming data speed is slower than the outgoing data speed.

When the FIFO is empty, a simultaneous push and pop causes an error, since there is no pop data to prefetch.

#### Reset

#### rst mode

This parameter selects whether reset is:

- Asynchronous (rst mode = 0), or
- Synchronous (rst mode = 1).

If the asynchronous mode is selected, asserting rst n (setting it low) immediately causes the:

■ Internal address pointers to be set to 0,

- Input or output buffer to be reset, and
- Flags and error output to be initialized.

If the synchronous mode is selected, the internal address pointers, flags, and error outputs are initialized at the rising edge of clk after rst n is asserted.

The error output and flags are initialized as follows:

- The empty and almost empty are initialized to 1, and
- All other flags and the error output are initialized to 0.

#### **Errors**

#### err\_mode

The *err\_mode* parameter determines which possible fault conditions are detected, and whether the error output remains active until reset or only for the clock cycle in which the error was detected.

When *err\_mode* is set to 0 at design time, the diag\_n input provides an unconditional synchronous reset to the value of the rd\_addr output port. This can be used to intentionally cause the FIFO address pointers to become corrupted, forcing a pointer inconsistency-type error.

For normal operation when  $err\_mode = 0$ , diag\_n should be driven inactive (high). When  $err\_mode$  is set to 1 or 2, the diag\_n input is ignored (unconnected).

#### error

The error output indicates a fault in the operation of the FIFO control logic. There are several possible causes for the error output to be activated:

- 1. Overflow (push with no pop while full; or, flush while ram\_full for data\_in\_width < data\_out\_width case; or, push when full is active and the output buffer has more than one byte for data\_in\_width > data\_out\_width case).
- 2. Underflow (pop while empty).
- 3. Empty pointer mismatch (rd addr ≠ wr addr when empty).
- 4. Full pointer mismatch (rd addr ≠ wr addr when full).
- 5. In between pointer mismatch (rd addr = wr addr when neither empty nor full).

When  $err\_mode = 0$ , all five causes are detected, and the error output (once activated) remains active until reset. When  $err\_mode = 1$ , only causes 1 and 2 are detected, and the error output (once activated) remains active until reset. When  $err\_mode = 2$ , only causes 1 and 2 are detected, and the error output only stays active for the clock cycle in which the error is detected. For error mode descriptions, see Table 1-5 on page 4. The error output is set low when rst\_n is applied.

### **Controller Status Flag Outputs**

For operation of the status flags, see Figure 1-3 on page 15.

#### empty

The empty output indicates that there are no words or bytes in the FIFO available to be popped. The empty output is set high when rst\_n is applied.

#### almost\_empty

The almost\_empty output is asserted when there are no more than ae\_level words currently in the FIFO available to be popped. The value present on the ae\_level port defines the almost empty threshold. The almost\_empty output is updated only on the rising edge of clk. This signal is useful for preventing the FIFO from underflowing. The almost empty output is set high when rst n is applied.

#### half\_full

The half\_full output is active (high) when at least half the FIFO memory locations are occupied. The half\_full output is set low when rst\_n is applied.

#### almost full

The almost\_full output is asserted when there are no more than depth - af\_thresh empty locations in the FIFO. The value present on the af\_thresh port defines the almost full threshold. The almost\_full output is updated only on the rising edge of clk. This signal is useful for preventing the FIFO from overflowing. The almost\_full output is set low when rst\_n is applied.

#### full

The full output indicates that the FIFO is full, and there is no space available for push data. The full output is set low when rst\_n is applied.

#### ram\_full

The ram\_full output is used for the *data\_in\_width* < *data\_out\_width* case. The ram\_full output indicates that the RAM is full, and there is no space available for flushing a partial word into the RAM. The ram\_full output is set low when rst n is applied.

For  $data_{in}$ \_width  $\leq data_{out}$ \_width, ram full is tied to the full output.

#### part\_wd

This flag is only used for the <code>data\_in\_width < data\_out\_width</code> case. The <code>part\_wd</code> output indicates that the FIFO has a partial word accumulated in the input buffer. The <code>part\_wd</code> output is set low when <code>rst\_n</code> is applied.

For  $data_in\_width \ge data\_out\_width$ , part\_wd is tied low since the input data is always a full word.

### **Application Notes**

The ae level value is supplied by the application, and is chosen:

- To allow input flow control logic to interrupt the pushing of data into the FIFO, or
- to Give output flow control logic enough time to begin popping data.

Systems can characterize their own response times dynamically against the data stream. This allows you to set the ae level as tight as practical on the fly for optimal utilization of FIFO memory.

The af thresh value is supplied by the application, and is chosen:

- To give output flow control logic enough time to begin popping data, or
- To allow input flow control logic to interrupt the pushing of data into the FIFO.

Systems can characterize their own response times dynamically against the data stream. This allows you to set the almost\_full flag trip point on the fly for optimal utilization of FIFO memory.

Figure 1-3 DW\_asymfifoctl\_s1\_df FIFO Status Flags



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

The following figures show timing diagrams for various conditions of DW\_asymfifoctl\_s1\_df.

Figure 1-4 Status Flag Timing Waveforms for data\_in\_width > data\_out\_width





Figure 1-5 Status Flag Timing Waveforms for data\_in\_width < data\_out\_width





<sup>\*</sup> Note: B16 and B17 are only two of three slices needed for what would be W6 (not shown). B16 and B17 are waiting in a 2-stage assembly buffer in this case, as shown in Figure 1-2 on page 6, where B16 and B17 represent byte1 and byte2, respectively, for *data\_in\_width* = 8.

Figure 1-6 Status Flag Timing Waveforms for Flush Operation



Figure 1-7 Reset Timing Waveforms



### **Enabling minPower**

You can instantiate this component without enabling minPower, but to achieve power savings from the low-power implementation (at a sub-level--see Table 1-3 on page 3), you must enable minPower optimization, as follows:

- Design Compiler
  - Version P-2019.03 and later:

```
set power enable minpower true
```

Before version P-2019.03 (requires the DesignWare-LP license feature):

```
set synthetic_library {dw_foundation.sldb dw_minpower.sldb}
set link library {* $target library $synthetic library}
```

**Fusion Compiler** 

Optimization for minPower is enabled as part of the total\_power metric setting. To enable the total\_power metric, use the following:

```
set qor strategy -stage synthesis -metric total power
```

### **Related Topics**

- Memory FIFO Overview
- DesignWare Building Block IP User Guide

21

### **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 asymfifoctl s1 df inst is
  generic (inst data in width : INTEGER := 8;
           inst data out width : INTEGER := 16;
                              : INTEGER := 8;
           inst depth
           inst err mode
                              : INTEGER := 1;
           inst rst mode
                              : INTEGER := 1;
           inst byte order
                            : INTEGER := 0 );
 port (inst clk
                          : in std logic;
                           : in std logic;
        inst rst n
        inst push req n : in std logic;
        inst flush n
                           : in std logic;
        inst pop req n
                          : in std logic;
                           : in std logic;
        inst diag n
        inst data in
                        : in std logic vector(inst data in width-1 downto 0);
                        : in std logic vector(maximum(inst data in width,
        inst rd data
                                            inst data out width) -1 downto 0);
      inst ae level : in std logic vector(bit width(inst depth)-1 downto 0);
      inst af thresh : in std logic vector(bit width(inst depth)-1 downto 0);
       we n inst
                           : out std logic;
        empty inst
                           : out std logic;
        almost empty inst : out std logic;
        half full inst
                           : out std logic;
        almost full inst
                           : out std logic;
        full inst
                           : out std logic;
        ram full inst
                          : out std logic;
        error inst
                           : out std logic;
       part wd inst
                           : out std logic;
       wr data inst
                           : out std logic vector(maximum(inst data in width,
                                            inst data out width) -1 downto 0);
       wr addr inst : out std logic vector(bit width(inst depth)-1 downto 0);
       rd addr inst : out std logic vector(bit width(inst depth)-1 downto 0);
       data out inst : out std logic vector(inst data out width-1 downto 0)
                                                                                  );
end DW asymfifoctl s1 df inst;
```

```
architecture inst of DW asymfifoctl s1 df inst is
begin
  -- Instance of DW asymfifoctl s1 df
  U1 : DW asymfifoctl s1 df
    generic map (data in width => inst data in width,
                 data out width => inst data out width,
                 depth => inst depth, err mode => inst err mode,
                 rst mode => inst rst mode,
                                              byte order => inst byte order )
    port map (clk => inst clk,
                                 rst n => inst rst n,
              push req n => inst push req n,
                                              flush n => inst flush n,
              pop req n => inst pop req n, diag n => inst diag n,
              data in => inst data in,
                                       rd data => inst rd data,
              ae level => inst ae level, af thresh => inst af thresh,
              we n => we n inst,
                                   empty => empty inst,
              almost empty => almost empty inst,
              half full => half full inst, almost full => almost full inst,
              full => full inst, ram full => ram full inst,
              error => error inst,
                                   part wd => part wd inst,
              wr data => wr data inst, wr addr => wr addr inst,
              rd addr => rd addr inst,
                                       data out => data out inst );
end inst;
-- pragma translate off
configuration DW asymfifoctl s1 df inst cfg inst
 of DW asymfifoctl s1 df inst is
  for inst
  end for; -- inst
end DW asymfifoctl s1 df inst cfg inst;
-- pragma translate on
```

23

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

```
module DW asymfifoctl s1 df inst(inst clk, inst rst n, inst push req n,
    inst flush n, inst pop req n, inst diag n, inst data in, inst rd data,
    inst ae level, inst af thresh, we n inst, empty inst, almost empty inst,
   half full inst, almost full inst, full inst, ram full inst, error inst,
   part wd inst, wr data inst, wr addr inst, rd addr inst, data out inst );
 parameter data in width = 8;
 parameter data out width = 16;
 parameter depth = 8;
 parameter err mode = 1;
 parameter rst mode = 1;
 parameter byte order = 0;
  `define bit width depth 3 // ceil(log2(depth))
  input inst clk;
  input inst rst n;
  input inst push req n;
  input inst flush n;
  input inst pop req n;
  input inst diag n;
  input [data in width-1:0] inst data in;
  input [((data in width > data out width)?
         data in width : data out width) -1 : 0] inst rd data;
  input [`bit width depth-1 : 0] inst ae level;
  input ['bit width depth-1 : 0] inst af thresh;
  output we n inst;
  output empty inst;
  output almost empty inst;
  output half full inst;
  output almost full inst;
  output full inst;
  output ram full inst;
  output error inst;
  output part wd inst;
  output [((data in width > data out width)?
          data in width : data out width) -1 : 0] wr data inst;
  output [`bit width depth-1 : 0] wr_addr_inst;
  output ['bit width depth-1 : 0] rd addr inst;
  output [data out width-1: 0] data out inst;
```

```
// Instance of DW asymfifoctl s1 df
 DW asymfifoctl s1 df #(data in width, data out_width, depth, err_mode,
                         rst mode, byte order)
   U1 (.clk(inst clk),
                          .rst n(inst rst n),
                                                .push req n(inst push req n),
        .flush n(inst flush n),
                                 .pop req n(inst pop req n),
        .diag n(inst diag n),
                              .data in(inst data in),
        .rd data(inst rd_data),
                                .ae level(inst ae level),
        .af thresh(inst af thresh),
                                     .we n(we n inst),
                                                         .empty(empty inst),
         .almost empty(almost empty inst), .half full(half full inst),
         .almost full(almost full inst),
                                          .full(full inst),
         .ram full(ram full inst), .error(error inst),
         .part_wd(part_wd_inst), .wr_data(wr_data_inst),
         .wr_addr(wr_addr_inst), .rd_addr(rd_addr_inst),
         .data out(data out 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 16 and added the DW_SUPPRESS_WARN<br/>macro</li> </ul> |  |
| October 2019 | DWBB_201903.5 | ■ Added the "Disabling Clock Monitor Messages" section                                                                                                             |  |
| March 2019   | DWBB_201903.0 | <ul> <li>Clarified license requirements in Table 1-3 on page 3</li> <li>Added "Enabling minPower" on page 20</li> </ul>                                            |  |
| January 2019 | DWBB_201806.5 | ■ Updated example in "HDL Usage Through Component Instantiation - VHDL" on page 21                                                                                 |  |
| October 2017 | DWBB_201709.1 | ■ Replaced the synthesis implementations in Table 1-3 on page 3 with the str implementation                                                                        |  |
|              |               | 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