# 刀

# Deep First-In First-Out (FIFO) 512x9 CMOS Memory 67C4501-25/35/50/65/80

#### **Features**

- Ram-based FIFO
- 512x9 organization
- Cycle times of 35/45/65/80/100 nanoseconds
- Asynchronous and simultaneous writes and reads
- Low power consumption
  - 60 mA max, -35/55/65/80
  - 70 mA max, -25
- Status flags Full, Half-Full, Empty
- Retransmit capability
- · Expandable in both width and depth
- Increased noise immunity for XI CMOS threshold
- Functional and pin-compatible with industry standard devices

# **General Description**

The 67C4501 is a RAM-based CMOS FIFO that is 512 words deep with 9-bit wide words. It is expandable to any width and/or depth to create much larger FIFOs.

This FIFO can accept data and output data asynchronously and simultaneously at data rates from 0 to 28.5 MHz. Status flags are provided to signify empty, full, and half-full conditions. The capability also exists to retransmit data from the FIFO.

Deep FIFOs such as the 67C4501 are useful in a wide range of applications. The ability to buffer large transfers of data and the rate adaption capabilities make the 67C4501 useful in communication, image processing, mass storage, DSP, and printing systems.

#### **Pin Names**

| PIN NAME | DESIGNATION                  |
|----------|------------------------------|
| w        | Write                        |
| R        | Read                         |
| RS       | Reset                        |
| FL/RT    | First Load/Retransmit        |
| Dχ       | Data In                      |
| QX       | Data Out                     |
| XI       | Expansion In                 |
| XO/HF    | Expansion Out/Half-Full Flag |
| FF       | Full Flag                    |
| EF       | Empty Flag                   |
| VCC      | Supply Voltage               |
| GND      | Ground                       |

# **Ordering Information**

| PART<br>NUMBER | DESCRIPTION            | PACK   | TEMP |
|----------------|------------------------|--------|------|
| 67C4501-25     | 512-word by 9-bit FIFO | N,J,NL | Com  |
| 67C4501-35     | 512-word by 9-bit FIFO | N,J,NL | Com  |
| 67C4501-50     | 512-word by 9-bit FIFO | N,J,NL | Com  |
| 67C4501-65     | 512-word by 9-bit FIFO | N,J,NL | Com  |
| 67C4501-80     | 512-word by 9-bit FIFO | N,J,NL | Com  |

# Pin Configurations





| Publication #  | Rev.      | Amendment |
|----------------|-----------|-----------|
| 10175          | C         | /0        |
| Issue Date: Au | gust 1988 |           |

# Deep First-In First-Out (FIFO) 512x9 CMOS Memory 67C4501-25/35/50/65/80

# **Absolute Maximum Ratings\***

| Supply voltage, VCC0.5 V to +7.0 V           | Supply |
|----------------------------------------------|--------|
| Input voltage0.5 V to V <sub>CC</sub> +0.5 V | Input  |
| Operating temperature                        | Opera  |
| Storage temperature55°C to +150°C            | Storag |
| Power dissipation                            | Power  |
| D.C. output current                          | D.C. o |

<sup>\*</sup>Note:

Stresses greater than those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions above those

indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods of time may affect reliability.

# DC Electrical Characteristics Commercial: V<sub>CC</sub> = 5 V ±10%, T<sub>A</sub> = 0°C to + 70°C

