



# **Vivado Design Suite 7 Series FPGA and Zynq 7000 SoC Libraries Guide (UG953)**

## **XPM\_FIFO\_ASYNC**

# XPM\_FIFO\_ASYNC

Parameterized Macro: Asynchronous FIFO

- MACRO\_GROUP: XPM
- MACRO\_SUBGROUP: XPM\_FIFO



X17928-092617

## Introduction

This macro is used to instantiate an asynchronous FIFO.

The following describes the basic write and read operation of an XPM\_FIFO instance. It does not distinguish between FIFO types, clock domain or read mode.

- After a user issues a reset, the user should wait until the busy signals go low before issuing another reset.
- All synchronous signals are sensitive to the rising edge of wr\_clk/rd\_clk, which is assumed to be a buffered and toggling clock signal behaving according to target device and FIFO/memory primitive requirements.
- A write operation is performed when the FIFO is not full and wr\_en is asserted on each wr\_clk cycle.
- A read operation is performed when the FIFO is not empty and rd\_en is asserted on each rd\_clk cycle.
- The number of clock cycles required for XPM FIFO to react to dout, full, and empty changes depends on the CLOCK\_DOMAIN, READ\_MODE, and FIFO\_READ\_LATENCY settings.
  - It can take more than one rd\_clk cycle to deassert empty due to write operation (wr\_en = 1).
  - It can take more than one rd\_clk cycle to present the read data on dout port upon assertion of rd\_en.
  - It may take more than one wr\_clk cycle to deassert full due to read operation (rd\_en = 1).
- All write operations are gated by the value of wr\_en and full on the initiating wr\_clk cycle.
- All read operations are gated by the value of rd\_en and empty on the initiating rd\_clk cycle.
- Undriven or unknown values provided on module inputs will produce undefined output port behavior.
- wr\_en/rd\_en should not be toggled when reset (rst) or wr\_rst\_busy or rd\_rst\_busy is asserted.
- Assertion/deassertion of prog\_full happens only when full is deasserted.
- Assertion/deassertion of prog\_empty happens only when empty is deasserted.

---

 **Note:** In an asynchronous FIFO (that is, two independent clocks), the RELATED\_CLOCKS attribute should be set to TRUE only if both the wr\_clk and rd\_clk are generated from the same source.

---

## Timing Diagrams

**Figure: Reset Behavior**



X20501-050719

**Figure: Standard Write Operation.**

FIFO\_WRITE\_DEPTH=16, PROG\_FULL\_THRESH=6



**Figure: Standard Read Operation.**

FIFO\_WRITE\_DEPTH=16, PROG\_EMPTY\_THRESH=3,  
FIFO\_READ\_LATENCY=1

**Figure: Standard Read Operation.**

FIFO\_WRITE\_DEPTH=16, PROG\_EMPTY\_THRESH=3,

FIFO\_READ\_LATENCY=3

**Figure: Write Operation.**

READ\_MODE=FWFT, FIFO\_WRITE\_DEPTH=16, PROG\_FULL\_THRESH=7

**Figure: Read Operation.**

READ\_MODE=FWFT, FIFO\_WRITE\_DEPTH=16, PROG\_EMPTY\_THRESH=5



X17951-101619

**Figure: Standard Write Operation with Empty Deassertion.**

## FIFO\_WRITE\_DEPTH=16

**Figure: Standard Read Operation with Full Deassertion.**

## FIFO\_WRITE\_DEPTH=16, FIFO\_READ\_LATENCY=1



## Latency

This section defines the latency in which different output signals of the FIFO are updated in response to read or write operations for standard read mode and FWFT read mode implementations.

---

**Note:** For LUTRAM, auto, mixed, and distributed RAM primitive types with `FIFO_READ_LATENCY = 0` and `READ_MODE = "std"` will infer LUTRAM memory without a `rd_clk`. In this configuration, the `dout` port will toggle with respect to the posedge of the write clock only. Take care of this path as data is driven out of the LUT directly without any `rd_clk` domain flop.

---

The following table defines the write port flags update latency due to a write operation.

**Table: Standard Read Mode — Write Port Flags Due to Write Operation**

| Signal        | Latency (wr_clk) |
|---------------|------------------|
| full          | 0                |
| almost_full   | 0                |
| prog_full     | 2                |
| wr_ack        | 1                |
| overflow      | 0                |
| wr_data_count | 2                |

The following table defines the read port flags update latency due to a read operation.

**Table: Standard Read Mode — Read Port Flags Due to Read Operation**

| Signal        | Latency (rd_clk)  |
|---------------|-------------------|
| empty         | 0                 |
| almost_empty  | 0                 |
| prog_empty    | 1                 |
| data_valid    | FIFO_READ_LATENCY |
| underflow     | 0                 |
| rd_data_count | 2                 |

