



# DW\_fifo\_s2\_sf

# Synchronous (Dual-Clock) FIFO with Static Flags

Version, STAR and Download Information: IP Directory

### **Features and Benefits**

# **Revision History**

- Fully registered synchronous flag output ports
- Single clock cycle push and pop operations
- Parameterized word width
- Parameterized word depth
- Separate status flags for each clock system
- FIFO empty, half full, and full flags
- Parameterized almost full and almost empty flag thresholds

FIFO push error (overflow) and pop error (underflow) flags

## data\_in push\_empty push\_ae push req n push\_hf push\_af >clk\_push push full push\_error pop\_req\_n data out pop\_empty pop\_ae clk pop pop\_hf pop\_af pop\_full pop\_error rst\_n

## **Description**

The DW\_fifo\_s2\_sf component is a dual independent clock FIFO. It combines the FIFO controller of the DW\_fifoctl\_s2\_sf component and the flip-flop-based RAM of the DW\_ram\_r\_w\_s\_dff component.

The FIFO provides parameterized width and depth, and a full complement of flags (full, almost full, half full, almost empty, empty, and error) for both of the clock domains.

Table 1-1 describes the pins for the DW\_fifo\_s2\_sf component and the design parameters are described in Table 1-2 on page 2.

Table 1-1 Pin Description

| Pin Name   | Width      | Direction | Function                                                                 |
|------------|------------|-----------|--------------------------------------------------------------------------|
| clk_push   | 1 bit      | Input     | Input clock for push interface                                           |
| clk_pop    | 1 bit      | Input     | Input clock for pop interface                                            |
| rst_n      | 1 bit      | Input     | Reset input, active low                                                  |
| push_req_n | 1 bit      | Input     | FIFO push request, active low                                            |
| pop_req_n  | 1 bit      | Input     | FIFO pop request, active low                                             |
| data_in    | width bits | Input     | FIFO data to push                                                        |
| push_empty | 1 bit      | Output    | FIFO empty <sup>a</sup> output flag synchronous to clk_push, active high |

Table 1-1 Pin Description (Continued)

| Pin Name   | Width      | Direction | Function                                                                                                                     |  |
|------------|------------|-----------|------------------------------------------------------------------------------------------------------------------------------|--|
| push_ae    | 1 bit      | Output    | FIFO almost empty <sup>a</sup> output flag synchronous to clk_push, active high (determined by <i>push_ae_lvl</i> parameter) |  |
| push_hf    | 1 bit      | Output    | FIFO half full <sup>a</sup> output flag synchronous to clk_push, active high                                                 |  |
| push_af    | 1 bit      | Output    | FIFO almost full <sup>a</sup> output flag synchronous to clk_push, active high (determined by <i>push_af_lvl</i> parameter)  |  |
| push_full  | 1 bit      | Output    | FIFO full <sup>a</sup> output flag synchronous to clk_push, active high                                                      |  |
| push_error | 1 bit      | Output    | FIFO push error (overrun) output flag synchronous to clk_push, active high                                                   |  |
| pop_empty  | 1 bit      | Output    | FIFO empty <sup>b</sup> output flag synchronous to clk_pop, active high                                                      |  |
| pop_ae     | 1 bit      | Output    | FIFO almost empty <sup>b</sup> output flag synchronous to clk_pop, active high (determined by <i>pop_ae_lvl</i> parameter)   |  |
| pop_hf     | 1 bit      | Output    | FIFO half full <sup>b</sup> output flag synchronous to clk_pop, active high                                                  |  |
| pop_af     | 1 bit      | Output    | FIFO almost full <sup>b</sup> output flag synchronous to clk_pop, active high (determined by <i>pop_af_lvl</i> parameter)    |  |
| pop_full   | 1 bit      | Output    | FIFO full <sup>b</sup> output flag synchronous to clk_pop, active high                                                       |  |
| pop_error  | 1 bit      | Output    | FIFO pop error (under-run) output flag synchronous to clk_pop, active high                                                   |  |
| data_out   | width bits | Output    | FIFO data to pop                                                                                                             |  |

a. As perceived by the push interface.

**Table 1-2** Parameter Description