| SYMBOL                         | PARAMETER                                                          | TA= | 501-25<br>25 ns<br>MAX | TA = | 501-35<br>35 ns<br>MAX | TA= | 501-50<br>50 ns<br>MAX | TA= | 501-65<br>65 ns<br>MAX | TA = | 501-80<br>80 ns<br>MAX | UNITS |
|--------------------------------|--------------------------------------------------------------------|-----|------------------------|------|------------------------|-----|------------------------|-----|------------------------|------|------------------------|-------|
| ILI <sup>1</sup>               | Input leakage current (any input)                                  | -1  | 1                      | -1   | 1                      | -1  | 1                      | -1  | 1                      | -1   | 1                      | μΑ    |
| ILO <sup>2</sup>               | Output leakage current                                             | -10 | 10                     | -10  | 10                     | -10 | 10                     | -10 | 10                     | -10  | 10                     | μА    |
| VIH <sup>3</sup>               | Input high voltage (all inputs except XI)                          | 2.0 | _                      | 2.0  | _                      | 2.0 | _                      | 2.0 | _                      | 2.0  | _                      | V     |
| V <sub>IL</sub> <sup>3</sup>   | Input low voltage (all inputs except $\overline{XI}$ )             | -   | 8.0                    | _    | 0.8                    | -   | 0.8                    | _   | 0.8                    | _    | 8.0                    | V     |
| VIHXI <sup>3</sup>             | Input high voltage, XI                                             | 3.5 |                        | 3.5  | _                      | 3.5 | _                      | 3.5 | _                      | 3.5  | _                      | V     |
| V <sub>ILXI</sub> <sup>3</sup> | Input low voltage, XI                                              | _   | 1.5                    | _    | 1.5                    | _   | 1.5                    | _   | 1.5                    | _    | 1.5                    | V     |
| VOH                            | Output logic "1" voltage IOH = -2 mA                               | 2.4 | _                      | 2.4  | _                      | 2.4 | _                      | 2.4 | _                      | 2.4  | _                      | V     |
| VOL                            | Output logic "0" voltage IOL = 8 mA                                | _   | 0.4                    | _    | 0.4                    | _   | 0.4                    | _   | 0.4                    | _    | 0.4                    | V     |
| ICC1 <sup>4</sup>              | Average V <sub>CC</sub> power supply current                       | _   | 70                     | _    | 60                     | _   | 60                     | _   | 60                     | _    | 60                     | mA    |
| ¹CC2⁴                          | Average standby current<br>(R = W = RS = FL/RT = V <sub>IH</sub> ) | _   | 20                     | _    | 20                     | _   | 20                     | _   | 20                     | _    | 20                     | mA    |
| ICC3⁴                          | Power down current (all inputs = V <sub>CC</sub> -0.2 V)           | _   | 5                      | _    | 5                      | -   | 5                      | _   | 5                      | _    | 5                      | mA    |

#### Notes:

<sup>1.</sup> Measurements with GND  $\leq$   $V_{IN} \leq$   $V_{CC}$ .

<sup>2.</sup>  $\overline{R} \ge V_{IH}$ , GND  $\le V_{OUT} \le V_{CC}$ .

These are absolute voltage levels with respect to the ground pins on the device and include all overshoots due to system and/or tester noise.Do not attempt to test these values without suitable equipment.

<sup>4.</sup> ICC measurements are made with outputs open.

# AC Electrical Characteristics $V_{CC}$ = 5 V $\pm 10\%$ , $T_A$ = 0° C to + 70° C

| SYMBOL            | DESCRIPTION                           | FIG      | 67C4501-25<br>MIN MAX | 67C4501-35<br>MIN MAX | 67C4501-50<br>MIN MAX | 67C4501-65<br>MIN MAX | 67C4501-80<br>MIN MAX | UNITS |
|-------------------|---------------------------------------|----------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-------|
| Write and         | Flag Timing                           | <u> </u> |                       |                       |                       |                       |                       |       |
| twc               | Write cycle time                      | 3        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| twpw              | Write pulse width                     | 3        | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| twr               | Write recovery time                   | 3        | 10                    | 10                    | 15                    | 15                    | 20                    | ns    |
| tDS               | Data set-up time                      | 3, 9     | 15                    | 18                    | 30                    | 30                    | 40                    | ns    |
| tDH .             | Data hold time                        | 3, 9     | 0                     | 0                     | 5                     | 10                    | 10                    | ns    |
| tWFF              | Write LOW to full flag LOW            | 6, 9     | 25                    | 30                    | 45                    | 60                    | 60                    | ns    |
| twhe              | Write LOW to half-full flag LOW       | 5        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tWEF              | Write HIGH to empty flag HIGH         | 4, 8     | 25                    | 30                    | 45                    | 60                    | 60                    | ns    |
| twLZ <sup>1</sup> | Write pulse HIGH to data bus at LOW Z | 8        | 5                     | 10                    | 15                    | 15                    | 20                    | ns    |
|                   | Flag Timing                           |          |                       |                       |                       |                       |                       |       |
| tRC               | Read cycle time                       | 3        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tA                | Access time                           | 3,4,8,9  | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| t <sub>BB</sub>   | Read recovery time                    | 3        | 10                    | 10                    | 15                    | 15                    | 20                    | ns    |
| tRPW              | Read pulse width                      | 3        | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| tRLZ1             | Read pulse LOW to data bus at LOW Z   | 3        | 5                     | 5                     | 10                    | 10                    | 10                    | ns    |
| tDV               | Data valid from read pulse HIGH       | 3        | 5                     | 5                     | 5                     | 5                     | 5                     | ns    |
| tRHZ <sup>1</sup> | Read pulse HIGH to data bus at HIGH Z | 3        | 18                    | 20                    | 30                    | 30                    | 30                    | ns    |
| tRFF              | Read HIGH to full flag HIGH           | 6, 9     | 25                    | 30                    | 45                    | 60                    | 60                    | ns    |
| tRHF              | Read HIGH to half-full flag HIGH      | 5        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tREF              | Read LOW to empty flag LOW            | 4, 8     | 25                    | 30                    | 45                    | 60                    | 60                    | ns    |
| Reset Tim         | ning                                  |          |                       |                       |                       |                       |                       |       |
| tRSC              | Reset cycle time                      | 2        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tRS               | Reset pulse width                     | 2        | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| trss              | Reset set-up time                     | 2        | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| tRSR              | Reset recovery time                   | 2        | 10                    | 10                    | 15                    | 15                    | 20                    | ns    |
| tEFL              | Reset to empty flag LOW               | 2        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tHFH              | Reset to half-full flag HIGH          | 2        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tFFH              | Reset to full flag HIGH               | 2        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| Retransm          | it Timing                             |          |                       |                       |                       |                       |                       |       |
| trtC              | Retransmit cycle time                 | 7        | 35                    | 45                    | 65                    | 80                    | 100                   | ns    |
| tRT               | Retransmit pulse width                | 7        | 25                    | 35                    | 50                    | 65                    | 80                    | ns    |
| tRTR              | Retransmit recovery time              | 7        | 10                    | 10                    | 15                    | 15                    | 20                    | ns    |

