

# FIFO

### **User Guide**

03/2018

Hercules Microelectronics, Inc.

China

## Contents

| Со | ontents                       |                                        | 2  |  |  |  |  |  |  |  |  |  |
|----|-------------------------------|----------------------------------------|----|--|--|--|--|--|--|--|--|--|
| 1  | Software FIFO Introduction3   |                                        |    |  |  |  |  |  |  |  |  |  |
| 2  | 2 Software FIFO Block Diagram |                                        |    |  |  |  |  |  |  |  |  |  |
|    | 2.1                           | Asynchronous FIFO                      | 4  |  |  |  |  |  |  |  |  |  |
|    | 2.2                           | Synchronous FIFO                       | 4  |  |  |  |  |  |  |  |  |  |
| 3  | Soft                          | ware FIFO Interface                    | 6  |  |  |  |  |  |  |  |  |  |
|    | 3.1                           | Asynchronous FIFO interface            | 6  |  |  |  |  |  |  |  |  |  |
|    | 3.2                           | Synchronous FIFO interface             | 8  |  |  |  |  |  |  |  |  |  |
|    | 3.3                           | FIFO programmed parameter list         | 10 |  |  |  |  |  |  |  |  |  |
| 4  | Soft                          | ware FIFO Usage and Control            | 13 |  |  |  |  |  |  |  |  |  |
|    | 4.1                           | FIFO Full/Empty generation             | 13 |  |  |  |  |  |  |  |  |  |
|    | 4.2                           | Almost full/Almost empty generation    | 14 |  |  |  |  |  |  |  |  |  |
|    | 4.3                           | Programmable full/empty generation     | 15 |  |  |  |  |  |  |  |  |  |
|    | 4.3.1                         | Programmable Full                      | 15 |  |  |  |  |  |  |  |  |  |
|    | 4.3.2                         | 2 Programmable Empty                   | 17 |  |  |  |  |  |  |  |  |  |
|    | 4.3.3                         | 3 Data count generation                | 19 |  |  |  |  |  |  |  |  |  |
|    | 4.3.4                         | 4 Handshaking interface generation     | 20 |  |  |  |  |  |  |  |  |  |
| 5  | Harc                          | dware FIFO                             | 21 |  |  |  |  |  |  |  |  |  |
|    | 5.1                           | Introduction                           | 21 |  |  |  |  |  |  |  |  |  |
|    | 5.2                           | Difference between SW FIFO and HW FIFO | 21 |  |  |  |  |  |  |  |  |  |
| 6  | АНВ                           | interface FIFO                         | 23 |  |  |  |  |  |  |  |  |  |
| 7  | Reso                          | ource usage                            | 24 |  |  |  |  |  |  |  |  |  |
| 8  | Simu                          | ulating your design                    | 25 |  |  |  |  |  |  |  |  |  |
| 9  | Gen                           | erated File Directory Structure        | 26 |  |  |  |  |  |  |  |  |  |
| Re | vision                        | History                                | 28 |  |  |  |  |  |  |  |  |  |



## **1 Software FIFO Introduction**

This document describes the FIFO (First-in First-out) IP core, including asynchronous FIFO and synchronous FIFO. The FIFO supports the following features:

- Support data width up to 128 bits with depth up to 1K bits;
- Support different input and output data widths;
- Support both synchronous and asynchronous FIFO;
- Support wfull/rempty status flag;
- Optional synchronous clear inputs for both read and write;
- Optional almost\_full/almost\_empty status flag to indicate only one more data can be written/read before FIFO is full/empty;
- Optional prog\_full/prog\_empty status flag. Support 4 types of programmable full flag generation : Single threshold constant, Single threshold with dedicated input port, Assert and negate threshold constants, Assert and negate thresholds with dedicated input ports;
- Optional count vector(s)(wr\_data\_cnt and rd\_data\_cnt) provide visibility into number of data words currently in the FIFO, synchronized to either clock domain;
- Four optional handshake signals (wr\_ack, rd\_ack, overflow, underflow) provide feedback (acknowledge ment or rejection) in response to write and read requests in the prior clock cycle;
- Invalid read or write requests are rejected without affecting the FIFO state. When FIFO is full, data can't write to FIFO anymore, the write data will be omitted. When FIFO is empty, data can't read out anymore;
- Support AHB interface.
- Support First Word Fall Through function
- Up to 200MHz performance.

Device Support:

HME-M5, HME -M7, HME -HR3, HME \_HR2, HME \_M0, HME \_M1



## 2 Software FIFO Block Diagram

### 2.1 Asynchronous FIFO

Following figure shows the block diagram of asynchronous FIFO.



Figure 2-1 Asynchronous FIFO Block Diagram

To implement asynchronous FIFO function:

- To store the FIFO data, the dual port memory (EMB5K) are used, the number of EMB5K depends on the data width and memory depth that user need;
- Synchronous bridge between different clock domains are used to solve the metastability issue;
- To eliminate the problem associated with synchronizing multiple changing signals on the same clock edge, Gray counter is used. Gray codes only allow one bit to change for each clock transition.(Only one bit is allowed to convert at each transition clock in Gray codes).

### 2.2 Synchronous FIFO

Following figure shows the block diagram of synchronous FIFO:





#### Figure 2-2 Synchronous FIFO Block Diagram

To implement synchronous FIFO function:

Compared with asynchronous FIFO, no synchronous bridge and gray code counter are needed in synchronous FIFO.



## **3 Software FIFO Interface**

### 3.1 Asynchronous FIFO interface

Following figure shows the interface of asynchronous FIFO.



Figure 3-1 Asynchronous FIFO Interface

The asynchronous FIFO pin descriptions are outlined in the table below.

Table 3-1 Asynchronous FIFO pin description

| Interface | Name             | Direction  | Width | Description                                         |  |  |  |  |  |  |  |
|-----------|------------------|------------|-------|-----------------------------------------------------|--|--|--|--|--|--|--|
| System    | wclk             | Input      | 1     | write clock input                                   |  |  |  |  |  |  |  |
|           | wrst_n Input 1 W |            |       | Write reset input, active low                       |  |  |  |  |  |  |  |
|           | rclk             | Input      | 1     | Read clock input                                    |  |  |  |  |  |  |  |
|           | rrst_n           | Input      | 1     | Read reset input, active low                        |  |  |  |  |  |  |  |
| User      | wdata            | Input      | wr_dw | FIFO write data                                     |  |  |  |  |  |  |  |
| Interface | rdata            | Input      | rd_dw | FIFO read data                                      |  |  |  |  |  |  |  |
|           | wen              | Input      | 1     | FIFO write enable                                   |  |  |  |  |  |  |  |
|           | ren              | Input      | 1     | FIFO read enable                                    |  |  |  |  |  |  |  |
|           | wclr             | Input      | 1     | Synchronous clear input to clear write pointer,     |  |  |  |  |  |  |  |
|           |                  | (optional) |       | write related flag output, active high              |  |  |  |  |  |  |  |
|           | rclr             | Input      | 1     | Synchronous clear input to clear read pointer, read |  |  |  |  |  |  |  |
|           |                  | (optional) |       | related flag output, active high                    |  |  |  |  |  |  |  |
|           | prog_full_thresh | Input      | wr_aw | Programmable Full Threshold: This signal is used to |  |  |  |  |  |  |  |
|           |                  | (optional) |       | input the                                           |  |  |  |  |  |  |  |