The following table defines the write port flags update latency due to a read operation. N is the number of synchronization stages.

**Table: Standard Read Mode — Write Port Flags Due to Read Operations**

| Signal | Latency |
|--------|---------|
|        |         |

| Signal        | Latency                 |
|---------------|-------------------------|
| full          | 1 rd_clk + (N+2) wr_clk |
| almost_full   | 1 rd_clk + (N+3) wr_clk |
| prog_full     | 1 rd_clk + (N+2) wr_clk |
| wr_ack        | N/A                     |
| overflow      | N/A                     |
| wr_data_count | 1 rd_clk + (N+2) wr_clk |

The following table defines the read port flags update latency due to a write operation. N is the number of synchronization stages. In this example, N is 2.

**Table: Standard Read Mode — Read Port Flags Due to Write Operation**

| Signal        | Latency                 |
|---------------|-------------------------|
| empty         | 1 wr_clk + (N+2) rd_clk |
| almost_empty  | 1 wr_clk + (N+3) rd_clk |
| prog_empty    | 1 wr_clk + (N+3) rd_clk |
| data_valid    | N/A                     |
| underflow     | N/A                     |
| rd_data_count | 1 wr_clk + (N+2) rd_clk |

The following table defines the write port flags update latency due to a write operation.

**Table: FWFT Read Mode — Write Port Flags Due to Write Operation**

| Signal      | Latency |
|-------------|---------|
| full        | 2       |
| almost_full | 1       |
| prog_full   | 0       |

| Signal        | Latency |
|---------------|---------|
| wr_ack        | 1       |
| overflow      | 2       |
| wr_data_count | 2       |

The following table defines the read port flags update latency due to a read operation.

**Table: FWFT Read Mode — Read Port Flags Due to Read Operation**

| Signal        | Latency |
|---------------|---------|
| empty         | 2       |
| almost_empty  | 2       |
| prog_empty    | 3       |
| data_valid    | 0       |
| underflow     | 2       |
| rd_data_count | 2       |

The following table defines the write port flags update latency due to a read operation. N is the number of synchronization stages.

**Table: FWFT Read Mode — Write Port Flags Due to Read Operation**

| Signal        | Latency                                   |
|---------------|-------------------------------------------|
| full          | $1 \text{ rd_clk} + (N+3) \text{ wr_clk}$ |
| almost_full   | $1 \text{ rd_clk} + (N+4) \text{ wr_clk}$ |
| prog_full     | $1 \text{ rd_clk} + (N+5) \text{ wr_clk}$ |
| wr_ack        | N/A                                       |
| overflow      | N/A                                       |
| wr_data_count | $1 \text{ rd_clk} + (N+3) \text{ wr_clk}$ |

The following table defines the read port flags update latency due to a write operation. N is the number of synchronization stages. In this example, N is 2.

**Table: FWFT Read Mode — Read Port Flags Due to Write Operation**

| Signal        | Latency                 |
|---------------|-------------------------|
| empty         | 1 wr_clk + (N+4) rd_clk |
| almost_empty  | 1 wr_clk + (N+4) rd_clk |
| prog_empty    | 1 wr_clk + (N+3) rd_clk |
| data_valid    | 1 wr_clk + (N+4) rd_clk |
| underflow     | N/A                     |
| rd_data_count | 1 wr_clk + (N+4) rd_clk |

## Port Descriptions

| Port         | Direction | Width | Domain | Sense | Handling if Unused | Description                                                                                                                 |
|--------------|-----------|-------|--------|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
| almost_empty | Output    | 1     | rd_clk | LEVEL | Don't Care         | Almost Empty : When asserted, this signal indicates that only one more read can be performed before the FIFO goes to empty. |
| almost_full  | Output    | 1     | wr_clk | LEVEL | Don't Care         | Almost Full: When asserted, this signal indicates that only one more write can be performed before the FIFO is full.        |
| data_valid   | Output    | 1     | rd_clk | LEVEL | Don't Care         | Read Data Valid: When asserted, this signal indicates that valid data is                                                    |

| Port               | Direction | Width       | Domain     | Sense  | Handling if Unused | Description                                                                                                                                                                                                          |
|--------------------|-----------|-------------|------------|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |           |             |            |        |                    | available on the output bus (dout).                                                                                                                                                                                  |
| dbiterr            | Output    | 1           | rd_clk     | LEVEL  | DONT_CARE          | Double Bit Error: Indicates that the ECC decoder detected a double-bit error and data in the FIFO core is corrupted.                                                                                                 |
| din                | Input     | WRITE_WIDTH | DATA_WIDTH | ACTIVE |                    | Write Data: The input data bus used when writing the FIFO.                                                                                                                                                           |
| dout               | Output    | READ_WIDTH  | DATA_WIDTH | ACTIVE |                    | Read Data: The output data bus is driven when reading the FIFO.                                                                                                                                                      |
| empty              | Output    | 1           | rd_clk     | LEVEL  | LOW                | Empty Flag: When asserted, this signal indicates that the FIFO is empty.<br>Read requests are ignored when the FIFO is empty, initiating a read while empty is not destructive to the FIFO.                          |
| full               | Output    | 1           | wr_clk     | LEVEL  | HIGH               | Full Flag: When asserted, this signal indicates that the FIFO is full.<br>Write requests are ignored when the FIFO is full, initiating a write when the FIFO is full is not destructive to the contents of the FIFO. |
| injectdbiterrInput |           | 1           | wr_clk     | LEVEL  | 0HIGH              | Double Bit Error Injection: Injects a double bit error if                                                                                                                                                            |