Note

<sup>1.</sup> Characterized parameters.

### **Block Diagram**



Figure 1.

# **Functional Description**

The 67C4501 CMOS FIFO is designed around a 512x9 dual-port static RAM array. (See Figure 1.) RAM-based FIFOs store the data written into them in a sequential pattern.

The dual-port RAM array has dedicated write and read address pointers. The flag logic prevents illogical writes and reads from occurring. The Empty Flag prevents reading while empty, a data underflow condition. While the Full Flag prevents writing while full, a data overflow condition. Once data that has been stored at a given address is read, it can be overwritten.

Address pointers automatically overflow to address zero after reaching address 511. Thus the flag status of the FIFO is a function of the difference between the pointers, not their absolute value.

Resetting the FIFO simply initializes both address pointers to address zero. Pulsing Retransmit initializes the read address pointer to zero without affecting the write address pointer.

Expansion Logic is used when implementing a FIFO of a depth greater than that of the 67C4501. The write, read, data-in and data-out lines of the 67C4501 are connected in parallel, and the Expansion-Out  $(\overline{XO})$  and the Expansion-In  $(\overline{XI})$  lines are daisy-chained together. The write and read control circuits of the individual FIFOs are automatically enabled and disabled through the handshake between  $\overline{XO}$  and  $\overline{XI}$ .

# **Operational Description**

#### Resetting the FIFO

Upon power up, the FIFO must be initialized with a Reset cycle. (See Figure 2.) The states of  $\overline{\text{XI}}$  and  $\overline{\text{FL}}$  are used during the reset cycle to determine the FIFO's mode of operation, as shown in

Tables 1 and 2. For a valid reset cycle to occur, both the Read  $(\overline{R})$  and Write  $(\overline{W})$  signals must be HIGH tRSS prior to, and tRSR after, the rising edge of Reset  $(\overline{RS})$ . The reset cycle initializes the FIFO to an empty condition, signified by the Empty Flag  $(\overline{EF})$  being LOW (active), and both the Half-Full  $(\overline{HF})$  and Full Flag  $(\overline{FF})$  being HIGH (inactive).



Figure 2. Reset Timing

# Reset and Retransmit Truth Table — Single-Device Configuration/Width-Expansion Mode

|            |    | INPUT |    | INTERNA                | OUTPUTS                |                |                |                |
|------------|----|-------|----|------------------------|------------------------|----------------|----------------|----------------|
| MODE       | RS | FL/RT | Χī | READ POINTER           | WRITE POINTER          | EF             | FF             | HF             |
| Reset      | 0  | X     | 0  | Location zero          | Location zero          | 0              | 1              | 1              |
| Retransmit | 1  | 0     | 0  | Location zero          | Unchanged              | X <sup>1</sup> | X <sup>1</sup> | X <sup>1</sup> |
| Read/Write | 1  | 1     | 0  | Increment <sup>2</sup> | Increment <sup>2</sup> | х              | Х              | Х              |