|                      |                     |       | threshold value for the assertion and de-assertion                                                                                                                                                                                                                       |
|----------------------|---------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      |                     |       | of the                                                                                                                                                                                                                                                                   |
|                      |                     |       | programmable full flag.                                                                                                                                                                                                                                                  |
| prog_empty_thresh    | Input               | rd_aw | Programmable Empty Threshold: This signal is used                                                                                                                                                                                                                        |
|                      | (optional)          |       | to input the                                                                                                                                                                                                                                                             |
|                      |                     |       | threshold value for the assertion and de-assertion                                                                                                                                                                                                                       |
|                      |                     |       | of the                                                                                                                                                                                                                                                                   |
|                      |                     |       | programmable empty flag.                                                                                                                                                                                                                                                 |
| prog_full_assert     | Input               | wr_aw | Programmable Full Threshold Assert: This signal is                                                                                                                                                                                                                       |
|                      | (optional)          |       | used to set the upper threshold value for the                                                                                                                                                                                                                            |
|                      |                     |       | programmable full flag, which defines when the                                                                                                                                                                                                                           |
|                      |                     |       | signal is asserted.                                                                                                                                                                                                                                                      |
| prog_full_negate     | Input               | wr_aw | Programmable Full Threshold Negate: This signal is                                                                                                                                                                                                                       |
|                      | (optional)          |       | used to set the                                                                                                                                                                                                                                                          |
|                      |                     |       | lower threshold value for the programmable full                                                                                                                                                                                                                          |
|                      |                     |       | flag, which defines when the signal is de-asserted.                                                                                                                                                                                                                      |
| prog_empty_assert    | Input               | rd_aw | Programmable Empty Threshold Assert: This signal                                                                                                                                                                                                                         |
|                      | (optional)          |       | is used to set                                                                                                                                                                                                                                                           |
|                      |                     |       | the lower threshold value for the programmable                                                                                                                                                                                                                           |
|                      |                     |       | empty flag, which                                                                                                                                                                                                                                                        |
|                      |                     |       | defines when the signal is asserted                                                                                                                                                                                                                                      |
| prog_empty_negate    | Input               | rd_aw | Programmable Empty Threshold Negate: This                                                                                                                                                                                                                                |
|                      | (optional)          |       | signal is used to set                                                                                                                                                                                                                                                    |
|                      |                     |       | the upper threshold value for the programmable                                                                                                                                                                                                                           |
|                      |                     |       | empty flag, which                                                                                                                                                                                                                                                        |
|                      |                     |       | defines when the signal is de-asserted.                                                                                                                                                                                                                                  |
| wfull                | Output              | 1     | FIFO full flag, active high                                                                                                                                                                                                                                              |
| rempty               | Output              | 1     | FIFO empty flag, active high                                                                                                                                                                                                                                             |
| almost_full          | Output              | 1     | This signal indicates that only one more write car                                                                                                                                                                                                                       |
|                      | (optional)          |       | be performed before the FIFO is full.                                                                                                                                                                                                                                    |
| almost_empty         | Ouput               | 1     | this signal indicates that the FIFO is almost empty                                                                                                                                                                                                                      |
|                      | (optional)          |       | and one word remains in the FIFO.                                                                                                                                                                                                                                        |
| prog_full            | Output              | 1     | This signal is asserted when the number of words                                                                                                                                                                                                                         |
|                      | (optional)          |       | in the FIFO is greater than or equal to the assert                                                                                                                                                                                                                       |
|                      | (-1/                |       |                                                                                                                                                                                                                                                                          |
|                      | ()                  |       | threshold. It is deasserted when the number of                                                                                                                                                                                                                           |
|                      | (                   |       | threshold. It is deasserted when the number of words in the FIFO is less than the threshold.                                                                                                                                                                             |
| prog_empty           | Ouput               | 1     | words in the FIFO is less than the threshold.                                                                                                                                                                                                                            |
| prog_empty           |                     | 1     | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word                                                                                                                                                                         |
| prog_empty           | Ouput               | 1     | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word<br>in the FIFO is less than or equal to the                                                                                                                             |
| prog_empty           | Ouput               | 1     | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word<br>in the FIFO is less than or equal to the<br>programmable threshold. It is de-asserted when                                                                           |
| prog_empty           | Ouput               | 1     | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word<br>in the FIFO is less than or equal to the<br>programmable threshold. It is de-asserted when                                                                           |
|                      | Ouput<br>(optional) | 1     | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word<br>in the FIFO is less than or equal to the<br>programmable threshold. It is de-asserted when<br>the number of words in the FIFO exceeds the<br>programmable threshold. |
| prog_empty<br>wr_ack | Ouput               |       | words in the FIFO is less than the threshold.<br>This signal is asserted when the number of word<br>in the FIFO is less than or equal to the<br>programmable threshold. It is de-asserted when<br>the number of words in the FIFO exceeds the                            |



| rd ool      | Output     | 1     | rd adu This signal indicates that valid data is      |
|-------------|------------|-------|------------------------------------------------------|
| rd_ack      | Output     | 1     | rd_ack: This signal indicates that valid data is     |
|             | (optional) |       | available on the output bus (rdata).                 |
| overflow    | Output     | 1     | Overflow: This signal indicates that a write request |
|             | (optional) |       | (wen) during the prior clock cycle was rejected,     |
|             |            |       | because the FIFO is full.                            |
| underflow   | Output     | 1     | Underflow: Indicates that read request (ren) during  |
|             | (optional) |       | the previous clock cycle was rejected because the    |
|             |            |       | FIFO is empty.                                       |
| wr_data_cnt | Output     | wr_aw | Indicate how many data are stored in FIFO, in write  |
|             | (optional) |       | clock domain.                                        |
| rd_data_cnt | Output     | rd_aw | Indicate how many data are stored in FIFO, in read   |
|             | (optional) |       | clock domain.                                        |

### 3.2 Synchronous FIFO interface

Following figure shows the synchronous FIFO interface





The synchronous FIFO pin descriptions are outlined in the table below.

| Table 3-2 Synchronous | FIFO pin | description |
|-----------------------|----------|-------------|
|-----------------------|----------|-------------|

| Interface | Name  | Direction | Width | Description             |
|-----------|-------|-----------|-------|-------------------------|
| System    | clk   | Input     | 1     | clock input             |
|           | rst_n | Input     | 1     | reset input, active low |



| User      | wdata             | Input               | wr_dw | FIFO write data                                                                                                                                                              |  |  |  |  |  |  |  |
|-----------|-------------------|---------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Interface | rdata             | Input               | rd_dw | FIFO read data                                                                                                                                                               |  |  |  |  |  |  |  |
|           | wen               | Input               | 1     | FIFO write enable                                                                                                                                                            |  |  |  |  |  |  |  |
|           | ren               | Input               | 1     | FIFO read enable                                                                                                                                                             |  |  |  |  |  |  |  |
|           | wclr              | Input               | 1     | Synchronous clear input to clear write pointer,                                                                                                                              |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | write related flag output, active high                                                                                                                                       |  |  |  |  |  |  |  |
|           | rclr              | Input               | 1     | Synchronous clear input to clear read pointer, read                                                                                                                          |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | related flag output, active high                                                                                                                                             |  |  |  |  |  |  |  |
|           | prog_full_thresh  | Input               | wr_aw | Programmable Full Threshold: This signal is used to                                                                                                                          |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | input the                                                                                                                                                                    |  |  |  |  |  |  |  |
|           |                   |                     |       | threshold value for the assertion and de-assertion                                                                                                                           |  |  |  |  |  |  |  |
|           |                   |                     |       | of the                                                                                                                                                                       |  |  |  |  |  |  |  |
|           |                   |                     |       | programmable full flag.                                                                                                                                                      |  |  |  |  |  |  |  |
|           | prog_empty_thresh | Input               | rd_aw | Programmable Empty Threshold: This signal is used                                                                                                                            |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | to input the                                                                                                                                                                 |  |  |  |  |  |  |  |
|           |                   |                     |       | threshold value for the assertion and de-assertion                                                                                                                           |  |  |  |  |  |  |  |
|           |                   |                     |       | of the                                                                                                                                                                       |  |  |  |  |  |  |  |
|           |                   |                     |       | programmable empty flag.                                                                                                                                                     |  |  |  |  |  |  |  |
|           | prog_full_assert  | Input               | wr_aw | Programmable Full Threshold Assert: This signal is                                                                                                                           |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | used to set the upper threshold value for the                                                                                                                                |  |  |  |  |  |  |  |
|           |                   |                     |       | programmable full flag, which defines when the                                                                                                                               |  |  |  |  |  |  |  |
|           |                   |                     |       | signal is asserted.                                                                                                                                                          |  |  |  |  |  |  |  |
|           | prog_full_negate  | Input               | wr_aw | Programmable Full Threshold Negate: This signal is                                                                                                                           |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | used to set the                                                                                                                                                              |  |  |  |  |  |  |  |
|           |                   |                     |       | lower threshold value for the programmable full<br>flag, which defines when the signal is de-asserted.<br>Programmable Empty Threshold Assert: This signal<br>is used to set |  |  |  |  |  |  |  |
|           |                   |                     |       |                                                                                                                                                                              |  |  |  |  |  |  |  |
|           | prog_empty_assert | Input<br>(optional) | rd_aw |                                                                                                                                                                              |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | the lower threshold value for the programmable                                                                                                                               |  |  |  |  |  |  |  |
|           |                   |                     |       | empty flag, which                                                                                                                                                            |  |  |  |  |  |  |  |
|           |                   |                     |       | defines when the signal is asserted                                                                                                                                          |  |  |  |  |  |  |  |
|           | prog_empty_negate | Input               | rd_aw | Programmable Empty Threshold Negate: This                                                                                                                                    |  |  |  |  |  |  |  |
|           | p. 08_0p.t/8446   | (optional)          |       | signal is used to set                                                                                                                                                        |  |  |  |  |  |  |  |
|           |                   | (0000000)           |       | the upper threshold value for the programmable                                                                                                                               |  |  |  |  |  |  |  |
|           |                   |                     |       | empty flag, which                                                                                                                                                            |  |  |  |  |  |  |  |
|           |                   |                     |       | defines when the signal is de-asserted.                                                                                                                                      |  |  |  |  |  |  |  |
|           | wfull             | Output              | 1     | FIFO full flag, active high                                                                                                                                                  |  |  |  |  |  |  |  |
|           | rempty            | Output              | 1     | FIFO empty flag, active high                                                                                                                                                 |  |  |  |  |  |  |  |
|           | almost_full       | Output              | 1     | This signal indicates that only one more write car                                                                                                                           |  |  |  |  |  |  |  |
|           | _                 | (optional)          |       | be performed before the FIFO is full.                                                                                                                                        |  |  |  |  |  |  |  |
|           | almost_empty      | Ouput               | 1     | This signal indicates that the FIFO is almost empty                                                                                                                          |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | and one word remains in the FIFO.                                                                                                                                            |  |  |  |  |  |  |  |
|           | prog_full         | Output              | 1     | This signal is asserted when the number of words                                                                                                                             |  |  |  |  |  |  |  |
|           |                   | (optional)          |       | in the FIFO is greater than or equal to the asser                                                                                                                            |  |  |  |  |  |  |  |



| r | Г           |            | 1     | ,,                                                   |  |  |  |  |  |  |
|---|-------------|------------|-------|------------------------------------------------------|--|--|--|--|--|--|
|   |             |            |       | threshold. It is deasserted when the number of       |  |  |  |  |  |  |
|   |             |            |       | words in the FIFO is less than the negate threshold. |  |  |  |  |  |  |
|   |             |            |       | The threshold can be const, dynamic inputs, const    |  |  |  |  |  |  |
|   |             |            |       | range or dynamic range inputs                        |  |  |  |  |  |  |
|   | prog_empty  | Ouput      | 1     | This signal is asserted when the number of words     |  |  |  |  |  |  |
|   |             | (optional) |       | in the FIFO is less than or equal to the             |  |  |  |  |  |  |
|   |             |            |       | programmable threshold. It is de-asserted when       |  |  |  |  |  |  |
|   |             |            |       | the number of words in the FIFO exceeds the          |  |  |  |  |  |  |
|   |             |            |       | programmable threshold.                              |  |  |  |  |  |  |
|   |             |            |       | The threshold can be const, dynamic inputs, const    |  |  |  |  |  |  |
|   |             |            |       | range or dynamic range inputs                        |  |  |  |  |  |  |
|   | rd_ack      | Output     | 1     | Rd_ack: This signal indicates that valid data is     |  |  |  |  |  |  |
|   |             | (optional) |       | available on the output bus (rdata).                 |  |  |  |  |  |  |
|   | wr_ack      | Output     | 1     | Write Acknowledge: This signal indicates that a      |  |  |  |  |  |  |
|   |             | (optional) |       | write request (wen) during the prior clock cycle     |  |  |  |  |  |  |
|   |             |            |       | succeeded.                                           |  |  |  |  |  |  |
|   | overflow    | Output     | 1     | Overflow: This signal indicates that a write request |  |  |  |  |  |  |
|   |             | (optional) |       | (wen) during the prior clock cycle was rejected,     |  |  |  |  |  |  |
|   |             |            |       | because the FIFO is full.                            |  |  |  |  |  |  |
|   | underflow   | Output     | 1     | Underflow: Indicates that read request (ren) during  |  |  |  |  |  |  |
|   |             | (optional) |       | the previous clock cycle was rejected because the    |  |  |  |  |  |  |
|   |             |            |       | FIFO is empty.                                       |  |  |  |  |  |  |
|   | wr_data_cnt | Output     | wr_aw | Indicate how many data are stored in FIFO in write   |  |  |  |  |  |  |
|   |             | (optional) |       | domain                                               |  |  |  |  |  |  |
|   | rd_data_cnt | Output     | rd_aw | Indicate how many data are stored in FIFO in read    |  |  |  |  |  |  |
|   |             | (optional) | _     | domain                                               |  |  |  |  |  |  |
| L |             |            | L     |                                                      |  |  |  |  |  |  |

### 3.3 FIFO programmed parameter list

FIFO related parameters are shown as below:

Table 3-3 FIFO parameters list

| Name            | Туре | Value | Description                                                                                              |
|-----------------|------|-------|----------------------------------------------------------------------------------------------------------|
| wr_dw           | int  | >=1   | Write data width                                                                                         |
| rd_dw           | int  | >=1   | Read data width                                                                                          |
| wr_aw           | int  | >=4   | Write address width                                                                                      |
| rd_aw           | Int  | >=4   | Read address width                                                                                       |
| need_syn_wr_clr | Int  | 1, 0  | <ol> <li>Synchronous clear for FIFO in<br/>write clock domain;</li> <li>Not synchronous clear</li> </ol> |
| need_syn_rd_clr | int  | 1, 0  | <ol> <li>Synchronous clear for FIFO in<br/>write clock domain;</li> <li>Not synchronous clear</li> </ol> |



| area full ture          | otaine | aanat dun cirala                                                                            | Support 4 tupos of anomaly the       |
|-------------------------|--------|---------------------------------------------------------------------------------------------|--------------------------------------|
| prog_full_type          | string | const, dyn_single                                                                           | Support 4 types of programmable      |
|                         |        | range, dyn_range                                                                            | full flag generation:                |
|                         |        |                                                                                             | const: single programmable           |
|                         |        |                                                                                             | threshold setting through            |
|                         |        |                                                                                             | parameter;                           |
|                         |        |                                                                                             | dyn_single: single programmable      |
|                         |        |                                                                                             | threshold setting through            |
|                         |        |                                                                                             | inputs(prog_full_thresh);            |
|                         |        |                                                                                             | range: multiple programmable         |
|                         |        |                                                                                             | threshold setting through            |
|                         |        |                                                                                             | parameters;                          |
|                         |        |                                                                                             | dyn_range: multiple programmable     |
|                         |        |                                                                                             | thresh setting through inputs ports  |
| prog_empty_type         | String | const, dyn_single                                                                           | Support 4 types of programmable      |
|                         |        | range, dyn_range                                                                            | full flag generation:                |
|                         |        |                                                                                             | const: single programmable           |
|                         |        |                                                                                             | threshold setting through            |
|                         |        |                                                                                             | parameter;                           |
|                         |        |                                                                                             | dyn_single:                          |
|                         |        |                                                                                             |                                      |
|                         |        |                                                                                             | single programmable threshold        |
|                         |        |                                                                                             | setting through                      |
|                         |        |                                                                                             | inputs(prog_full_thresh);            |
|                         |        |                                                                                             | range:                               |
|                         |        |                                                                                             | multiple programmable threshold      |
|                         |        |                                                                                             | setting through parameters;          |
|                         |        |                                                                                             | dyn_range:                           |
|                         |        |                                                                                             | multiple programmable thresh         |
|                         |        |                                                                                             | setting through inputs ports         |
| prog_full_thresh        | Int    | >=2,<=wn,                                                                                   | Programmable full threshold          |
|                         |        | wn=(1< <wr_aw< td=""><td></td></wr_aw<>                                                     |                                      |
|                         |        | -2*sh_bits)                                                                                 |                                      |
| prog_empty_thresh       | Int    | >=2, <=rn                                                                                   | Programmable empty threshold         |
|                         |        | rn=(1< <rd_aw-2*sh_bits< td=""><td></td></rd_aw-2*sh_bits<>                                 |                                      |
|                         |        | )                                                                                           |                                      |
| prog_full_assert_const  | Int    | )<br>>=3,<=wn,                                                                              | Programmable upper threshold         |
|                         |        | wn=(1< <wr_aw< td=""><td>value for the programmable full flag</td></wr_aw<>                 | value for the programmable full flag |
|                         |        | _                                                                                           |                                      |
| and full as a little    |        | -2*sh_bits)                                                                                 |                                      |
| prog_full_negate_const  | int    | >=2,<=wn,                                                                                   | Programmable lower threshold         |
|                         |        | wn=(1< <wr_aw< td=""><td>value for the programmable full</td></wr_aw<>                      | value for the programmable full      |
|                         |        | -3*sh_bits)                                                                                 | flag, must less than                 |
|                         |        |                                                                                             | prog_full_assert_const               |
| prog_empty_assert_const | Int    | >=2, <=rn                                                                                   | Programmable lower threshold         |
|                         |        | rn=(1< <rd_aw-3*sh_bits< td=""><td>value for the programmable empty</td></rd_aw-3*sh_bits<> | value for the programmable empty     |
|                         |        | )                                                                                           | flag                                 |



| prog_empty_negate_const | Int | >=3, <=rn                                                                                   | Programmable upper threshold         |
|-------------------------|-----|---------------------------------------------------------------------------------------------|--------------------------------------|
|                         |     | rn=(1< <rd_aw-2*sh_bits< td=""><td>value for the programmable empty</td></rd_aw-2*sh_bits<> | value for the programmable empty     |
|                         |     | )                                                                                           | flag, must bigger than               |
|                         |     |                                                                                             | prog_empty_asser_const               |
| gen_prog_full           | Int | 1, 0                                                                                        | 1: generate programmable full flag;  |
|                         |     |                                                                                             | 0: do not generate programmable      |
|                         |     |                                                                                             | full flag.                           |
| gen_prog_empty          | Int | 1, 0                                                                                        | 1: generate programmable empty       |
|                         |     |                                                                                             | flag;                                |
|                         |     |                                                                                             | 0: do not generate programmable      |
|                         |     |                                                                                             | empty flag.                          |
| gen_almost_full         | Int | 1, 0                                                                                        | 1: generate almost full flag;        |
|                         |     |                                                                                             | 0: do not generate almost full flag. |
| gen_almost_empty        | Int | 1, 0                                                                                        | 1: generate almost empty flag;       |
|                         |     |                                                                                             | 0: do not generate almost empty      |
|                         |     |                                                                                             | flag.                                |
| gen_wr_data_cnt         | Int | 1, 0                                                                                        | 1: generate write data count flag;   |
|                         |     |                                                                                             | 0: do not generate write data count  |
|                         |     |                                                                                             | flag.                                |
| gen_rd_data_cnt         | Int | 1, 0                                                                                        | 1: generate read data count flag;    |
|                         |     |                                                                                             | 0: do not generate read data count   |
|                         |     |                                                                                             | flag.                                |
| gen_wr_ack              | Int | 1, 0                                                                                        | 1: generate write acknowledge flag;  |
|                         |     |                                                                                             | 0: do not generate write             |
|                         |     |                                                                                             | acknowledge flag.                    |
| gen_rd_ack              | Int | 1, 0                                                                                        | 1: generate read acknowledge flag;   |
|                         |     |                                                                                             | 0: do not generate read              |
|                         |     |                                                                                             | acknowledge flag.                    |
| gen_wr_overflow         | Int | 1, 0                                                                                        | 1: generate write overflow flag;     |
|                         |     |                                                                                             | 0: do not generate write overflow    |
|                         |     |                                                                                             | flag.                                |
| gen_rd_underflow        | int | 1,0                                                                                         | 1: generate read underflow flag;     |
|                         |     |                                                                                             | 0: do not generate read underflow    |
|                         |     |                                                                                             | flag.                                |
| fwft_en                 | int | 1,0                                                                                         | 1: support FWFT function             |
|                         |     |                                                                                             | 0: not support FWFT function         |

NOTE:

 $sh\_bits = wr\_dw > rd\_dw ? log2(wr\_dw/rd\_dw) : log2(rd\_dw/wr\_dw)$ 



## **4 Software FIFO Usage and Control**

This section describes the behavior of asynchronous and synchronous FIFO write/read and the associated status flags.

When write enable is asserted and the FIFO is not full, data is added to the FIFO from the input bus and write acknowledge is asserted. If the FIFO is continuously written without being read, it is filled with data. Write operations are successful only when the FIFO is not full. When the FIFO is full, any writing request is ignored, in the meanwhile the overflow flag is asserted and there is no change in the state of the FIFO.

When read enable signal is asserted and the FIFO is not empty, data is read from the FIFO on the output bus, and the rd\_ack flag is asserted. If the FIFO is continuously read without being written, the FIFO empties eventually. Read operations are successful only if the FIFO is not empty. When the FIFO is empty, any read operation request is ignored, meanwhile the underflow flag is asserted and there is no change in the state of the FIFO.

### 4.1 FIFO Full/Empty generation

A FIFO is full when the pointers are equal again, that is, the write pointer has wrapped around and caught up to the read pointer.

A FIFO is empty when the read and write pointers are both equal. This condition happens when both pointers are reset to zero during a reset operation, or when the read pointer catches up to the write pointer, which means the last data is read out from the FIFO.

**Full Generation:** 

Asynchronous FIFO full generation example



Figure 4-1 Asynchronous FIFO full generation

Synchronous FIFO full generation example

| clk            | 1  |   |   |   |   |     |   |   |   |   |   |          |   |     |   |   |                  |            |   |  |    | ſ |
|----------------|----|---|---|---|---|-----|---|---|---|---|---|----------|---|-----|---|---|------------------|------------|---|--|----|---|
| ret_n          |    |   |   |   |   |     |   |   |   |   |   |          |   |     |   |   |                  |            |   |  |    |   |
| wen            |    |   |   |   |   |     |   |   |   |   |   |          |   |     |   |   |                  |            |   |  |    |   |
| wbin[4:0]      |    | 0 |   | 1 | 2 | ) 3 | 4 | 5 | 6 | 7 | 8 | 9        |   | ь   |   | d | . •              | ) <u>f</u> | X |  | 10 |   |
| wbin_next[4:0] |    | 0 | 1 | 2 | 3 | 4   | 5 | 6 | 7 | 8 | 9 | <u> </u> | Ь | е   | a | e | ) <mark>E</mark> | 1          |   |  | 10 |   |
| rbin[4:0]      | 14 |   |   |   |   |     |   |   |   |   |   |          |   | 3 4 | T |   |                  |            |   |  |    |   |
| wEull          |    |   |   |   |   |     |   |   |   |   |   |          |   |     |   |   |                  |            |   |  |    |   |