| Parameter   | Values                              | Description                                                                                                                                             |
|-------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| width       | 1 to 2048<br>Default: 8             | Width of the data_in and data_out buses                                                                                                                 |
| depth       | 4 to 1024<br>Default: 8             | Number of words that can be stored in the FIFO                                                                                                          |
| push_ae_lvl | 1 to <i>depth</i> - 1<br>Default: 2 | Almost empty level for the <code>push_ae</code> output port (the number of words in the FIFO at or below which the <code>push_ae</code> flag is active) |
| push_af_lvl | 1 to <i>depth</i> - 1<br>Default: 2 | Almost full level for the push_af output port (the number of empty memory locations in the FIFO at which the push_af flag is active.)                   |
| pop_ae_lvl  | 1 to <i>depth</i> - 1<br>Default: 2 | Almost empty level for the pop_ae output port (the number of words in the FIFO at or below which the pop_ae flag is active)                             |

b. As perceived by the pop interface.

Table 1-2 Parameter Description (Continued)

| Parameter  | Values                              | Description                                                                                                                                                               |
|------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pop_af_lvl | 1 to <i>depth</i> - 1<br>Default: 2 | Almost full level for the pop_af output port (the number of empty memory locations in the FIFO at which the pop_af flag is active.)                                       |
| err_mode   | 0 or 1<br>Default: 0                | Error mode:  0: Stays active until reset [latched]  1: Active only as long as error condition exists [unlatched])                                                         |
| push_sync  | 1 to 3<br>Default: 2                | Push flag synchronization mode:  1: Single register synchronization from pop pointer 2: Double register 3: Triple register                                                |
| pop_sync   | 1 to 3<br>Default: 2                | Pop flag synchronization mode:  1: Single register synchronization from push pointer 2: Double register 3: Triple register                                                |
| rst_mode   | 0 to 3<br>Default: 0                | Reset mode:  O: Asynchronous reset including memory  1: Synchronous reset including memory  2: Asynchronous reset excluding memory  3: Synchronous reset excluding memory |

## Table 1-3 Synthesis Implementations

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

### Table 1-4 Simulation Models

| Model                             | Function                             |
|-----------------------------------|--------------------------------------|
| DW06.DW_FIFO_S2_SF_CFG_SIM        | Design unit name for VHDL simulation |
| dw/dw06/src/DW_fifo_s2_sf_sim.vhd | VHDL simulation model source code    |
| dw/sim_ver/DW_fifo_s2_sf.v        | Verilog simulation model source code |

#### Table 1-5 Push Interface Function Table

| push_req_n | push_full | Action                                                                 | push_err |
|------------|-----------|------------------------------------------------------------------------|----------|
| 0          | 0         | Push operation                                                         | No       |
| 0          | 1         | Overrun; incoming data dropped (no action other than error generation) | Yes      |
| 1          | Х         | No action                                                              | No       |

#### Table 1-6 Pop Interface Function Table

| pop_req_n | pop_empty | Action                                           | pop_err |
|-----------|-----------|--------------------------------------------------|---------|
| 0         | 0         | Pop operation                                    | No      |
| 0         | 1         | Underrun (no action other than error generation) | Yes     |
| 1         | Х         | No action                                        | No      |

# Writing to the FIFO (Push)

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

With <code>push\_req\_n</code> input asserted and <code>push\_full</code> inactive, the FIFO prepares to write the value at the <code>data\_in</code> input port to the internal RAM. On the next <code>clk\_push</code>, the data is written into the RAM and the internal write address pointer is advanced.

#### Write Errors

An error occurs if a push operation is attempted while the FIFO is full (as perceived by the push interface). That is, if:

- The push\_req\_n input is asserted (low), and
- The push full flag is active (high)

on the rising edge of clk\_push, the push\_error output goes active. When a push error (overrun) occurs, the data word that the application attempted to push onto the FIFO is lost. After the push error, other than the lost data, the FIFO remains in a valid full state and can continue to operate properly with respect to the data in the FIFO before the push error occurred.

For details of the push operation, refer to "Timing Waveforms" on page 13.

# Reading from the FIFO (Pop)