- 1. Flags will change to show correct state according to write pointer.
- 2. Pointers will increment only if corresponding flag is HIGH at the beginning of the cycle.

Table 1.

# Reset and First Load Truth Table — Depth-Expansion/Compound-Expansion Mode

| MODE                    | INPUT |                |                 | INTERNA                | OUTPUTS                |    |   |
|-------------------------|-------|----------------|-----------------|------------------------|------------------------|----|---|
| MODE                    | RS    | RS FL/RT XI    |                 | READ POINTER           | ĒF                     | FF |   |
| Reset — first device    | 0     | 0              | X01             | Location zero          | Location zero          | 0  | 1 |
| Reset all other devices | 0     | 1              | X0 <sup>1</sup> | Location zero          | Location zero          | 0  | 1 |
| Read/Write              | 1     | X <sup>2</sup> | XO¹             | Increment <sup>3</sup> | Increment <sup>3</sup> | Х  | Х |

- 1.  $\overline{XI}$  is connected to  $\overline{XO}$  of previous device. See Figure 12.
- 2. Same as during Reset Cycle.
- 3. Pointers will increment only if corresponding flag is HIGH at the beginning of the cycle.

#### Table 2.

#### Writing Data to the FIFO

The HIGH state of the Full Flag ( $\overline{FF}$ ) indicates that the FIFO is capable of accepting data. The falling edge of Write ( $\overline{W}$ ) initiates a write cycle. (See Figure 3.) Data appearing at inputs D0-D8 tDS prior to, and tDH after, the rising edge of  $\overline{W}$  will be stored sequentially in the FIFO.

The LOW-to-HIGH transition of the Empty Flag  $(\overline{EF})$  occurs tWEF after the rising edge of  $\overline{W}$  during the first write cycle on an empty FIFO. (See Figure 4.) The Half-Full Flag  $(\overline{HF})$  will go

LOW tWHF after the falling edge of  $\overline{W}$  during the write operation which creates the half-full condition. (See Figure 5.)  $\overline{HF}$  will remain LOW, while the number of writes to the FIFO exceed the number of reads by 256 or more. The Half-Full Flag is not available in Depth-Expansion Mode. The Full Flag ( $\overline{FF}$ ) goes LOW tWFF after the falling edge of  $\overline{W}$  during the write cycle which creates a full condition. (See Figure 6.) A full condition exists when there have been 512 more write cycles than read cycles. The Full Flag being active prohibits any further write operations, thus preventing data overflow situations.



Figure 3. Asynchronous Write and Read Timing

### Reading Data from the FIFO

The HIGH state of the Empty Flag ( $\overline{\mathbb{EF}}$ ) indicates that the FIFO is ready to output data. The falling edge of Read ( $\overline{\mathbb{R}}$ ) initiates a read cycle. (See Figure 3.) Valid data appears on the outputs Q0-Q8 tA after the falling edge of  $\overline{\mathbb{R}}$ , and remains until tDV after the rising edge of  $\overline{\mathbb{R}}$ . Q0-Q8 return to a high impedance state when  $\overline{\mathbb{R}}$  is inactive, when the FIFO is empty, or when the FIFO is in Depth Expansion Mode but is not active.

The Full Flag ( $\overline{\text{FF}}$ ) will go HIGH tRFF after the rising edge of  $\overline{\text{R}}$  during the first read cycle following a full condition. (See Figure 6.) The Half-Full Flag ( $\overline{\text{HF}}$ ) will go HIGH tRHF after the rising edge of  $\overline{\text{R}}$  during the read operation, which eliminates the half-full condition. (See Figure 5.)  $\overline{\text{HF}}$  will remain HIGH, while the number of writes to the FIFO exceed the number of reads by 255 or less. The Half-Full Flag is not available in Depth-Expansion Mode. The HIGH-to-LOW transition of  $\overline{\text{EF}}$  occurs tREF after the falling edge of  $\overline{\text{R}}$  during the read cycle, which creates an empty condition. An empty condition exists when there have been an equal number of write cycles and read cycles. The Empty Flag being active prohibits any further read operations, thus preventing a data underflow situation.

#### Half-Full Flag

The Half-Full ( $\overline{\text{HF}}$ ) Flag will be active LOW only when the net balance of the words written into the FIFO exceeds the number of words read out by 256 or more. (See Figure 5.)