Figure 4-2 Synchronous FIFO full generation

**Empty Generation:** 



Asynchronous FIFO empty generation example

| relk              | 1  |      |   |   |    |   |   |   |   |   |   |          |   |   |   |   |    |    |    |    |    |   |  |
|-------------------|----|------|---|---|----|---|---|---|---|---|---|----------|---|---|---|---|----|----|----|----|----|---|--|
| rret_n            | 1  |      |   |   |    |   |   |   |   |   |   |          |   |   |   |   |    |    |    |    |    |   |  |
| ren               | 0  |      |   |   |    |   |   |   |   |   |   |          |   |   |   |   |    |    |    |    |    |   |  |
| rbin_next[4:0]    | 10 | 0    | 1 | 2 | 3  | 4 | 5 | 6 | 7 | 8 | 9 | <u> </u> | Ь | e | đ | e | £  |    |    | 1  | 0  |   |  |
| rgray_next[4:0]   | 18 | 0    | 1 | 3 | 2  | 6 | 7 | 5 | 4 | e | d | <u> </u> | • | ۵ | ь | 9 | 8  |    |    | 1  | 3  |   |  |
| welk              | 0  |      |   |   |    |   |   |   |   |   |   |          |   |   | ப |   |    |    |    |    | ЛГ | Л |  |
| wen               | 0  |      |   |   |    |   |   |   |   |   |   |          |   |   | 1 |   |    |    |    |    |    |   |  |
| rq2_wptr[4:0]     | 18 | Ь) 9 | ) |   | 18 |   |   |   |   |   |   |          |   |   |   |   | 19 | 1Ь | le |    |    |   |  |
| rq2_wptr_bin[4:0] | 10 | d) e | ľ |   | 10 |   |   |   |   |   |   |          |   |   |   |   |    | 11 | 12 | 14 |    |   |  |
| rempty            | 1  |      |   |   |    |   |   |   |   |   |   |          |   |   |   |   |    |    |    |    |    |   |  |