A pop operation occurs when pop\_req\_n is asserted (low) and the pop\_empty flag is not active (low) (the FIFO is not empty).

Asserting pop\_req\_n while pop\_empty is not active causes the internal read pointer to be incremented on the next rising edge of clk\_pop. Thus, the RAM read data (available at the data\_out output port) must be captured on the rising edge of clk\_pop following the assertion of pop\_req\_n.

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

Figure 1-1 on page 5 shows an internal block diagram of the FIFO.

Figure 1-1 DW\_fifo\_s2\_sf Block Diagram



## **Read Errors**

An error occurs if a pop operation is attempted while the FIFO is empty (as perceived by the pop interface). That is, if:

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

on the rising edge of clk\_pop, the pop\_error output goes active. When a pop error (i.e. underrun) occurs, no action (other than the error flag) is taken. After the pop error, the FIFO remains in a valid empty state and can continue to operate properly.

#### Reset

## rst\_mode

This parameter selects whether reset is asynchronous (rst mode = 0 or 2) or synchronous (rst mode = 1 or 3).

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

- Internal address pointers are set to 0
- Flags and error outputs are initialized.

If a synchronous mode is selected, after the assertion of rst\_n, the following are initialized at the rising edge of clk push:

- Write address pointer
- Push flags
- push error output

And at the rising edge of clk pop, the following are initialized:

- Read address pointer
- Pop flags
- pop error output

## Metastability Issues Regarding Reset

To avoid metastability upon reset, assert rst\_n (low) for at least three cycles of the slower of the two clock inputs, clk\_push and clk\_pop. During the assertion of rst\_n and for at least one cycle of clk\_push after rst\_n goes high, push\_req\_n must be inactive (high). In addition, it is recommended that the pop\_req\_n signal also be held inactive for at least one clock cycle of clk\_pop after the release of rst\_n. For an example of this timing, see Figure 1-2.



Because the one input that is critical to proper reset sequencing (push\_req\_n) is in the domain of clk\_push, it is recommended that the reset input, rst\_n, be synchronous to clk\_push.

Figure 1-2 Avoiding Metastability Upon Reset



## **Error Outputs and Flags Status**

The error outputs and flags are initialized as follows:

- The push\_empty, push\_ae, pop\_empty, and pop\_ae are initialized to 1 (high), and
- All other flags and the error outputs are initialized to 0 (low).

If  $rst_mode = 0$  or 1, the RAM array is also initialized when  $rst_n$  is asserted. If  $rst_mode = 2$  or 3, only the address pointers and flag outputs are initialized; the RAM array is not initialized.

# Synchronization Between Clock Systems

Each interface (push and pop) operates synchronous to its own clock: <code>clk\_push</code> and <code>clk\_pop</code>. Each interface is independent, containing its own state machine and flag logic. The pop interface also has the primary read address counter and a synchronized copy of the write address counter. The push interface also has the primary write address counter and a synchronized copy of the read address counter. The two clocks may be asynchronous with respect to each other. The FIFO controller performs inter-clock synchronization so each interface can monitor the actions of the other. This enables the number of words in the FIFO, at any given point in time, to be determined independently by the two interfaces.

The only information that is synchronized across clock domain boundaries is the read or write address generated by the opposite interface. If an address is transitioning while being sampled by the opposite interface (for example, wr\_addr sampled by clk\_pop), sampling uncertainty can occur. By Gray coding the address values that are synchronized across clock domains, this sampling uncertainty is limited to a single bit.

Single-bit sampling uncertainty results in only one of two possible Gray coded addresses being sampled: the previous address or the new address. The uncertainty in the bit that is changing near a sampling clock edge directly corresponds to an uncertainty in whether the new value is captured by the sampling clock edge or whether the previous value is captured (and the new value may be captured by a subsequent sampling clock edge). Thus, there are no errors in sampling Gray coded pointers, just a matter of whether a change of pointer value occurs in time to be captured by a given sampling clock edge or whether it must wait for the next sampling clock edge to be registered

## push\_sync and pop\_sync