| Port               | Direction | Width | Domain | Sense        | Handling if Unused                                                                                                                                                                                                                                       |
|--------------------|-----------|-------|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |           |       |        |              | the ECC feature is used on block RAMs or UltraRAM macros.                                                                                                                                                                                                |
| injectsbiterrInput |           | 1     | wr_clk | LEVEL_0HIGH  | Single Bit Error Injection: Injects a single bit error if the ECC feature is used on block RAMs or UltraRAM macros.                                                                                                                                      |
| overflow           | Output    | 1     | wr_clk | LEVEL_DONTCA | Overflow: This signal indicates that a write request (wren) during the prior clock cycle was rejected, because the FIFO is full. Overflowing the FIFO is not destructive to the contents of the FIFO.                                                    |
| prog_emptyOutput   |           | 1     | rd_clk | LEVEL_DONTCA | Programmable Empty: This signal is asserted when the number of words in the FIFO is less than or equal to the programmable empty threshold value. It is de-asserted when the number of words in the FIFO exceeds the programmable empty threshold value. |
| prog_full          | Output    | 1     | wr_clk | LEVEL_DONTCA | Programmable Full: This signal is asserted when the number of words in the FIFO is greater than or equal to the programmable full threshold value.                                                                                                       |

| Port          | Direction | Width               | Domain    | Sense        | Handling if Unused                                                                                                                                                                                                             |
|---------------|-----------|---------------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |           |                     |           |              | It is de-asserted when the number of words in the FIFO is less than the programmable full threshold value.                                                                                                                     |
| rd_clk        | Input     | 1                   | NA        | EDGE_RISING  | Read clock: Used for read operation. rd_clk must be a free running clock.                                                                                                                                                      |
| rd_data_count | Output    | RD_DATA_COUNT_WIDTH | RD_DOMAIN | DATA_WIDE    | Read Data Count: This bus indicates the number of words read from the FIFO.                                                                                                                                                    |
| rd_en         | Input     | 1                   | rd_clk    | LEVEL_ACTIVE | <p>Read Enable: If the FIFO is not empty, asserting this signal causes data (on dout) to be read from the FIFO.</p> <ul style="list-style-type: none"> <li>Must be held active-low when rd_RST_BUSY is active high.</li> </ul> |
| rd_RST_BUSY   | Output    | 1                   | rd_clk    | LEVEL_ACTIVE | Read Reset Busy: Active-High indicator that the FIFO read domain is currently in a reset state.                                                                                                                                |
| rst           | Input     | 1                   | wr_clk    | LEVEL_ACTIVE | <p>Reset: Must be synchronous to wr_clk. The clock(s) can be unstable at the time of applying reset, but reset must be released only after the clock(s) is/are stable.</p>                                                     |

| Port          | Direction | Width               | Domain        | Sense       | Handling if Unused | Description                                                                                                                                                                       |
|---------------|-----------|---------------------|---------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sbiterr       | Output    | 1                   | rd_clk        | LEVEL_0HIGH | Do Not Care        | Single Bit Error: Indicates that the ECC decoder detected and fixed a single-bit error.                                                                                           |
| sleep         | Input     | 1                   | NA            | LEVEL_0HIGH | Do Not Care        | Dynamic power saving: If sleep is High, the memory/fifo block is in power saving mode.                                                                                            |
| underflow     | Output    | 1                   | rd_clk        | LEVEL_0HIGH | Do Not Care        | Underflow: Indicates that the read request (rd_en) during the previous clock cycle was rejected because the FIFO is empty. Under flowing the FIFO is not destructive to the FIFO. |
| wr_ack        | Output    | 1                   | wr_clk        | LEVEL_0HIGH | Do Not Care        | Write Acknowledge: This signal indicates that a write request (wr_en) during the prior clock cycle is succeeded.                                                                  |
| wr_clk        | Input     | 1                   | NA            | EDGE_RISING | Do Not Care        | Write clock: Used for write operation. wr_clk must be a free running clock.                                                                                                       |
| wr_data_count | Output    | WR_DATA_COUNT_WIDTH | WR_CLK_DOMAIN | Do Not Care | Do Not Care        | Write Data Count: This bus indicates the number of words written into the FIFO.                                                                                                   |
| wr_en         | Input     | 1                   | wr_clk        | LEVEL_0HIGH | Do Not Care        | Write Enable: If the FIFO is not full, asserting this signal causes data (on din) to be written to the FIFO.                                                                      |