Care should be exercised in using the Half-Full Flag, because it is capable of producing arbitrarily short pulses. For example, if the FIFO contains 256 words, and Read and Write pulses are applied simultaneously, the HF flag may produce an arbitrarily short pulse, depending on the precise phase of Read and Write.

 $\overline{\text{HF}}$  will always settle to the correct state after the appropriate delay, tWHF or tRHF. This property of the Half-Full Flag is clearly a function of the dynamic relation between  $\overline{\text{W}}$  and  $\overline{\text{R}}$ . Generally, the use of level-sensitive, rather than edge-sensitive, status detection circuits will alleviate this hazard.



Figure 4. Empty Flag Timing



Note: Depending on the precise phase of  $\overline{W}$  and  $\overline{R}$ , the Half-Full Flag may appear as a pulse of arbitrarily short duration of either polarity when  $\overline{W}$  and  $\overline{R}$  are operating asynchronously near half-full.

Figure 5. Half-Full Flag Timing

#### Retransmit

The  $\overline{FL/RT}$  is used as the Retransmit ( $\overline{RT}$ ) input in Single Device Mode. The retransmit capability is intended for use when there are 512 or less writes between reset cycles.  $\overline{RT}$ , an active LOW going pulse of at least tRT in duration, initializes the internal read pointer to address zero and leaves the write pointer unaffected.  $\overline{W}$  and  $\overline{R}$  must both be HIGH during the retransmit cycle. The first write  $\overline{O}$  read cycle should not start until tRTR after the rising edge of  $\overline{RT}$ . The flags may change state during this cycle, but they will accurately reflect the new state of the FIFO tRTC after the falling edge of  $\overline{RT}$ . (See Figure 7 and Table 1.)

#### Single-Device/Width-Expansion Modes

Single-Device and Width-Expansion Modes are configured by grounding the Expansion-In (XI) input. (See Figures 10 & 11 and Table 1.) During these modes of operation, the Half-Full Flag and Retransmit features are available. The 67C4501 can be expanded in width to create FIFOs of word widths greater than 9 bits. In Width-Expansion Mode all of the control line inputs are common to all devices. (See Figure 11.) Creating composite status flags can pose two hazards. 1) OR-ing the flag outputs is fine for the HIGH-to-LOW transition, because the skew between devices is masked out. However, when the flags make a LOW-to-HIGH transition, a false composite flag is generated due to the skew between devices. 2) The converse is true when the flags are AND-ed: the LOW-to-HIGH transition is fine. and the HIGH-to-LOW generates a false flag. These two hazards can be avoided if one devices' flags are used as the flags for the expanded FIFO, and the write and read control circuitry is

designed to hold off sampling the flags until the worst case settling time (tWEF, tWHF, tWFF, tREF, tRHF, and tWFF) for each flag has elapsed.

#### Depth-Expansion Mode

Depth-Expansion Mode is configured during the Reset cycle. (See Figure 12 and Table 2.) Expansion Out ( $\overline{XO}$ ) of one device must be connected to Expansion In ( $\overline{XI}$ ) of the next device, with  $\overline{XO}$  of the last device being connected to  $\overline{XI}$  of the first device. The device that is to receive data first has its First Load ( $\overline{FL}$ ) input tied LOW, while all other devices must have this input HIGH. Write and read control is passed between devices using  $\overline{XO}$  and  $\overline{XI}$ . A LOW-going pulse on  $\overline{XO}$  occurs when the last physical location, address 511, of an active device is written to, and another LOW-going pulse occurs when the last physical location of an active device is read. Only one device is enabled for writes, and only one device is enabled for reads at any given time

When expanding in depth, a composite Full Flag must be created by OR-ing all the FF outputs together. Likewise, a composite Empty Flag is created by OR-ing all the FF outputs together. The Half-Full Flag and Retransmit functions are not available in Depth-Expansion Mode.

#### Compound Expansion

FIFOs of greater width and depth than the 67C4501 can be created by using both Width-Expansion Mode and Depth-Expansion Mode simultaneously. (See Figure 13.)



Figure 6. Full Flag Timing



Note: EF, HF and FF may change state during Retransmit as a result of the offset of the read and write pointers, but the flags will be valid at tRTC.

Figure 7. Retransmit Timing



Note:  $(t_{RPE} = t_{RPW}, t_{RFT} = t_{REF})$ 

Figure 8. Read Data Flow Through Mode



Note :  $(t_{WPF} = t_{WPW}, t_{WFT} = t_{WFF})$ 

Figure 9. Write Data Flow Through Mode