The push\_sync and pop\_sync parameters determine the number of register stages (1, 2 or 3) used to synchronize the internal Gray code read pointer to clk\_push (for push\_sync) and internal Gray code write pointer to clk\_pop (for pop\_sync). A value of 1 indicates single-stage synchronization, a value of 2 indicates double-stage synchronization, and a value of 3 indicates triple-stage synchronization.

Single-stage synchronization is only adequate when using very slow clock rates (with respect to the target technology). There must be enough timing slack to allow metastable synchronization events to stabilize and propagate to the pointer and flag registers.



Because timing slack and selection of register types are very difficult to control and metastability characteristics of registers are extremely difficult to ascertain, single-stage synchronization is not recommended.

Double-stage synchronization is desirable when using relatively high clock rates. It allows an entire clock period for metastable events to settle at the first stage before being cleanly clocked into the second stage of the synchronizer. Double-stage synchronization increases the latency between the two interfaces, resulting in flags that are less up to date with respect to the true state of the FIFO.

Triple-stage synchronization is desirable when using very high clock rates. It allows an entire clock period for metastable events to settle at the first stage before being clocked into the second stage of the synchronizer. Then, in the unlikely event that a metastable event propagates into the second stage, the

output of the second stage is allowed to settle for another entire clock period before being clocked into the third stage. Triple-stage synchronization increases the latency between the two interfaces, resulting in flags that are less up to date with respect to the true state of the FIFO.

## **Empty to Not Empty Transitional Operation**

When the FIFO is empty, both push\_empty and pop\_empty are active (high). During the first push (push\_req\_n active (low)), the rising edge of clk\_push writes the first word into the FIFO. The push\_empty flag is driven low.

The pop\_empty flag does not go low until one cycle (of clk\_pop) after the new internal Gray code write pointer has been synchronized to clk\_pop. This can take as long as 2 to 4 cycles (depending on the value of the pop\_sync parameter). For more information, see "Timing Waveforms" on page 13. The system design should allow for this latency in the depth budgeting of the FIFO design.

## **Not Empty to Empty Transitional Operation**

When the FIFO is almost empty, both push\_empty and pop\_empty are inactive (low) and pop\_ae is active (high). During the final pop (pop\_req\_n active (low)), the rising edge of clk\_pop reads the last word out of the FIFO. The pop\_empty flag is driven high.

The push\_empty flag is not asserted (high) until one cycle (of clk\_push) after the new internal Gray code read pointer is synchronized to clk\_push. This can take as long as 2 to 4 cycles (depending on the value of the push\_sync parameter). Refer to the timing diagrams for more information.

You should be aware of this latency when designing the system data flow protocol.

## **Full to Not Full Transitional Operation**

When the FIFO is full, both push\_full and pop\_full are active (high) During the first pop (pop\_req\_n active (low)), the rising edge of clk\_pop reads the first word out of the FIFO. The pop\_full flag is driven low.

The push\_full flag does not go low until one cycle (of clk\_push) after the new internal Gray code read pointer has been synchronized to clk\_push. This can take as long as 2 to 4 cycles (depending on the value of the push\_sync parameter). For more information, see "Timing Waveforms" on page 13.

You should be aware of this latency when designing the system data flow protocol.

## **Not Full to Full Transitional Operation**

When the FIFO is almost full, both push\_full and pop\_full are inactive (low), and push\_af is active (high). During the final push (push\_req\_n active (low)), the rising edge of clk\_push writes the last word into the FIFO. The push full flag is driven high.

The pop\_full flag is not asserted (high) until one cycle (of clk\_pop) after the new internal Gray code write pointer has been synchronized to clk\_pop. This can take as long as 2 to 4 cycles (depending on the value of the pop\_sync parameter). For more information, see "Timing Waveforms" on page 13.

You should allow for this latency in the depth budgeting of the FIFO design.

### **Errors**

#### err mode

The err\_mode parameter determines whether the push\_error and pop\_error outputs remain active until reset (persistent) or for only the clock cycle in which the error is detected (dynamic).

When the err\_mode parameter is set to 0 at design time, persistent error flags are generated. When the err\_mode parameter is set to 1 at design time, dynamic error flags are generated.

#### push\_error