| Port        | Direction | Width | Domain | Sense | Handling if Unused | Description                                                                                                       |
|-------------|-----------|-------|--------|-------|--------------------|-------------------------------------------------------------------------------------------------------------------|
|             |           |       |        |       |                    | <ul style="list-style-type: none"> <li>Must be held active-low when rst or wr_rst_busy is active high.</li> </ul> |
| wr_rst_busy | Output    | 1     | wr_clk | LEVEL | ACTIVE-HIGH        | Write Reset Busy: Active-High indicator that the FIFO write domain is currently in a reset state.                 |

## Design Entry Method

|                              |     |
|------------------------------|-----|
| Instantiation                | Yes |
| Inference                    | No  |
| IP and IP Integrator Catalog | No  |

## Available Attributes

| Attribute Values                                                                                                                                          | Description                                                                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| <b>DATA_CASCADE_HEIGHT</b><br>Default - Allow Vivado Synthesis to choose.<br>to more - Vivado Synthesis sets the specified value as Cascade Height.<br>64 |                                                                                           |
| <b>SPECIFYING_STAGES</b><br>of synchronization stages on the CDC path<br>to<br>8                                                                          | <ul style="list-style-type: none"> <li>Must be &lt; 5 if FIFO_WRITE_DEPTH = 16</li> </ul> |
| <b>WRITING_RESET_VALUES</b><br>path.                                                                                                                      |                                                                                           |
| <b>ECC_MODE</b><br>"no_ecc" - Disables ECC<br>• "en_ecc" - Enables both ECC Encoder and Decoder                                                           |                                                                                           |

| <u><b>DefaultValues</b></u> | <u><b>Description</b></u>                                                                                                                                                                                                                                                                                                                               |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FIFO_ECC_MODE</b>        | NOTE: ECC_MODE should be "no_ecc" if FIFO_MEMORY_TYPE is set to "auto". Violating this may result incorrect behavior.                                                                                                                                                                                                                                   |
| <b>FIFO_ASSERT_ERR</b>      | <p><b>String</b>"ASSERT_ERR</p> <ul style="list-style-type: none"> <li>• "warning" - Report warning message for FIFO overflow and underflow in simulation.</li> <li>• "error" - Report error message for FIFO overflow and underflow in simulation.</li> <li>• "fatal" - Report fatal message for FIFO overflow and underflow in simulation.</li> </ul> |
| <b>FIFO_MEMORY_TYPE</b>     | <p>The primitive (resource type) to use.</p> <p>"block",<br/>"distributed"</p> <ul style="list-style-type: none"> <li>• "auto" Allow Vivado Synthesis to choose           <ul style="list-style-type: none"> <li>• "block"- Block RAM FIFO</li> <li>• "distributed"- Distributed RAM FIFO</li> </ul> </li> </ul>                                        |
| <b>FIFO_READ_DEPTH</b>      | <p>NOTE: There may be a behavior mismatch if Block RAM or Ultra RAM specific features, like ECC or Asymmetry, are selected with FIFO_MEMORY_TYPE set to "auto".</p> <p>to<br/>10</p> <ul style="list-style-type: none"> <li>• If READ_MODE = "fwft", then the only applicable value is 0.</li> </ul>                                                    |
| <b>FIFO_WRITE_DEPTH</b>     | <p>Depth, must be power of two.</p> <p>to<br/>4194304</p> <ul style="list-style-type: none"> <li>• In standard READ_MODE, the effective depth = FIFO_WRITE_DEPTH-1</li> <li>• In First-Word-Fall-Through READ_MODE, the effective depth = FIFO_WRITE_DEPTH+1</li> </ul>                                                                                 |
| <b>FIFO_RESET_VALUE</b>     | <p>Set prog_full to FULL_RESET_VALUE during reset</p> <p>to<br/>1</p>                                                                                                                                                                                                                                                                                   |

| Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Title                                    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| <p><b>DECODE_FIFO_WRITE_DEPTH_THRESHOLD</b> Number of read words in the FIFO at or below which <code>fprog_empty</code> is asserted.</p> <p>4194301</p> <ul style="list-style-type: none"> <li>• Min_Value = <math>3 + (\text{READ\_MODE\_VAL} * 2)</math></li> <li>• Max_Value = <math>(\text{FIFO\_WRITE\_DEPTH}-3) - (\text{READ\_MODE\_VAL} * 2)</math></li> </ul> <p>If READ_MODE = "std", then READ_MODE_VAL = 0; Otherwise READ_MODE_VAL = 1.</p> <p>NOTE: The default threshold value is dependent on default FIFO_WRITE_DEPTH value. If FIFO_WRITE_DEPTH value is changed, ensure the threshold value is within the valid range though the programmable flags are not used.</p>                                                                                                                                          | <b>DECODE_FIFO_WRITE_DEPTH_THRESHOLD</b> |
| <p><b>DECODE_FIFO_WRITE_DEPTH_THRESHOLD</b> Number of write words in the FIFO at or above which <code>fprog_full</code> is asserted.</p> <p>4194301</p> <ul style="list-style-type: none"> <li>• Min_Value = <math>3 + (\text{READ\_MODE\_VAL} * 2 * (\text{FIFO\_WRITE\_DEPTH}/\text{FIFO\_READ\_DEPTH})) + \text{CDC\_SYNC\_STAGES}</math></li> <li>• Max_Value = <math>(\text{FIFO\_WRITE\_DEPTH}-3) - (\text{READ\_MODE\_VAL} * 2 * (\text{FIFO\_WRITE\_DEPTH}/\text{FIFO\_READ\_DEPTH}))</math></li> </ul> <p>If READ_MODE = "std", then READ_MODE_VAL = 0; Otherwise READ_MODE_VAL = 1.</p> <p>NOTE: The default threshold value is dependent on default FIFO_WRITE_DEPTH value. If FIFO_WRITE_DEPTH value is changed, ensure the threshold value is within the valid range though the programmable flags are not used.</p> | <b>DECODE_FIFO_WRITE_DEPTH_THRESHOLD</b> |
| <p><b>DECODE_FIFO_READ_DEPTH</b> Data_count. To reflect the correct value, the width should be <math>\log_2(\text{FIFO\_READ\_DEPTH})+1</math>.</p> <p>23</p> <ul style="list-style-type: none"> <li>• FIFO_READ_DEPTH = <math>\text{FIFO\_WRITE\_DEPTH} * \text{WRITE\_DATA\_WIDTH} / \text{READ\_DATA\_WIDTH}</math></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>DECODE_FIFO_READ_DEPTH</b>            |
| <p><b>DECODE_DATA_WIDTH</b> The read data port, dout to</p> <p>4096</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                          |

| <u>Default Values</u>     | <u>Description</u>                                                                                                                                                                                                                                                       |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | <ul style="list-style-type: none"> <li>• Write and read width aspect ratio must be 1:1, 1:2, 1:4, 1:8, 8:1, 4:1 and 2:1</li> <li>• For example, if WRITE_DATA_WIDTH is 32, then the READ_DATA_WIDTH must be 32, 64, 128, 256, 16, 8, 4.</li> </ul>                       |
| NOTE:                     |                                                                                                                                                                                                                                                                          |
|                           | <ul style="list-style-type: none"> <li>• READ_DATA_WIDTH should be equal to WRITE_DATA_WIDTH if FIFO_MEMORY_TYPE is set to "auto". Violating this may result incorrect behavior.</li> <li>• The maximum FIFO size (width x depth) is limited to 150-Megabits.</li> </ul> |
| <u>READING MODE</u>       |                                                                                                                                                                                                                                                                          |
| "fwft"                    | <p>"std"- standard read mode</p> <ul style="list-style-type: none"> <li>• "fwft"- First-Word-Fall-Through read mode</li> </ul>                                                                                                                                           |
| <u>SEPARATE_CLKS</u>      | <p>if clk and rd_clk are related having the same source but different clock ratios</p> <p>1</p>                                                                                                                                                                          |
| <u>DISMISERTION</u>       | <p>simulation message reporting. Messages related to potential misuse will not be reported.</p> <p>1- Enable simulation message reporting. Messages related to potential misuse will be reported.</p>                                                                    |
| <u>WRING DATA AND REG</u> | <p>wr_data_valid, almost_empty, rd_data_count, prog_empty, underflow, wr_ack, almost_full, wr_data_count, prog_full, overflow features.</p>                                                                                                                              |