Figure 4-3 Asynchronous FIFO empty generation

#### Synchronous FIFO empty generation example



Figure 4-4 Synchronous FIFO empty generation

### 4.2 Almost full/Almost empty generation

When only one more write operation can be performed before the FIFO is full, the almost full signal is asserted. This flag is active high and synchronous to the write clock.

When only one more read operation can be performed before the FIFO is empty, the almost empty signal is asserted. This flag is active high and synchronous to the read clock.

#### Almost full generation:

#### Asynchronous FIFO almost full generation example



Figure 4-5 Asynchronous FIFO almost full generation

Synchronous FIFO almost full generation example



Figure 4-6 Synchronous FIFO almost full generation

Almost empty generation:



Asynchronous FIFO almost empty generation example

| relk              | 1  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   |              |    |             |    |            |      |
|-------------------|----|------------|---|---|-----|---|---|---|---|---|---|---|---|---|---|-----|---|---|--------------|----|-------------|----|------------|------|
| rret_n            | 1  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   |              |    |             |    |            |      |
| ren               | 0  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   |              |    |             |    |            |      |
| rbin_next[4:0]    | 10 |            | 0 | 1 | ) Z | 3 | 4 | 5 | 6 | 7 | 8 | 9 | ۵ | Ь | с | ) a | • | f | 1<br>1       | 10 |             |    | 11         | 12   |
| rgray_next[4:0]   | 18 |            | 0 | 1 | 3   | 2 | 6 | 7 | 5 | 4 | с | a | £ | e | ۵ | ΪЬ  | 9 | 8 | 1            | 18 |             |    | 19         | 1Ь ( |
| welk              | 0  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     | Ш |   |              | ЛЛ |             |    | Л          |      |
| wen               | 0  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   | <br><u>'</u> |    |             |    |            |      |
| rq2_wptr[4:0]     | 18 | Ь          | 9 |   |     |   |   |   |   |   |   | 1 | 8 |   |   |     |   |   | I            | 19 | <u>(1</u> ь | le | 1 <u>f</u> | le   |
| rq2_wptr_bin[4:0] | 10 | <b>a</b> ( | e |   |     |   |   |   |   |   |   | 1 | 0 |   |   |     |   |   |              | 11 | 12          | 14 | 15         | 17   |
| rempty            | 1  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   |              |    |             |    |            |      |
| almost_empty      | 0  |            |   |   |     |   |   |   |   |   |   |   |   |   |   |     |   |   |              |    |             |    |            |      |

Figure 4-7 Asynchronous FIFO almost empty generation

#### Synchronous FIFO almost empty generation example

| clk            | 1  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    |    |    |    |    |    |    |               |
|----------------|----|---|-----|---|---|---|---|---|---|------------|-----------|------------|---|-----|----------|----------|---|-----|---|-----|------------|----|----|----|----|----|----|----|---------------|
| ret_n          | 1  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    |    |    |    |    |    |    |               |
| ren            | 0  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    |    |    |    |    |    |    |               |
| rbin[4:0]      | 14 |   |     |   | 0 |   | 1 | 2 | 3 | <u> </u> 4 | <u> 5</u> | Ϊ <u>6</u> | 7 | ľ 8 | [ 9      | <u> </u> | Ь | [ c | d | Ĭ e | [ <u>f</u> |    |    | 10 |    |    |    |    | <u>, 11 )</u> |
| rbin_next[4:0] | 14 |   |     | 0 |   | 1 | 2 | 3 | 4 | 5          | <u> 6</u> | 7          | 8 | 9   | <b>a</b> | Ь        | е | a   | e | E   |            |    | 10 |    |    |    |    | 11 | 12            |
| wen            | 1  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    |    |    |    |    |    |    |               |
| wbin[4:0]      | 4  | a | • ( | £ |   |   |   |   |   |            |           |            | 1 | .0  |          |          |   |     |   |     |            | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 (          |
| rempty         | 0  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    | 1  |    |    |    |    |    |               |
| almost_empty   | 0  |   |     |   |   |   |   |   |   |            |           |            |   |     |          |          |   |     |   |     |            |    |    |    |    |    |    |    |               |

Figure 4-8 Synchronous FIFO almost empty generation

### 4.3 Programmable full/empty generation

#### 4.3.1 Programmable Full

The FIFO Generator supports four ways to define the programmable full threshold:

- Single threshold constant (prog\_full\_type = "single")
- Single threshold with dedicated input port (prog\_full\_typ = "dyn\_single")
- Assert and negate threshold constants (prog\_full\_type = "range")
- Assert and negate thresholds with dedicated input ports (prog\_full\_type = "dyn\_range")

When the number of words in the FIFO is greater than or equal to the asserted threshold, the programmable full signal is asserted. It is de-asserted when the number of words in the FIFO less than the negate threshold. When the number of words in the FIFO is less than or equal to the programmable threshold, the programmable empty signal is asserted. It is de-asserted when the number of words in the FIFO exceeds the programmable threshold.

#### **Programmable Full: Single Threshold**

This option enables the user to set a single threshold value for the assertion and deassertion of prog\_full. When the number of entries in the FIFO is greater than or equal to the threshold value, prog\_full is asserted or else the flag is deasserted.

Two options are available to implement this threshold:

- Single threshold constant. User specifies the threshold value through the IP Wizard. Once the core is generated, this value can only be changed by regenerating the core. This option consumes fewer resources than the single threshold with dedicated input port.
- Single threshold with dedicated input port. User specifies the threshold value through an input port (prog\_full\_thresh) on the core. This input can be changed dynamically, providing the user the flexibility to change the programmable full threshold in-circuit without re-generating the core.
- Asynchronous FIFO programmable full generation example





Figure 4-9 Asynchronous FIFO programmable full generation (prog\_full\_thresh=12)

#### Synchronous FIFO programmable full generation example



Figure 4-10 Synchronous FIFO programmable full generation (prog\_full\_thresh=12)

#### Programmable Full: Assert and Negate Thresholds

This option enables the user to set separate values for the assertion and deassertion of prog\_full. When the number of entries in the FIFO is greater than or equal to the assert value, prog\_full is asserted. When the number of entries in the FIFO is less than the negate value, prog\_full is deasserted.

Two options are available to implement these thresholds:

- Assert and negate threshold constants: User specifies the threshold values through the IP Wizard. Once the core is generated, these values can only be changed by re-generating the core. This option consumes fewer resources than the assert and negate thresholds with dedicated input ports.
- Assert and negate thresholds with dedicated input ports: User specifies the threshold values through input ports on the core. These input ports can be changed dynamically, providing the user with the flexibility to change the values of the programmable full assert (prog\_full\_assert) and negate (prog\_full\_negate) thresholds in-circuit without re-generating the core.



#### Asynchronous FIFO programmable full generation example

Figure 4-11 Asynchronous FIFO programmable full generation (prog\_full\_assert=13, prog\_full\_negate=9)

Synchronous FIFO programmable full generation example





Figure 4-12 Synchronous FIFO programmable full generation (prog\_full\_assert=13, prog\_full\_negate=9)

#### 4.3.2 Programmable Empty

The FIFO Generator supports four ways to define the programmable empty thresholds:

- Single threshold constant (prog\_empty\_type = "single")
- Single threshold with dedicated input port (prog\_empty\_type = "dyn\_single")
- Assert and negate threshold constants (prog\_empty\_type = "range")
- Assert and negate thresholds with dedicated input ports (prog\_empty\_type = "dyn\_range")

#### Programmable Empty: Single Threshold

This option enables you to set a single threshold value for the assertion and deassertion of prog\_empty. When the number of entries in the FIFO is less than or equal to the threshold value, prog\_empty is asserted or else prog\_empty is deasserted.

Two options are available to implement this threshold:

- **Single threshold constant:** User specifies the threshold value through the IP Wizard. Once the core is generated, this value can only be changed by regenerating the core. This option consumes fewer resources than the single threshold with dedicated input port.
- **Single threshold with dedicated input port**: User specifies the threshold value through an input port (prog\_empty\_thresh) on the core. This input can be changed dynamically, providing the flexibility to change the programmable empty threshold in-circuit without re-generating the core.
- Asynchronous FIFO programmable empty generation example



Figure 4-13 Asynchronous FIFO programmable empty generation (prog\_empty\_thresh=4)

Synchronous FIFO programmable empty generation example





Figure 4-14 Synchronous FIFO programmable empty generation (prog\_empty\_thresh=4)

#### Programmable Empty: Assert and Negate Thresholds

This option lets the user set separate values for the assertion and deassertion of prog\_empty. When the number of entries in the FIFO is less than or equal to the assert value, prog\_empty is asserted. When the number of entries in the FIFO is greater than the negate value, prog\_empty is deasserted.

Two options are available to implement these thresholds.

- Assert and negate threshold constants. The threshold values are specified through the IP Wizard. Once the core is generated, these values can only be changed by re-generating the core. This option consumes fewer resources than the assert and negate thresholds with dedicated input ports.
- Assert and negate thresholds with dedicated input ports. The threshold values are specified through input ports on the core. These input ports can be changed dynamically, providing the user the flexibility to change the values of the programmable empty assert (prog\_empty\_assert) and negate (prog\_empty\_negate) thresholds in-circuit without regenerating the core.

#### Asynchronous FIFO programmable empty generation example



Figure 4-15 Asynchronous FIFO programmable empty generation (prog\_empty\_assert=3, prog\_empty\_negate=5)

#### Synchronous FIFO programmable empty generation example

| clk              | 1  |            |            |    |    |    |    |    |        |    |    |     |    |    |    |    |            |    |    |    |  |
|------------------|----|------------|------------|----|----|----|----|----|--------|----|----|-----|----|----|----|----|------------|----|----|----|--|
| ren              | 1  |            |            |    |    |    |    |    |        |    |    |     |    |    |    |    |            |    |    |    |  |
| rbin[4:0]        | а  | <u>}</u> 6 | X 7        | 8  | 9  | ٩  | Ь  | c  | а      | •  | £  |     |    |    |    |    |            |    |    |    |  |
| rdata[7:0]       | 14 | е          | е          | 10 | 12 | 14 | 16 | 18 | 14     | le | le |     |    |    |    |    |            |    |    |    |  |
| rempty           | 0  |            |            |    |    |    |    |    | I      |    |    |     |    |    |    |    |            |    |    |    |  |
| almost_empty     | 0  |            |            |    |    |    |    |    | I<br>I |    |    |     |    |    |    |    |            |    |    |    |  |
| prog_empty       | 1  |            |            |    |    |    |    |    |        |    |    |     |    |    |    |    |            |    |    |    |  |
| rd_data_cnt[3:0] | 3  | <u>)</u>   | <u>)</u> 9 | 8  | 7  | 6  | 5  | 4  | 3      | 2  | 1  | ( C | )  | 1  | 2  | 3  | 4          | 5  | 6  | 7  |  |
| wen              | 0  |            |            |    |    |    |    |    | I<br>I |    |    |     |    |    |    |    |            |    |    |    |  |
| wbin[4:0]        | 10 |            |            |    |    |    | 1  | 0  | I      |    |    |     |    | 11 | 12 | 13 | 14         | 15 | 16 | 17 |  |
| wdata[7:0]       | 20 |            | 10<br>20   |    |    |    |    |    |        |    |    |     | 22 | 24 | 26 | 28 | 2 <b>a</b> | 2e | 2e | 30 |  |

Figure 4-16 Synchronous FIFO programmable empty generation (prog\_empty\_assert=3, prog\_empty\_negate=5)



#### 4.3.3 Data count generation

Write data count (wr\_data\_cnt) pessimistically reports the number of words written into the FIFO. The count is guaranteed to never under-report the number of words in the FIFO (although it may temporarily over-report the number of words present) to ensure that the user never overflows the FIFO.

Read data count (rd\_data\_cnt) pessimistically reports the number of words available for reading. The count is guaranteed to never over-report the number of words available in the FIFO (although it may temporarily under-report the number of words available) to ensure that the user design never underflows the FIFO.

For write and read with different width, the wr\_data\_cnt represents the data with write data width that stored in FIFO and rd\_data\_cnt represents the data with read data width that stored in FIFO.

#### Asynchronous FIFO

| welk                               |                                                                    |
|------------------------------------|--------------------------------------------------------------------|
| wen                                |                                                                    |
| ren                                |                                                                    |
| wbin_next[4:0]<br>[2_rptr_bin[4:0] |                                                                    |
| wr_data_ont[4:0]<br>wfull          | a 6 7 8 9 a b c a e f 10 f e a c b a 9 8 7 6 5 4 3 2 3 4 5 6 7 8 9 |
| almost_full<br>prog_full           |                                                                    |
| rempty                             |                                                                    |
| almost_empty<br>prog_empty         |                                                                    |

Figure4-17 Asynchronous FIFO wr\_data\_cnt (prog\_empty\_thresh=4)

The wr\_data\_cnt signal shows how many data are stored in FIFO in write clock domain, as is shown in the figure above

| welk                     |                                                         |      |
|--------------------------|---------------------------------------------------------|------|
| wen                      |                                                         |      |
| relk                     |                                                         |      |
| ren<br>rbin_next[4:0]    |                                                         | 1 12 |
| rq2_wptr_bin[4:0]        |                                                         | 5 17 |
| wr_data_ent[4:0]         |                                                         | 891  |
| rd_data_ent[4:0]         | 5 2 4 5 7 8 a b a e f e d c b a 9 8 7 6 5 4 3 2 1 0 1 2 | 4    |
| wful1                    |                                                         | ;    |
| almost_full<br>prog_full |                                                         |      |
| rempty                   |                                                         | i i  |
| almost_empty             |                                                         |      |
| prog_empty               | 0                                                       |      |

Figure4-18 Asynchronous FIFO rd\_data\_cnt (prog\_empty\_thresh=4)

The rd\_data\_cnt signal shows how many data are stored in FIFO in read clock domain, as is shown in the figure above

Synchronous FIFO



Figure4-19 Synchronous FIFO wr\_data\_cnt (prog\_full\_assert=13, prog\_full\_negate=9)





Figure4-20 Synchronous FIFO rd\_data\_cnt (prog\_full\_assert=13, prog\_full\_negate=9)

#### 4.3.4 Handshaking interface generation

Handshaking flags (read acknowledge, underflow, write acknowledge and overflow) are supported to provide additional information regarding the status of the write and read operations.

The write acknowledge flag (wr\_ack) is asserted at the completion of each successful write operation and indicates that the data on the wdata port has been stored in the FIFO. This flag is synchronous to the write clock (wclk).

The read acknowledge flag (rd\_ack) is asserted at the completion of each successful read operation and indicates that the data read out from FIFO. This flag is synchronous to the read clock (rclk).

The over\_flow flag, this signal indicates that a write request (wen) during the prior clock cycle is rejected, because the FIFO is full

The underflow flag, this signal indicates that the read request during the previous clock cycle was rejected because the FIFO is empty



Figure4-21 Asynchronous FIFO write handshaking signal

| relk       | 1  |    |   |   |            |   |   |   |   |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Л    |    |       | $\Box$ |    |            |      |   |   |
|------------|----|----|---|---|------------|---|---|---|---|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|-------|--------|----|------------|------|---|---|
| ren        | 1  |    |   |   |            |   |   |   |   |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |       |        |    |            |      |   | 1 |
| rbin[4:0]  | 1  | 0  | 1 | 2 | ) <u>3</u> | 4 | 5 | 6 | 7 | 8  | ) 9 | ( • | Ь  | ļe | a  | le | E  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 14 | [ 1ь | 10 | e ( 1 | 1d (   | le | <b>1</b> £ | 0    |   |   |
| rd_ack     | 1  |    |   |   |            |   |   |   |   |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |       |        |    |            |      |   | 1 |
| rdata[7:0] | 34 | XX | 2 | 4 | 6          | 8 | ۵ | е | e | 10 | 12  | 14  | 16 | 18 | 14 | le | le | 1  |    |    |    | 20 |    |    |    |    | 22 | 24 | 26   | 28 | 3 ( 2 | 2a (   | 2c | 2e         | - 30 | 3 | 2 |
| rempty     | 0  |    |   |   |            |   |   |   |   |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |       |        |    |            |      |   |   |
| underflow  |    |    |   |   |            |   |   |   |   |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |       |        |    |            |      |   |   |

Figure4-22 Asynchronous FIFO read handshaking signal

For synchronous FIFO, the handshaking interface is the same as asynchronous FIFO, except that synchronous FIFO's write and read are in the same clock domain.



## **5 Hardware FIFO**

### **5.1 Introduction**

The hardware FIFO can support the features as below:

- Support data width up to 18 bits with depth up to 1K bits;
- Support both synchronous and asynchronous FIFO;
- Support wfull/rempty status flag;
- Optional synchronous clear inputs that can clear write and read pointer simultaneously;
- Optional almost\_full/almost\_empty status flag generated according to the single threshold constant.
- Four optional handshake signals (wr\_ack, rd\_ack, overflow, underflow) provide feedback
   (acknowledgment or rejection) in response to write and read requests in the prior clock cycle;
- Invalid read or write requests are rejected without affecting the FIFO state. When FIFO is full, data can't write to FIFO anymore, the write data will be omitted. When FIFO is empty, data can't read out anymore;

Device Support:

HME-M7

### 5.2 Difference between SW FIFO and HW FIFO

#### Table 5-1 Compare SW FIFO with HW FIFO

| Items    | FIFO         | SW FIFO                             | HW FIFO                        |
|----------|--------------|-------------------------------------|--------------------------------|
| Size     |              | Depth up to: 2 <sup>19</sup>        | Only support up to 18Kbits     |
|          |              | Width up to: 288                    |                                |
|          | almost       | Indicates there is only one more    | Same as prog_full/empty in SW  |
|          | full/empty   | data can be written to or read from | FIFO                           |
|          |              | FIFO                                |                                |
| Dinc     | wr_cnt       | Indicates the number of data        | Do not support this function   |
| Pins     | rd_cnt       | stored in FIFO in write/read clock  |                                |
|          |              | domain                              |                                |
|          | clear signal | wclr: clear write pointer           | fifo_clr: clear write and read |
|          |              | rclr: clear read pointer            | pointer simultaneously         |
| Features | Proggrammble | Support 4 types:                    | Only one type:                 |
|          | full/empty   | Single threshold constant, Single   | Single threshold constant      |
|          | threshold    | threshold with dedicated input      |                                |
|          |              | port,                               |                                |



| Assert and negate threshold       |  |
|-----------------------------------|--|
| constants,                        |  |
| Assert and negate thresholds with |  |
| dedicated input ports             |  |



## **6 AHB interface FIFO**

See the document of "<u>HME\_AHB\_interface\_FIFO\_user\_guide\_EN02.pdf</u>" please click the file name.



## 7 Resource usage

| DepthxWidth | LUTs | Regs | EMBs |
|-------------|------|------|------|
| 64x16       | 24   | 16   | 1    |
| 512x16      | 32   | 22   | 2    |
| 1024x16     | 52   | 25   | 4    |
| 2048x16     | 55   | 27   | 8    |
| 4096x16     | 57   | 29   | 16   |

Table 7-1 Benchmarks, synchronous FIFO without optional features

Table 7-2 Benchmarks, synchronous FIFO with almost full/empty flag, multiple threshold and handshaking

| DepthxWidth | LUTs | Regs | EMBs |
|-------------|------|------|------|
| 64x16       | 46   | 22   | 1    |
| 512x16      | 60   | 28   | 2    |
| 1024x16     | 81   | 31   | 4    |
| 2048x16     | 87   | 33   | 8    |
| 4096x16     | 91   | 35   | 16   |

Table 7-3 Benchmarks, asynchronous FIFO without optional features

| DepthxWidth | LUTs | Regs | EMBs |
|-------------|------|------|------|
| 64x16       | 49   | 58   | 1    |
| 512x16      | 69   | 82   | 2    |
| 1024x16     | 93   | 91   | 4    |
| 2048x16     | 101  | 99   | 8    |
| 4096x16     | 110  | 107  | 16   |

Table 7-4 Benchmarks, asynchronous FIFO with almost full/empty flag, multiple threshold and handshaking

| DepthxWidth | LUTs | Regs | EMBs |
|-------------|------|------|------|
| 64x16       | 79   | 64   | 1    |
| 512x16      | 113  | 88   | 2    |
| 1024x16     | 142  | 97   | 4    |
| 2048x16     | 161  | 105  | 8    |
| 4096x16     | 169  | 113  | 16   |



## 8 Simulating your design

The Fuxi IP Wizard provide the source RTL for the FIFO, user can directly use this source code to do simulation. Except the RTL, the simulation libraries for HME-M5 and HME\_M7 are needed, you can find the lib from: Fuxi install directory\data\lib\js\_sim.v

Fuxi install directory\data\lib\m7s sim.v

Fuxi install directory\data\lib\hr3\_sim.v

When using Fuxi IP Wizard to generate FIFO core, a simulation directory under ip\_core\fifo\_v2 is generated. You can find the source RTL under the ip\_core\fifo\src directory, as is shown in Table9-1.



### **9 Generated File Directory Structure**

The FIFO IP wizard generated code includes source files (src) and related documentation(doc). The detailed design directory structure is as below:



Figure 9-1 FIFO IP wizard generate files structure

Table 9-1 Design Directory structure

| Directory                                       | Description                                                           |
|-------------------------------------------------|-----------------------------------------------------------------------|
| src\                                            | Directory for project source code, including IP wizard generate code. |
| ip_core\                                        | The directory specially for all IPs                                   |
| \fifo_v2                                        | Directory for FIFO IP                                                 |
| \doc\HME_AHB_interface_FIFO_user_guide_EN02.doc | User guide for ahb interface FIFO IP                                  |
| \doc\HME_fifo_user_guide_EN02.doc               | User guide for FIFO IP                                                |
|                                                 | (no ahb interface)                                                    |



| \src                                     | IP Design RTL                                 |
|------------------------------------------|-----------------------------------------------|
| fifo_ahb.v                               | The src of abb interface FIFO IP              |
| asyn fifo.v                              | Asynchronous FIFO source code                 |
| syn_fifo.v                               | Synchronous FIFO source code                  |
|                                          |                                               |
| M1M0_syn_fifo.v                          | Synchronous FIFO source code for device M0/M1 |
| MAINAO actum fife u                      |                                               |
| M1M0_asyn_fifo.v                         | Asynchronous FIFO source code for             |
|                                          | device M0/M1                                  |
| \sim                                     |                                               |
| \ syn_arm_w_r_tb.v                       | Testbench of ahb interface FIFO(arm           |
|                                          | write & arm read) IP                          |
| \ syn_arm_w_r_tb.do                      | Do script for Modelsim simulation             |
|                                          | (arm write & arm read)                        |
| \fifo_ahb_tb_modelsim.f                  | Modelsim simulation related files             |
| \fifo_v2_sim.v                           | Other RTL design files with AHB               |
|                                          | interface for simulation                      |
| \sim_src                                 |                                               |
| \*.v                                     | Other RTL design files for simulation         |
|                                          | about AHB bus                                 |
| \example                                 |                                               |
| fifo_demo_arm_r_fp_w.zip                 | AHB interface FIFO IP examples                |
| fifo_demo_arm_w_arm_r.zip                |                                               |
| fifo_demo_arm_w_fp_r.zip                 |                                               |
| HME_FIFO_AHB_example_user_guide_EN02.pdf | The guide of AHB interface FIFO               |



## **Revision History**

| Revision | Date       | Comments                                                                                                                           |  |
|----------|------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| 1.0      | 2018-03-26 | Initial release                                                                                                                    |  |
| 1.0      | 2018-03-26 | Interface update, support more prog_full/empty generation, support handshaking interfaces<br>Performance and resource usage update |  |
| 1.1      | 2018-03-26 | Change parameter type of prog_full/empty_type from string to int<br>Fix a bug of almost_empty generation of syn&asyn fifo          |  |
| 1.1      | 2018-03-26 | Add AHB interface                                                                                                                  |  |
| 2.0      | 2018-03-26 | Support First Word Fall Through function                                                                                           |  |
|          |            |                                                                                                                                    |  |