The push\_error output signal indicates that a push request was seen while the push\_full output was active (high) (an overrun error). When an overrun condition occurs, the write address pointer (wr\_addr) cannot advance, and the RAM write enable (we\_n) is not activated.

Therefore, a push request that would overrun the FIFO is, in effect, rejected, and an error is generated. This guarantees that no data already in the FIFO is destroyed (overwritten). Other than the loss of the data accompanying the rejected push request, FIFO operation can continue without reset.

### pop\_error

The pop\_error output signal indicates that a pop request was seen while the pop\_empty output signal was active (high) (an underrun error). When an underrun condition occurs, the read address pointer (rd\_addr) cannot decrement because there is no data in the FIFO to retrieve.

The FIFO timing is such that the logic controlling the pop\_req\_n input would not see the error until "nonexistent" data had already been registered by the receiving logic. This is easily avoided if this logic can pay close attention to the pop\_empty output and thus avoid an underrun completely.

## **Controller Status Flag Outputs**

The two halves of the FIFO controller each have their own set of status flags to indicate their separate view of the state of the FIFO. It is important to note that both the push interface and the pop interface perceives the state of fullness of the FIFO independently, based on information from the opposing interface that is delayed up to three clock cycles for proper synchronization between clock domains.

The push interface status flags respond immediately to changes in state caused by push operations, but there is delay between pop operations and corresponding changes of state of the push status flags. This delay is due to the latency introduced by the registers used to synchronize the internal Gray coded read pointer to clk\_push. The pop interface status flags respond immediately to changes in state caused by pop operations, but there is delay between push operations and corresponding changes of state of the pop status flags. This delay is due to the latency introduced by the registers used to synchronize the internal Gray coded write pointer to clk\_pop.

Most status flags have a property that is potentially useful to the designed operation of the FIFO controller. These properties are described in the following explanations of the flag behaviors.

#### push\_empty

The <code>push\_empty</code> output, active high, is synchronous to the <code>clk\_push</code> input. <code>push\_empty</code> indicates to the <code>push</code> interface that the FIFO is empty. During the first push, the rising edge of <code>clk\_push</code> causes the first word to be written into the FIFO, and <code>push\_empty</code> is driven low.

The action of the last word being popped from a nearly empty FIFO is controlled by the pop interface. Thus, the push\_empty output is asserted only after the new internal Gray code read pointer (from the pop interface) is synchronized to clk push and processed by the status flag logic.

### Property of push\_empty

If push empty is active (high), the FIFO is truly empty. This property does **not** apply to pop empty.

#### push\_ae

The push\_ae output, active high, is synchronous to the clk\_push input. The push\_ae output indicates to the push interface that the FIFO is almost empty when there are no more than push\_ae\_lvl words currently in the FIFO to be popped, as perceived at the push interface.

The push\_ae\_lvl parameter defines the almost empty threshold of the push interface, independent of that of the pop interface. The push\_ae output is useful when you want to push data into the FIFO in bursts (without allowing the FIFO to become empty).

#### Property of push\_ae

If push\_ae is active, the FIFO has at least (*depth* – *push\_ae\_lvl*) available locations. Thus, such status indicates that the push interface can safely and unconditionally push (*depth* – *push\_ae\_lvl*) words into the FIFO. This property guarantees that such a 'blind push' operation does not overrun the FIFO.

### push\_hf

The push\_hf output, active high, is synchronous to the clk\_push input, and indicates to the push interface that the FIFO has at least half of its memory locations occupied, as perceived by the push interface.

#### Property of push\_hf

If  $push_hf$  is inactive (low), the FIFO has at least half of its locations available. Thus, such status indicates that the push interface can safely and unconditionally push (INT(depth/2) + 1) words into the FIFO. This property guarantees that such a 'blind push' operation does not overrun the FIFO.

## push\_af

The push\_af output, active high, is synchronous to the clk\_push input. The push\_af output indicates to the push interface that the FIFO is almost full when there are no more than push\_af\_lvl empty locations in the FIFO as perceived by the push interface.

The push\_af\_lvl parameter defines the almost full threshold of the push interface independent of the pop interface. The push\_af output is useful when more than one cycle of advance warning is needed to stop the flow of data into the FIFO before it becomes full (to avoid a FIFO overrun).