| Default Values                                                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                   | <ul style="list-style-type: none"> <li>Setting USE_ADV_FEATURES[0] to 1 enables overflow flag; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[1] to 1 enables prog_full flag; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[2] to 1 enables wr_data_count; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[3] to 1 enables almost_full flag; Default value of this bit is 0</li> <li>Setting USE_ADV_FEATURES[4] to 1 enables wr_ack flag; Default value of this bit is 0</li> <li>Setting USE_ADV_FEATURES[8] to 1 enables underflow flag; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[9] to 1 enables prog_empty flag; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[10] to 1 enables rd_data_count; Default value of this bit is 1</li> <li>Setting USE_ADV_FEATURES[11] to 1 enables almost_empty flag; Default value of this bit is 0</li> <li>Setting USE_ADV_FEATURES[12] to 1 enables data_valid flag; Default value of this bit is 0</li> </ul> |
| <del>WAKEUP_TIME</del>                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| to 2                                                                                                              | <ul style="list-style-type: none"> <li>0 - Disable sleep</li> <li>2 - Use Sleep Pin</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| NOTE: WAKEUP_TIME should be 0 if FIFO_MEMORY_TYPE is set to "auto". Violating this may result incorrect behavior. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <del>DATA_COLDNT_OF_WD</del>                                                                                      | The width of the write data port, din                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| to 4096                                                                                                           | Write and read width aspect ratio must be 1:1, 1:2, 1:4, 1:8, 8:1, 4:1 and 2:1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                   | <ul style="list-style-type: none"> <li>For example, if WRITE_DATA_WIDTH is 32, then the READ_DATA_WIDTH must be 32, 64, 128, 256, 16, 8, 4.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Default Values                                                                                                                                                                                                                                                                        | Description |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| <p>NOTE:</p> <ul style="list-style-type: none"> <li>• WRITE_DATA_WIDTH should be equal to READ_DATA_WIDTH if FIFO_MEMORY_TYPE is set to "auto". Violating this may result incorrect behavior.</li> <li>• The maximum FIFO size (width x depth) is limited to 150-Megabits.</li> </ul> |             |

## VHDL Instantiation Template

```
-- xpm_fifo_async: Asynchronous FIFO
-- Xilinx Parameterized Macro, version 2025.1

xpm_fifo_async_inst : xpm_fifo_async
generic map (
    CASCADE_HEIGHT => 0,          -- DECIMAL
    CDC_SYNC_STAGES => 2,          -- DECIMAL
    DOUT_RESET_VALUE => "0",        -- String
    ECC_MODE => "no_ecc",          -- String
    EN_SIM_ASSERT_ERR => "warning", -- String
    FIFO_MEMORY_TYPE => "auto",     -- String
    FIFO_READ_LATENCY => 1,         -- DECIMAL
    FIFO_WRITE_DEPTH => 2048,       -- DECIMAL
    FULL_RESET_VALUE => 0,          -- DECIMAL
    PROG_EMPTY_THRESH => 10,         -- DECIMAL
    PROG_FULL_THRESH => 10,         -- DECIMAL
    RD_DATA_COUNT_WIDTH => 1,        -- DECIMAL
    READ_DATA_WIDTH => 32,          -- DECIMAL
    READ_MODE => "std",            -- String
    RELATED_CLOCKS => 0,           -- DECIMAL
    SIM_ASSERT_CHK => 0,            -- DECIMAL; 0=disable simulation
messages, 1=enable simulation messages
    USE_ADV_FEATURES => "0707",      -- String
    WAKEUP_TIME => 0,               -- DECIMAL
    WRITE_DATA_WIDTH => 32,          -- DECIMAL
    WR_DATA_COUNT_WIDTH => 1         -- DECIMAL
)
port map (
```

almost\_empty => almost\_empty, -- 1-bit output: Almost Empty : When asserted, this signal indicates that only one more read can be performed  
-- before the FIFO goes to empty.

almost\_full => almost\_full, -- 1-bit output: Almost Full: When asserted, this signal indicates that only one more write can be performed  
-- before the FIFO is full.

data\_valid => data\_valid, -- 1-bit output: Read Data Valid: When asserted, this signal indicates that valid data is available on the  
-- output bus (dout).

dbiterr => dbiterr, -- 1-bit output: Double Bit Error: Indicates that the ECC decoder detected a double-bit error and data in the  
-- FIFO core is corrupted.

dout => dout, -- READ\_DATA\_WIDTH-bit output: Read Data: The output data bus is driven when reading the FIFO.  
empty => empty, -- 1-bit output: Empty Flag: When asserted, this signal indicates that the FIFO is empty. Read requests are  
-- ignored when the FIFO is empty, initiating a read while empty is not destructive to the FIFO.

full => full, -- 1-bit output: Full Flag: When asserted, this signal indicates that the FIFO is full. Write requests are  
-- ignored when the FIFO is full, initiating a write when the FIFO is full is not destructive to the contents  
-- of the FIFO.

overflow => overflow, -- 1-bit output: Overflow: This signal indicates that a write request (wren) during the prior clock cycle was  
-- rejected, because the FIFO is

full. Overflowing the FIFO is not destructive to the contents of the FIFO.

```
prog_empty => prog_empty,          -- 1-bit output: Programmable
Empty: This signal is asserted when the number of words in the FIFO
is less than
                                         -- or equal to the programmable
empty threshold value. It is de-asserted when the number of words
in the FIFO
                                         -- exceeds the programmable
empty threshold value.
```