#### Property of push\_af

If push\_af is inactive (low) then the FIFO has at least ( $push\_af\_lvl + 1$ ) available locations. Thus, such status indicates that the push interface can safely and unconditionally push ( $push\_af\_lvl + 1$ ) words into the FIFO. This property guarantees that such a 'blind push' operation does not overrun the FIFO.

#### push full

The push\_full output, active high, is synchronous to the clk\_push input. The push\_full output indicates to the push interface that the FIFO is full. During the final push, the rising edge of clk\_push causes the last word to be pushed, and push\_full is asserted.

The action of the first word being popped from a full FIFO is controlled by the pop interface. Thus, the push\_full output goes low only after the new internal Gray code read pointer from the pop interface is synchronized to clk\_push and processed by the status flag state logic.

### pop\_empty

The pop\_empty output, active high, is synchronous to the clk\_pop input. The pop\_empty output indicates to the pop interface that the FIFO is empty as perceived by the pop interface. The action of the last word being popped from a nearly empty FIFO is controlled by the pop interface. Thus, the pop\_empty output is asserted at the rising edge of clk\_pop that causes the last word to be popped from the FIFO.

10

The action of pushing the first word into an empty FIFO is controlled by the push interface. That means pop\_empty goes low only after the new internal Gray code write pointer from the push interface is synchronized to clk pop and processed by the status flag state logic.

#### pop\_ae

The pop\_ae output, active high, is synchronous to the clk\_pop input. The pop\_ae output indicates to the pop interface that the FIFO is almost empty when there are no more than *pop\_ae\_lvl* words currently in the FIFO to be popped, as perceived by the pop interface.

The pop\_ae\_lvl parameter defines the almost empty threshold of the pop interface, independent of the push interface. The pop\_ae output is useful when more than one cycle of advance warning is needed to stop the popping of data from the FIFO before it becomes empty (to avoid a FIFO underrun).

## Property of pop\_ae

If pop\_ae is inactive (low), there are at least ( $pop\_ae\_lvl +$ ) words in the FIFO. Thus, such status indicates that the pop interface can safely and unconditionally pop ( $pop\_ae\_lvl + 1$ ) words out of the FIFO. This property guarantees that such a 'blind pop' operation does not underrun the FIFO.

### pop\_hf

The pop\_hf output, active high, is synchronous to the clk\_pop input. pop\_hf indicates to the pop interface that the FIFO has at least half of its memory locations occupied, as perceived by the pop interface.

## Property of pop\_hf

If pop\_hf is active (high), at least half of the words in the FIFO are occupied. Thus, such status indicates that the pop interface can safely and unconditionally pop INT((depth + 1)/2) words out of the FIFO. This property guarantees that such a 'blind pop' operation does not underrun the FIFO.

## pop\_af

The pop\_af output, active high, is synchronous to the clk\_pop input. The pop\_af indicates to the pop interface that the FIFO is almost full when there are no more than *pop\_af\_lvl* empty locations in the FIFO, as perceived by the pop interface.

The pop\_af\_lvl parameter defines the almost full threshold of the pop interface independent of that of the pop interface. The pop\_af output is useful when you want to pop data out of the FIFO in bursts (without allowing the FIFO to become empty).

## Property of pop\_af

If pop\_af is active (high), there are at least  $(depth - pop_af_lvl)$  words in the FIFO. Thus, such status indicates that the pop interface can safely and unconditionally pop  $(depth - pop_af_lvl)$  words out of the FIFO. This property guarantees that such a 'blind pop' operation does not underrun the FIFO.

#### pop\_full

The pop\_full output, active high, is synchronous to the clk\_pop input. The pop\_full output indicates to the pop interface that the FIFO is full, as perceived by the pop interface. The action of popping the first word out of a full FIFO is controlled by the pop interface. Thus, the pop\_full output goes low at the rising edge of the clk\_pop that causes the first word to be popped.

The action of the last word being pushed into a nearly full FIFO is controlled by the push interface. This means the pop\_full output is asserted only after the new write pointer from the pop interface is synchronized to clk\_pop and processed by the status flag state logic.

### Property of pop\_full

If pop\_full is active (high) then the FIFO is truly full. This property does not apply to push\_full.

## Simulation Methodology

DW\_fifo\_s2\_sf contains synchronization of Gray coded pointers between clock domains for which there are two methods for simulation.

- The first method is to use the simulation models, which emulate the RTL model, with no modeling of metastable behavior. Using this method requires no extra action.
- The second method (only available for Verilog simulation models) is to enable modeling of random skew between bits of the Gray coded pointers that traverse to and from each domain.

To use the second method, a Verilog preprocessing macro named DW\_MODEL\_MISSAMPLES must be defined in one of the following ways:

Specify the Verilog preprocessing macro in Verilog code:

```
`define DW MODEL MISSAMPLES
```

Or, include a command line option to the simulator, such as+define+DW\_MODEL\_MISSAMPLES (which is used for the Synopsys VCS simulator)

# **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\_fifo\_s2\_sf.

Figure 1-3 Push Timing Waveforms

FIFO depth = 8 (Even  $2^n$  Value);  $push\_ae\_lvl = 1$ ;  $push\_af\_lvl = 1$ ;  $pop\_ae\_lvl = 1$ ;  $pop\_af\_lvl = 1$ ;  $push\_sync = 2$ ;  $pop\_sync = 2$ ;  $err\_mode = 0$ 







Figure 1-4 **Pop Timing Waveforms** 







Figure 1-5 Single Word Push and Pop Timing Waveforms





Figure 1-6 FIFO depth  $\neq$  2<sup>n</sup> Push Timing Waveforms

FIFO depth = 9 ( $\neq$  2<sup>n</sup> Value); push\_ae\_lvl = 3; push\_af\_lvl = 3; pop\_ae\_lvl = 3; pop\_af\_lvl = 3; push\_sync = 1; pop\_sync = 1; err\_mode = 1





Figure 1-7 FIFO  $depth \neq 2^n$  Pop Timing Waveforms

FIFO depth = 9 ( $\neq$  2<sup>n</sup> Value); push\_ae\_lvl = 3; push\_af\_lvl = 3; pop\_ae\_lvl = 3; pop\_af\_lvl = 3; push\_sync = 1; pop\_sync = 1



# of Words Actually in FIFO



Figure 1-8 FIFO  $depth \neq 2^n$  Single Word Timing Waveforms







Figure 1-9 Reset Timing Waveforms



# **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.DWpackages.all;
use DWARE.DW foundation comp.all;
entity DW fifo s2 sf inst is
  generic (inst width
                          : INTEGER := 8;
           inst depth
                          : INTEGER := 8;
           inst push ae lvl : INTEGER := 2;
           inst push af lvl : INTEGER := 2;
           inst_pop_ae_lvl : INTEGER := 2;
           inst pop af lvl : INTEGER := 2;
           inst err mode
                          : INTEGER := 0;
           inst push sync
                           : INTEGER := 2;
           inst pop sync : INTEGER := 2;
           inst rst mode
                           : INTEGER := 0 );
 port (inst clk push : in std logic;
                       : in std logic;
        inst clk pop
        inst rst n
                      : in std logic;
        inst push req n : in std logic;
        inst pop req n : in std logic;
        inst data in : in std logic vector(inst width-1 downto 0);
       push empty inst : out std logic;
       push ae inst : out std logic;
       push_hf_inst : out std logic;
       push af inst : out std logic;
       push full inst : out std logic;
       push error inst : out std logic;
       pop empty inst : out std logic;
       pop ae inst
                      : out std logic;
       pop hf inst
                       : out std logic;
                      : out std_logic;
       pop af inst
       pop full inst
                       : out std logic;
       pop error inst : out std logic;
       data out inst
                       : out std logic vector(inst width-1 downto 0) );
end DW fifo s2 sf inst;
architecture inst of DW fifo s2 sf inst is
begin
```