```
prog_full => prog_full,          -- 1-bit output: Programmable
Full: This signal is asserted when the number of words in the FIFO
is greater
                                         -- than or equal to the
programmable full threshold value. It is de-asserted when the
number of words in the
                                         -- FIFO is less than the
programmable full threshold value.
```

rd\_data\_count => rd\_data\_count, -- RD\_DATA\_COUNT\_WIDTH-bit  
output: Read Data Count: This bus indicates the number of words  
read from the FIFO.

rd\_rst\_busy => rd\_rst\_busy, -- 1-bit output: Read Reset  
Busy: Active-High indicator that the FIFO read domain is currently  
in a reset state.

sbiterr => sbiterr, -- 1-bit output: Single Bit  
Error: Indicates that the ECC decoder detected and fixed a single-  
bit error.

underflow => underflow, -- 1-bit output: Underflow:  
Indicates that the read request (rd\_en) during the previous clock  
cycle was
 -- rejected because the FIFO is  
empty. Under flowing the FIFO is not destructive to the FIFO.

wr\_ack => wr\_ack, -- 1-bit output: Write  
Acknowledge: This signal indicates that a write request (wr\_en)  
during the prior clock
 -- cycle is succeeded.

wr\_data\_count => wr\_data\_count, -- WR\_DATA\_COUNT\_WIDTH-bit

output: Write Data Count: This bus indicates the number of words written into the FIFO.

wr\_rst\_busy => wr\_rst\_busy, -- 1-bit output: Write Reset Busy: Active-High indicator that the FIFO write domain is currently in a reset state.

din => din, -- WRITE\_DATA\_WIDTH-bit input: Write Data: The input data bus used when writing the FIFO.

injectdbiterr => injectdbiterr, -- 1-bit input: Double Bit Error Injection: Injects a double bit error if the ECC feature is used on block RAMs or UltraRAM macros.

injectsbiterr => injectsbiterr, -- 1-bit input: Single Bit Error Injection: Injects a single bit error if the ECC feature is used on block RAMs or UltraRAM macros.

rd\_clk => rd\_clk, -- 1-bit input: Read clock: Used for read operation. rd\_clk must be a free running clock.

rd\_en => rd\_en, -- 1-bit input: Read Enable: If the FIFO is not empty, asserting this signal causes data (on dout) to be read from the FIFO. Must be held active-low when rd\_rst\_busy is active high.

rst => rst, -- 1-bit input: Reset: Must be synchronous to wr\_clk. The clock(s) can be unstable at the time of applying reset, but reset must be released only after the clock(s) is/are stable.

sleep => sleep, -- 1-bit input: Dynamic power saving: If sleep is High, the memory/fifo block is in power saving mode.

wr\_clk => wr\_clk, -- 1-bit input: Write clock: Used for write operation. wr\_clk must be a free running clock.

wr\_en => wr\_en, -- 1-bit input: Write Enable: If the FIFO is not full, asserting this signal causes data (on din) to

```

be written                                -- to the FIFO. Must be held
active-low when rst or wr_rst_busy is active high.

);

-- End of xpm_fifo_async_inst instantiation

```

## Verilog Instantiation Template

```

// xpm_fifo_async: Asynchronous FIFO
// Xilinx Parameterized Macro, version 2025.1

xpm_fifo_async #(
    .CASCADE_HEIGHT(0),                      // DECIMAL
    .CDC_SYNC_STAGES(2),                     // DECIMAL
    .DOUT_RESET_VALUE("0"),                  // String
    .ECC_MODE("no_ecc"),                    // String
    .EN_SIM_ASSERT_ERR("warning"),          // String
    .FIFO_MEMORY_TYPE("auto"),              // String
    .FIFO_READ_LATENCY(1),                  // DECIMAL
    .FIFO_WRITE_DEPTH(2048),                // DECIMAL
    .FULL_RESET_VALUE(0),                  // DECIMAL
    .PROG_EMPTY_THRESH(10),                 // DECIMAL
    .PROG_FULL_THRESH(10),                 // DECIMAL
    .RD_DATA_COUNT_WIDTH(1),                // DECIMAL
    .READ_DATA_WIDTH(32),                  // DECIMAL
    .READ_MODE("std"),                     // String
    .RELATED_CLOCKS(0),                   // DECIMAL
    .SIM_ASSERT_CHK(0),                   // DECIMAL; 0=disable simulation
                                         messages, 1=enable simulation messages
    .USE_ADV_FEATURES("0707"),             // String
    .WAKEUP_TIME(0),                     // DECIMAL
    .WRITE_DATA_WIDTH(32),                // DECIMAL
    .WR_DATA_COUNT_WIDTH(1)               // DECIMAL
)
xpm_fifo_async_inst (
    .almost_empty(almost_empty),      // 1-bit output: Almost Empty :
When asserted, this signal indicates that only one more read can be

```

performed

// before the FIFO goes to empty.

.almost\_full(almost\_full), // 1-bit output: Almost Full:

When asserted, this signal indicates that only one more write can be performed

// before the FIFO is full.

.data\_valid(data\_valid), // 1-bit output: Read Data Valid:

When asserted, this signal indicates that valid data is available on the

// output bus (dout).

.dbiterr(dbiterr), // 1-bit output: Double Bit

Error: Indicates that the ECC decoder detected a double-bit error and data in the

// FIFO core is corrupted.

.dout(dout), // READ\_DATA\_WIDTH-bit output:

Read Data: The output data bus is driven when reading the FIFO.

.empty(empty), // 1-bit output: Empty Flag: When

asserted, this signal indicates that the FIFO is empty. Read requests are

// ignored when the FIFO is

empty, initiating a read while empty is not destructive to the

FIFO.

.full(full), // 1-bit output: Full Flag: When

asserted, this signal indicates that the FIFO is full. Write

requests are

// ignored when the FIFO is full,

initiating a write when the FIFO is full is not destructive to the contents of

// the FIFO.

.overflow(overflow), // 1-bit output: Overflow: This

signal indicates that a write request (wren) during the prior clock cycle was

// rejected, because the FIFO is

full. Overflowing the FIFO is not destructive to the contents of the FIFO.

```

    .prog_empty(prog_empty),           // 1-bit output: Programmable
Empty: This signal is asserted when the number of words in the FIFO
is less than
                                // or equal to the programmable
empty threshold value. It is de-asserted when the number of words
in the FIFO
                                // exceeds the programmable empty
threshold value.

    .prog_full(prog_full),           // 1-bit output: Programmable
Full: This signal is asserted when the number of words in the FIFO
is greater than
                                // or equal to the programmable
full threshold value. It is de-asserted when the number of words in
the FIFO is
                                // less than the programmable
full threshold value.

    .rd_data_count(rd_data_count), // RD_DATA_COUNT_WIDTH-bit
output: Read Data Count: This bus indicates the number of words
read from the FIFO.

    .rd_rst_busy(rd_rst_busy),     // 1-bit output: Read Reset Busy:
Active-High indicator that the FIFO read domain is currently in a
reset state.

    .sbiterr(sbiterr),             // 1-bit output: Single Bit
Error: Indicates that the ECC decoder detected and fixed a single-
bit error.

    .underflow(underflow),         // 1-bit output: Underflow:
Indicates that the read request (rd_en) during the previous clock
cycle was rejected
                                // because the FIFO is empty.

Under flowing the FIFO is not destructive to the FIFO.

    .wr_ack(wr_ack),              // 1-bit output: Write
Acknowledge: This signal indicates that a write request (wr_en)
during the prior clock
                                // cycle is succeeded.

    .wr_data_count(wr_data_count), // WR_DATA_COUNT_WIDTH-bit
output: Write Data Count: This bus indicates the number of words
written into the
                                // FIFO.

```

```

    .wr_rst_busy(wr_rst_busy),      // 1-bit output: Write Reset
    Busy: Active-High indicator that the FIFO write domain is currently
    in a reset
                                // state.

    .din(din),                  // WRITE_DATA_WIDTH-bit input:
    Write Data: The input data bus used when writing the FIFO.

    .injectdbiterr(injectdbiterr), // 1-bit input: Double Bit Error
    Injection: Injects a double bit error if the ECC feature is used on
    block RAMs
                                // or UltraRAM macros.

    .injectsbiterr(injectsbiterr), // 1-bit input: Single Bit Error
    Injection: Injects a single bit error if the ECC feature is used on
    block RAMs
                                // or UltraRAM macros.

    .rd_clk(rd_clk),            // 1-bit input: Read clock: Used
    for read operation. rd_clk must be a free running clock.

    .rd_en(rd_en),              // 1-bit input: Read Enable: If
    the FIFO is not empty, asserting this signal causes data (on dout)
    to be read
                                // from the FIFO. Must be held
    active-low when rd_rst_busy is active high.

    .rst(rst),                  // 1-bit input: Reset: Must be
    synchronous to wr_clk. The clock(s) can be unstable at the time of
    applying
                                // reset, but reset must be
    released only after the clock(s) is/are stable.

    .sleep(sleep),              // 1-bit input: Dynamic power
    saving: If sleep is High, the memory/fifo block is in power saving
    mode.

    .wr_clk(wr_clk),            // 1-bit input: Write clock: Used
    for write operation. wr_clk must be a free running clock.

    .wr_en(wr_en)                // 1-bit input: Write Enable: If
    the FIFO is not full, asserting this signal causes data (on din) to
    be written
                                // to the FIFO. Must be held
    active-low when rst or wr_rst_busy is active high.

```

```
 );  
  
// End of xpm_fifo_async_inst instantiation
```

## Related Information

- *XPM FIFO Testbench File* ([xpm-fifo-testbench.zip](#))