```
-- Instance of DW fifo s2 sf
 U1 : DW fifo s2 sf
   generic map (width => inst width,
                                        depth => inst depth,
                 push ae lvl => inst push ae lvl,
                 push af lvl => inst push af lvl,
                 pop ae lvl => inst pop ae lvl,
                 pop af lvl => inst pop af lvl, err mode => inst err mode,
                 push sync => inst push sync, pop sync => inst pop sync,
                 rst mode => inst rst mode )
   port map (clk push => inst clk push, clk pop => inst clk pop,
              rst n => inst rst n, push req n => inst push req n,
              pop req n => inst pop req n, data in => inst data in,
             push_empty => push_empty_inst,     push_ae => push_ae_inst,
              push hf => push hf inst,    push af => push af inst,
              push_full => push_full_inst,    push_error => push_error_inst,
              pop empty => pop empty inst,
                                           pop ae => pop ae inst,
              pop hf => pop hf inst, pop af => pop af inst,
              pop full => pop full inst, pop error => pop error inst,
              data out => data out inst );
end inst;
-- pragma translate off
configuration DW fifo s2 sf inst cfg inst of DW fifo s2 sf inst is
  for inst
  end for; -- inst
end DW fifo s2 sf inst cfg inst;
-- pragma translate on
```

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

```
module DW fifo s2 sf inst(inst clk push, inst clk pop, inst rst n,
                          inst push req n, inst pop req n, inst data in,
                          push empty inst, push ae inst, push hf inst,
                          push af inst, push full inst, push_error_inst,
                          pop empty inst, pop ae inst, pop hf inst,
                          pop af inst, pop full inst, pop error inst,
                          data out inst );
 parameter width = 8;
 parameter depth = 8;
 parameter push ae lvl = 2;
 parameter push af lvl = 2;
 parameter pop ae lvl = 2;
 parameter pop af lvl = 2;
 parameter err mode = 0;
 parameter push sync = 2;
 parameter pop sync = 2;
 parameter rst mode = 0;
  input inst_clk push;
  input inst clk pop;
  input inst rst n;
  input inst push req n;
  input inst pop req n;
  input [width-1 : 0] inst_data_in;
  output push empty inst;
  output push ae inst;
  output push hf inst;
  output push af inst;
  output push full inst;
  output push error inst;
  output pop empty inst;
  output pop ae inst;
  output pop hf inst;
  output pop af inst;
  output pop full inst;
  output pop error inst;
  output [width-1 : 0] data_out_inst;
```

```
// Instance of DW fifo s2 sf
 DW fifo s2 sf #(width, depth, push ae lvl, push af lvl, pop ae lvl,
                 pop af lvl, err mode, push_sync, pop_sync, rst_mode)
   U1 (.clk push(inst clk push),
                                    .clk pop(inst clk pop),
        .rst n(inst rst n),
                             .push req n(inst push req n),
         .pop req n(inst pop req n),
                                     .data in(inst data in),
         .push empty(push empty inst),
                                        .push ae (push ae inst),
         .push hf (push hf_inst), .push af (push af_inst),
         .push full (push full inst), .push error (push error inst),
         .pop empty(pop empty inst), .pop ae(pop ae inst),
         .pop hf (pop hf inst), .pop af (pop af inst),
         .pop_full(pop_full_inst), .pop_error(pop_error_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 12 and added the DW_SUPPRESS_WARN<br/>macro</li> </ul>                           |
| October 2019  | DWBB_201903.5 | ■ Added the "Disabling Clock Monitor Messages" section                                                                                                                                       |
| January 2019  | DWBB_201806.5 | <ul> <li>Updated example in "HDL Usage Through Component Instantiation -<br/>VHDL" on page 20</li> </ul>                                                                                     |
| December 2018 | DWBB_201809.4 | ■ Adjusted signals in Figure 1-1 on page 5                                                                                                                                                   |
| April 2018    | DWBB_201709.5 | ■ For STAR 9001317257, updated the maximum value for the <i>width</i> and <i>depth</i> parameters in Table 1-2 on page 2                                                                     |
| December 2017 | DWBB_201709.2 | <ul> <li>Added "Simulation Methodology" on page 12 to explain how to simulate<br/>synchronization of Gray coded pointers between clock domains</li> </ul>                                    |
| October 2017  | DWBB_201709.1 | <ul> <li>Replaced the synthesis implementations in Table 1-3 on page 3 with the str implementation</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