## 256/512/1K/2K/4K/8K x9 x2 Double Sync ${ }^{\text {TM }}$ FIFOs

## Features

- Double high speed, low power, first-in first-out (FIFO) memories
- Double 256 x 9 (CY7C4801)
- Double $512 \times 9$ (CY7C4811)
- Double 1K x 9 (CY7C4821)
- Double 2K x 9 (CY7C4831)
- Double 4K x 9 (CY7C4841)
- Double 8K x 9 (CY7C4851)
- Functionally equivalent to two CY7C4201/4211/4221/ 4231/4241/4251 FIFOs in a single package
- 0.65 micron CMOS for optimum speed/power
- High-speed $100-\mathrm{MHz}$ operation ( 10 ns read/write cycle times)
- Offers optimal combination of large capacity, high speed, design flexibility, and small footprint
- Fully asynchronous and simultaneous read and write operation
- Four status flags per device: Empty, Full, and programmable Almost Empty/Almost Full
- Low power - $\mathrm{l}_{\mathrm{CC} 1}=60 \mathrm{~mA}$
- Output Enable (OEA/OEB) pins
- Depth Expansion Capability
- Width Expansion Capability
- Space-saving 64-pin TQFP
- Pin compatible and functionally equivalent to IDT72801, 72811, 72821, 72831, 72841,72851


## Functional Description

The CY7C48X1 are Double high-speed, low-power, first-in first-out (FIFO) memories with clocked read and write interfaces. All are 9 bits wide and operate as two separate FIFOs. The CY7C48X1 are pin-compatible to IDT728X1. Programmable features include Almost Full/Almost Empty flags. These FIFOs provide solutions for a wide variety of data buffering needs, including high-speed data acquisition, multiprocessor interfaces, and communications buffering.

These FIFOs have two independent sets of 9-bit input and output ports that are controlled by separate clock and enable signals. The input port is controlled by a free-running clock (WCLKA,WCLKB) and two write-enable pins (WENA1, WENA2/LDA, WENB1, WENB2/LDB).
When ( $\overline{\text { WENA1 }}, \overline{W E N B 1}$ ) is LOW and (WENA2/ $\overline{\mathrm{LDA}}$, WENB2/LDB) is HIGH, data is written into the FIFO on the rising edge of the (WCLKA,WCLKB) signal. While (WENA1, WENA2/LDA, WENB1, WENB2/LDB) is held active, data is continually written into the FIFO on each WCLKA, WCLKB cycle. The output port is controlled in a similar manner by a free-running read clock (RCLKA, RCLKB) and two read-enable pins ((RENA1,$\overline{\text { RENB1 }})$, ( $\overline{\text { RENA2 }}, \overline{\text { RENB2 }}))$. In addition, the CY7C48X1 has output enable pins ( $\overline{\mathrm{OEA}}, \overline{\mathrm{OEB}}$ ) for each FIFO. The read (RCLKA, RCLKB) and write (WCLKA, WCLKB) clocks may be tied together for single-clock operation or the two clocks may be run independently for asynchronous read/write applications. Clock frequencies up to 100 MHz are achievable.

Depth expansion is possible using one enable input for system control, while the other enable is controlled by expansion logic to direct the flow of data.
The CY7C48X1 provides two sets of four different status pins: Empty, Full, Almost Empty, Almost Full. The Almost Empty/Almost Full flags are programmable to single word granularity. The programmable flags default to Empty+7 and Full-7.
The flags are synchronous, i.e., they change state relative to either the read clock (RCLKA,RCLKB) or the write clock (WCLKA,WCLKB). When entering or exiting the Empty and Almost Empty states, the flags are updated exclusively by the (RCLKA,RCLKB). The flags denoting Almost Full, and Full states are updated exclusively by (WCLKA,WCLKB) The synchronous flag architecture guarantees that the flags maintain their status for at least one cycle
All configurations are fabricated using an advanced $0.65 \mu$ N-Well CMOS technology. Input ESD protection is greater than 2001 V , and latch-up is prevented by the use of guard rings.


## Selection Guide

|  | 7C48X1-10 | 7C48X1-15 | 7C48X1-25 | 7C48X1-35 |
| :---: | :---: | :---: | :---: | :---: |
| Maximum Frequency (MHz) | 100 | 66.7 | 40 | 28.6 |
| Maximum Access Time (ns) | 8 | 10 | 15 | 20 |
| Minimum Cycle Time (ns) | 10 | 15 | 25 | 35 |
| Minimum Data or Enable Set-Up (ns) | 3 | 4 | 6 | 7 |
| Minimum Data or Enable Hold (ns) | 0.5 | 1 | 1 | 2 |
| Maximum Flag Delay (ns) | 8 | 10 | 15 | 20 |
| Active Power Supply $\quad$ Commercial | 60 | 60 | 60 | 60 |
| Current ( $\mathrm{l}_{\mathrm{CC1} 1}$ (mA) ${ }^{\text {a }}$ ( ${ }^{\text {a }}$ | 70 | 70 | 70 | 70 |


|  | CY7C4801 | CY7C4811 | CY7C4821 | CY7C4831 | CY7C4841 | CY7C4851 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Density | Double $256 \times 9$ | Double 512 $\times 9$ | Double 1K x 9 | Double 2K x 9 | Double 4K x 9 | Double 8K x9 |
| Package | $64-$ pin TQFP | 64 -pin TQFP | 64-pin TQFP | $64-$ pin TQFP | 64-pin TQFP | $64-$ pin TQFP |

## Maximum Ratings

(Above which the useful life may be impaired. For user guidelines, not tested.)
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

Ambient Temperature with
Power Applied $\qquad$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Supply Voltage to Ground Potential -0.5 V to +7.0 V

DC Voltage Applied to Outputs
in High Z State -0.5 V to +7.0 V
DC Input Voltage -0.5 V to +7.0 V
Output Current into Outputs (LOW) 20 mA
$\qquad$ >2001V (per MIL-STD-883, Method 3015) Latch-Up Current >200 mA

Operating Range ${ }^{[1]}$

| Range | Ambient <br> Temperature | V $_{\text {CC }}$ |
| :--- | :---: | :---: |$|$| $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ |
| :--- | :--- |
| Commercial | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Industrial ${ }^{[2]}$ | $5 \mathrm{~V} \pm 10 \%$ |

## Notes:

1. The Voltage on any input or I/O pin cannot exceed the power pin during power-up.
2. $\mathrm{T}_{\mathrm{A}}$ is the "instant on" case temperature.

CY7C4801/4811/4821 CY7C4831/4841/4851

## Pin Definitions

| Signal Name | Description | I/O | Description |
| :---: | :---: | :---: | :---: |
| $\mathrm{DA}_{0-8}$ | Data Inputs | 1 | Data Inputs for 9-bit bus |
| $\mathrm{DB}_{0-8}$ | Data Inputs | 1 | Data Inputs for 9-bit bus |
| $\mathrm{QA}_{0-8}$ | Data Outputs | O | Data Outputs for 9-bit bus |
| $\mathrm{QB}_{0-8}$ | Data Outputs | O | Data Outputs for 9-bit bus |
| $\frac{\overline{\text { WENA1 }}}{\overline{\text { WENB1 }}}$ | Write Enable 1 | 1 | WENA1 and WENB1 become the only write enables when the device is configured to have programmable flags. Data is written on a LOW-to-HIGH transition of WCLK when (WENA1,WENB1) is LOW and ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}}$ ) is HIGH. If the FIFO is configured to have two write enables, data is written on a LOW-to-HIGH transition of WCLK when (WENA1, WENB1) is LOW and (WENA2/LDA,WENB2/LDB) and ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}}$ ) are HIGH. |
|  | Write Enable 2 | 1 | If HIGH at reset, this pin operates as a second write enable. If LOW at reset, this pin |
| WENA2/LDA <br> Dual Mode Pin | Load | 1 | operates as a control to write or read the programmable flag offsets. (WENA1, WENB1) must be LOW and (WENA2/LDA, WENB2/LDB) must be HIGH to write data into the FIFO. Data will not be written into the FIFO if the ( $\overline{\text { FFA }}, \mathrm{FFB}$ ) is LOW. If the FIFO is configured to have programmable flags, (WENA2/LDA,WENB2/LDB) is held LOW to write or read the programmable flag offsets. |
| $\overline{\text { RENA1 }}$ $\frac{\text { RENA2 }}{\text { RENB1 }}$ $\frac{\text { RENB2 }}{}$ | Read Enable Inputs | 1 | Enables the device for Read operation. |
| WCLKA WCKLB | Write Clock | 1 | The rising edge clocks data into the FIFO when (产ENA1 $\overline{\text { WENB1 }}$ ) is LOW and (WENA2/LDA, WENB2/LDB) is HIGH and the FIFO is not Full. When (WENA2/LDA,WENB2/LDB) is asserted, WCLK writes data into the programmable flag-offset register. |
| RCLKA RCLKB | Read Clock | 1 | The rising edge clocks data out of the FIFO when ( $\overline{\text { RENA1 }}, \overline{\text { RENB1 }})$ and ( $\overline{\text { RENA2 }}, \overline{\text { RENB2 }})$ are LOW and the FIFO is not Empty. When (WENA2/LDA,WENB2/LDB) is LOW, (RCLKA,RCLKB) reads data out of the programmable flag-offset register. |
| $\overline{\text { EFA,EFB }}$ | Empty Flag | O | When ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}$ ) is LOW, the FIFO is empty. ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}$ ) is synchronized to (RCLKA,RCLKB). |
| $\overline{\text { FFA,FFB }}$ | Full Flag | O | When ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}})$ is LOW, the FIFO is full. ( $\overline{\mathrm{FFA}, \mathrm{FFB}}$ ) is synchronized to (WCLKA,WCLKB). |
| $\frac{\text { PAEA }}{\text { PAEB }}$ | Programmable Almost Empty | O | When ( $\overline{\mathrm{PAEA}}, \overline{\mathrm{PAEB}})$ is LOW, the FIFO is almost empty based on the almost empty offset value programmed into the FIFO. PAE is synchronized to RCLK. |
| $\overline{\overline{\mathrm{PAFA}}}$ | Programmable Almost Full | $\bigcirc$ | When ( $\overline{\text { PAFA }}, \overline{\mathrm{PAFB}}$ ) is LOW, the FIFO is almost full based on the almost full offset value programmed into the FIFO. PAF is synchronized to WCLK. |
| $\overline{\overline{\mathrm{RSA}}}$ | Reset | 1 | Resets device to empty condition. A reset is required before an initial read or write operation after power-up. |
| $\overline{\overline{\mathrm{OEA}}}$ | Output Enable | 1 | When ( $\overline{\mathrm{OEA}}, \overline{\mathrm{OEB}})$ is LOW, the FIFO's data outputs drive the bus to which they are connected. If ( $\overline{\mathrm{OEA}}, \overline{\mathrm{OEB}}$ ) is HIGH, the FIFO's outputs are in High Z (high-impedance) state. |

Electrical Characteristics Over the Operating Range ${ }^{[3]}$

| Parameter | Description | Test Conditions |  | 7C48X1-10 |  | 7C48X1-15 |  | 7C48X1-25 |  | 7C48X1-35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min} ., \\ & \mathrm{l}_{\mathrm{OH}}=-2.0 \mathrm{~mA} \end{aligned}$ |  | 2.4 |  | 2.4 |  | 2.4 |  | 2.4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Min.} ., \\ & \mathrm{l}_{\mathrm{OL}}=8.0 \mathrm{~mA} \end{aligned}$ |  |  | 0.4 |  | 0.4 |  | 0.4 |  | 0.4 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage |  |  | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage |  |  | -0.5 | 0.8 | -0.5 | 0.8 | -0.5 | 0.8 | -0.5 | 0.8 | V |
| $\mathrm{I}_{\mathrm{IX}}$ | Input Leakage Current | $\mathrm{V}_{\mathrm{CC}}=$ Max. |  | -10 | +10 | -10 | +10 | -10 | +10 | -10 | +10 | $\mu \mathrm{A}$ |
| $\mathrm{IOS}^{[4]}$ | Output Short Circuit Current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max} ., \\ & \mathrm{V}_{\mathrm{OUT}}=\mathrm{GND} \end{aligned}$ |  | -90 |  | -90 |  | -90 |  | -90 |  | mA |
| $\begin{array}{\|l} \mathrm{I}_{\mathrm{OZL}} \\ \mathrm{I}_{\mathrm{OZH}} \end{array}$ | Output OFF, High Z Current | $\begin{aligned} & \overline{\mathrm{OE}} \geq \mathrm{V}_{\mathrm{IH}}, \\ & \mathrm{~V}_{\mathrm{SS}}<\mathrm{V}_{\mathrm{O}}<\mathrm{V}_{\mathrm{C}} \end{aligned}$ |  | -10 | +10 | -10 | +10 | -10 | +10 | -10 | +10 | $\mu \mathrm{A}$ |
| $\mathrm{ICC1}^{[5]}$ | Active Power Supply |  | Com'l |  | 60 |  | 60 |  | 60 |  | 60 | mA |
|  |  |  | Ind |  | 70 |  | 70 |  | 70 |  | 70 | mA |

## Capacitance ${ }^{[6]}$

| Parameter | Description | Test Conditions | Max. | Unit |
| :--- | :--- | :--- | :--- | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$, | 10 | pF |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ | 10 | pF |

## AC Test Loads and Waveforms ${ }^{[7,8]}$



## ALL INPUT PULSES



48X1-5

Equivalent to:
THÉVENIN EQUIVALENT
OUTPUT $\quad 01.91 \mathrm{~V}$

## Notes:

3. See the last page of this specification for Group A subgroup testing information.
4. Test no more than one output at a time for not more than one second.
5. Outputs open. Tested at Frequency $=20 \mathrm{MHz}$.
6. Tested initially and after any design or process changes that may affect these parameters.
7. $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ for all AC parameters except for $\mathrm{t}_{\mathrm{OHz}}$.
8. $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ for $\mathrm{t}_{\mathrm{OHz}}$

Switching Characteristics Over the Operating Range

| Parameter | Description | 7C48X1-10 |  | 7C48X1-15 |  | 7C48X1-25 |  | 7C48X1-35 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{f}_{\mathrm{S}}$ | Clock Cycle Frequency |  | 100 |  | 66.7 |  | 40 |  | 28.6 | MHz |
| $\mathrm{t}_{\mathrm{A}}$ | Data Access Time | 2 | 8 | 2 | 10 | 2 | 15 | 2 | 20 | ns |
| $\mathrm{t}_{\text {CLK }}$ | Clock Cycle Time | 10 |  | 15 |  | 25 |  | 35 |  | ns |
| $\mathrm{t}_{\text {CLKH }}$ | Clock HIGH Time | 4.5 |  | 6 |  | 10 |  | 14 |  | ns |
| $\mathrm{t}_{\text {CLKL }}$ | Clock LOW Time | 4.5 |  | 6 |  | 10 |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Set-Up Time | 3.5 |  | 4 |  | 6 |  | 7 |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 0.5 |  | 1 |  | 1 |  | 2 |  | ns |
| $\mathrm{t}_{\text {ENS }}$ | Enable Set-Up Time | 3.5 |  | 4 |  | 6 |  | 7 |  | ns |
| $\mathrm{t}_{\text {ENH }}$ | Enable Hold Time | 0.5 |  | 1 |  | 1 |  | 2 |  | ns |
| $\mathrm{t}_{\text {RS }}$ | Reset Pulse Width ${ }^{[9]}$ | 10 |  | 15 |  | 25 |  | 35 |  | ns |
| $t_{\text {RSS }}$ | Reset Set-Up Time | 8 |  | 10 |  | 15 |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{RSR}}$ | Reset Recovery Time | 8 |  | 10 |  | 15 |  | 20 |  | ns |
| $\mathrm{t}_{\text {RSF }}$ | Reset to Flag and Output Time |  | 10 |  | 15 |  | 25 |  | 35 | ns |
| $\mathrm{t}_{\text {OLZ }}$ | Output Enable to Output in Low Z ${ }^{[10]}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{OE}}$ | Output Enable to Output Valid | 3 | 7 | 3 | 8 | 3 | 12 | 3 | 15 | ns |
| $\mathrm{t}_{\mathrm{OHZ}}$ | Output Enable to Output in High Z ${ }^{[10]}$ | 3 | 7 | 3 | 8 | 3 | 12 | 3 | 15 | ns |
| $\mathrm{t}_{\text {WFF }}$ | Write Clock to Full Flag |  | 8 |  | 10 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {REF }}$ | Read Clock to Empty Flag |  | 8 |  | 10 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {PAF }}$ | Clock to Programmable Almost-Full Flag |  | 8 |  | 10 |  | 15 |  | 20 | ns |
| $\mathrm{t}_{\text {PAE }}$ | Clock to Programmable Almost-Full Flag |  | 8 |  | 10 |  | 15 |  | 20 | ns |
| ${ }^{\text {tSKEW1 }}$ | Skew Time between Read Clock and Write Clock for Empty Flag and Full Flag | 5 |  | 6 |  | 10 |  | 12 |  | ns |
| $\mathrm{t}_{\text {SKEW2 }}$ | Skew Time between Read Clock and Write Clock for Almost-Empty Flag and Almost-Full Flag | 15 |  | 15 |  | 18 |  | 20 |  | ns |

Notes:
9. Pulse widths less than minimum values are not allowed.
10. Values guaranteed by design, not currently tested.

## Switching Waveforms



## Notes:

11. $t_{\text {SKEW } 1}$ is the minimum time between a rising (RCLKA,RCLKB) edge and a rising (WCLKA,WCLKB) edge to guarantee that (FFA,FFB) will go HIGH during the current clock cycle. If the time between the rising edge of (RCLKA,RCLKB) and the rising edge of (WCLKA,WCLKB) is less than tsKEW1, then (FFA,FFB) may not change state until the next (WCLKA,WCLKB) rising edge.
12. $\mathrm{t}_{\text {SKEW } 1}$ is the minimum time between a rising (WCLKA,WCLKB) edge and a rising (RCLKA,RCLKB) edge to guarantee that $(\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}})$ will go HIGH during the current clock cycle. It the time between the rising edge of (WCLKA,WCLKB) and the rising edge of RCLK is less than tSKEW1, then ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}})$ may not change state until the next (RCLKA,RCLKB) rising edge.

Switching Waveforms (continued)


## Notes:

13. The clocks (RCLKA,RCLKB, WCLKA,WCLKB) can be free-running during reset
14. After reset, the outputs will be LOW if $(\overline{O E A}, \mathrm{OEB})=0$ and three-state if $(\overline{O E A}, \mathrm{OEB})=1$.
15. Holding (WENA2/LDA,WENB2/LDB) HIGH during reset will make the pin act as a second enable pin. Holding(WENA2/LDA,WENB2/LDB) LOW during reset will make the pin act as a load enable for the programmable flag offset registers.

Switching Waveforms (continued)

First Data Word Latency after Reset with Simultaneous Read and Write


Notes:
16. When $t_{S K E W} \geq$ minimum specification, $\mathrm{t}_{\text {FRL }}$ (maximum) $=\mathrm{t}_{\mathrm{CL}}+\mathrm{t}_{\text {SKEW }}$. When $\mathrm{t}_{\text {SKEW }}<$ minimum specification, $\mathrm{t}_{\text {FRL }}$ (maximum) $=$ either $^{2}{ }^{*} \mathrm{t}_{\text {CLK }}+\mathrm{t}_{\text {SKEW }}$ or $\mathrm{t}_{\text {CLK }}+\mathrm{t}_{\text {SKEW }} 1$. The Latency Timing applies only at the Empty Boundary (EFA, EFB= LOW).
17. The first word is available the cycle after (EFA, EFB) goes HIGH, always.

Switching Waveforms (continued)

## Empty Flag Timing



Switching Waveforms (continued)


Switching Waveforms (continued)

Programmable Almost Empty Flag Timing


48X1-13

## Notes:

18. $t_{S K E W}$ is the minimum time between a rising (WCLKA,WCLKB) and a rising ( $R C L K A, R C L K B$ ) edge for ( (PAEA, PAEB) to change state during that clock cycle. If the time between the edge of (WCLKA,WCLKB) and the rising (RCLKA, RCLKB) is less than tSKEW2, then (PAEA, PAEB) may not change state until the next RCLK.
19. $($ PAEA, PAEB $)$ offset $=n$.
20. If a read is preformed on this rising edge of the read clock, there will be Empty $+(n-1)$ words in the FIFO when $(\overline{\text { PAEA }} \overline{\text { PAEB }})$ goes LOW.
21. If a write is performed on this rising edge of the write clock, there will be Full - $(m-1)$ words of the FIFO when (PAFA,PAFB) goes LOW.
22. (PAFA,PAFB) offset $=m$.
23. 256-m words in FIFO for CY7C4801, 512-m words for CY7C4811, 1024-m words for CY7C4821, 2048-m words for CY7C4831, 4096-m words for CY7C4841, 8192-m words for CY7C4851.
24. $t_{S K E W 2}$ is the minimum time between a rising (RCLKA,RCLKB) edge and a rising (WCLKA,WCLKB) edge for (PAFA,PAFB) to change during that clock cycle. If the time between the rising edge of (RCLKA,RCLKB) and the rising edge of (WCLKA,WCLKB) is less than tsKEW2, then (PAFA,PAFB) may not change state until the next (WCLKA,WCLKB).

CY7C4801/4811/4821
CY7C4831/4841/4851

Switching Waveforms (continued)

## Write Programmable Registers



Read Programmable Registers


## Architecture

The CY7C48X1 functions as two independent FIFOs in a single package, each with its own separate set of controls. The device consists of two arrays of 256 to 8 K words of 9 bits each (implemented by a dual-port array of SRAM cells), two read pointers, two write pointers, control signals (RCLKA, RCLKB, WCLKA, WCLKB, RENA1, RENB1, RENA2, RENB2, WENA1, WENB1, WENA2, WENB2, $\overline{\mathrm{RSA}}, \overline{\mathrm{RSB}}$ ), and flags ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}, \overline{\mathrm{PAEA}}, \overline{\mathrm{PAEB}}$, PAFA, PAFB, FFA, FFB).

## Resetting the FIFO

Upon power-up, the FIFO must be reset with a Reset ( $\overline{\mathrm{RSA}}$, RSB) cycle. This causes the FIFO to enter the Empty condition signified by (EFA,EFB) being LOW. All data outputs $\left(\mathrm{QA}_{0-8}, \mathrm{QB}_{0-8}\right)$ go LOW $t_{\text {RSF }}$ after the rising edge of RSA, RSB. In order for the FIFO to reset to its default state, a falling edge must occur on (RSA, $\overline{\mathrm{RSB}}$ ) and the user must not read or write while (RSA, RSB) is LOW. All flags are guaranteed to be valid $\mathrm{t}_{\mathrm{RSF}}$ after $\left.\overline{(\mathrm{RSA}}, \overline{\mathrm{RSB}}\right)$ is taken LOW.

## FIFO Operation

When the (WENA1, $\overline{\text { WENB1 }) ~ s i g n a l ~ i s ~ a c t i v e ~ L O W ~ a n d ~}$ (WENA2,WENB2) is active HIGH, data present on the ( $\mathrm{DA}_{0-8}, \mathrm{DB}_{0-8}$ ) pins is written into the FIFO on each rising edge (WCLKA,WCLKB) of the (WCLKA,WCLKB) signal. Similarly, when the (RENA1, RENB1) and (RENA2,RENB2) signals are active LOW, data in the FIFO memory will be presented on the $\left(\mathrm{QA}_{0-8}, \mathrm{QB}_{0-8}\right)$ outputs. New data will be presented on each rising edge of (RCLKA,RCLKB) while (RENA1,RENB1) and (RENA2,RENB2) are active. (RENA1, RENB1) and (RENA2, RENB2) must set up teNS $^{\text {R be- }}$ fore (RCLKA,RCLKB) for it to be a valid read function. (WENA1,WENB1) and (WENA2,WENB2) must occur $t_{\text {ENS }}$ before (WCLKA,WCLKB) for it to be a valid write function.
An output enable ( $\overline{\mathrm{OEA}}, \overline{\mathrm{OEB}}$ ) pin is provided to three-state the $\left(\mathrm{QA}_{0-8} \mathrm{QB}_{0-8}\right)$ outputs when (OEA, OEB) is asserted. When (OEA, OEB) is enabled (LOW), data in the output register will be available to the $\left(\mathrm{QA}_{0-8}, \mathrm{QB}_{0-8}\right)$ outputs after tOE.
The FIFO contains overflow circuitry to disallow additional writes when the FIFO is full, and underflow circuitry to disallow additional reads when the FIFO is empty. An empty FIFO maintains the data of the last valid read on its $\left(\mathrm{QA}_{0-8}, \mathrm{QB}_{0-8}\right)$ outputs even after additional reads occur.
Write Enable $1 \overline{(W E N A 1}, \overline{W E N B 1})$ - If the FIFO is configured for programmable flags, Write Enable 1 (WENA1,WENB1) is the only write enable control pin. In this configuration, when Write Enable 1 (WENA1, WENB1) is LOW, data can be loaded into the input register and RAM array on the LOW-to-HIGH
transition of every write clock (WCLKA,WCLKB). Data is stored is the RAM array sequentially and independently of any on-going read operation.
Write Enable 2/Load (WENA2/LDA, WENB2/LDB) - This is a dual-purpose pin. The FIFO is configured at Reset to have programmable flags or to have two write enables, which allows for depth expansion. If Write Enable 2/Load (WENA2/LDA, WENB2 $/ \overline{\mathrm{LDB}}$ ) is set active HIGH at Reset ( $\overline{\mathrm{RSA}}, \overline{\mathrm{RSB}}=\mathrm{LOW}$ ), this pin operates as a second write enable pin.
If the FIFO is configured to have two write enables, when Write Enable 1 (WENA1,WENB1) is LOW and Write Enable 2/Load (WENA2/ㄴDA, WENB2 $\overline{\mathrm{LDB}}$ ) is HIGH, data can be loaded into the input register and RAM array on the LOW-to-HIGH transition of every write clock (WCLKA,WCLKB). Data is stored in the RAM array sequentially and independently of any on-going read operation.

## Programming

When (WENA2/(LDA, WENB2/LDB) is held LOW during Reset, this pin is the load (LDA, LDB) enable for flag offset programming. In this configuration, (WENA2/LDA, WENB2/LDB) can be used to access the four 8-bit offset registers contained in the CY7C48X1 for writing or reading data to these registers.
When the device is configured for programmable flags and both (WENA2/LDA, WENB2/LDB) and (WENA1,WENB1) are LOW, the first LOW-to-HIGH transition of (WCLKA,WCLKB) writes data from the data inputs to the empty offset least significant bit (LSB) register. The second, third, and fourth LOW-to-HIGH transitions of (WCLKA,WCLKB) store data in the empty offset most significant bit (MSB) register, full offset LSB register, and full offset MSB register, respectively, when (WENA2/LDA, WENB2/LDB) and (WENA1,WENB1) are LOW. The fifth LOW-to-HIGH transition of (WCLKA,WCLKB) while (WENA2/LDA, WENB2/LDB) and (WENA1, WENB1) are LOW writes data to the empty LSB register again. Figure 1 shows the register sizes and default values for the various device types.
It is not necessary to write to all the offset registers at one time. A subset of the offset registers can be written; then by bringing the (WENA2/LDA, WENB2/LDB) input HIGH, the FIFO is returned to normal read and write operation. The next time (WENA2/LDA, WENB2/LDB) is brought LOW, a write operation stores data in the next offset register in sequence.

The contents of the offset registers can be read to the data outputs when (WENA2/(LDA, WENB2/ $\overline{\mathrm{LDB}}$ ) is LOW and both (RENA1,RENB1) and (RENA2,RENB2) are LOW. LOW-to-HIGH transitions of (RCLKA,RCLKB) read register contents to the data outputs. Writes and reads should not be preformed simultaneously on the offset registers.

$512 \times 9 \times 2$

$4 \mathrm{~K} \times 9 \times 2$

$1 \mathrm{~K} \times 9 \times 2$

$8 \mathrm{~K} \times 9 \times 2$


Figure 1. Offset Register Location and Default Values.

## Programmable Flag (PAEA, PAEB, PAFA,PAFB) Operation

Whether the flag offset registers are programmed as described in Table 1 or the default values are used, the programmable almost-empty flag (PAEA,PAEB) and programmable almost-full flag (PAFA,PAFB) states are determined by their corresponding offset registers and the difference between the read and write pointers.

Table 1. Writing the Offset Registers.

| LD | WEN | WCLK ${ }^{[25]}$ | Selection |  |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | $\smile$ | Empty Offset (LSB) <br> Empty Offset (MSB) <br> Full Offset (LSB) <br> Full Offset (MSB) | $\longleftrightarrow$ |
| 0 | 1 | $\smile$ | No Operation |  |
| 1 | 0 | $\smile$ | Write Into FIFO |  |
| 1 | 1 | $\smile$ | No Operation |  |

Notes:
25. The same selection sequence applies to reading form the registers. $\overline{\mathrm{REN} 1}$ and $\overline{\mathrm{REN} 2}$ are enabled and a read is performed on the LOW- to-HIGH transition of RCLK.

## Flag Operation

The CY7C48X1 devices provide four flag pins to indicate the condition of the FIFO contents. Empty, Full, ( $\overline{\mathrm{PAEA}}, \overline{\mathrm{PAEB}})$, and ( $\overline{\text { PAFA }}, \overline{\mathrm{PAFB}}$ ) are synchronous.

## Full Flag

The Full Flag ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}})$ will go LOW when the device is full. Write operations are inhibited whenever ( $\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}}$ ) is LOW regardless of the state of (WENA1, WENB1) and (WENA2/ㄴDA,WENB2/LDB).
$(\overline{\mathrm{FFA}}, \overline{\mathrm{FFB}})$ is synchronized to (WCLKA,WCLKB), i.e., it is exclusively updated by each rising edge of (WCLKA,WCLKB).

## Empty Flag

The Empty Flag ( $\overline{\mathrm{EFA}}, \overline{\mathrm{EFB}}$ ) will go LOW when the device is empty. Read operations are inhibited whenever (EFA, EFB) is LOW, regardless of the state of (RENA1, RENB1) and (RENA2, RENB2. ( $\mathrm{EFA}, \mathrm{EFB}$ ) is synchronized to (RCLKA,RCLKB), i.e., it is exclusively Full Flag.

Table 2. Status Flags.

| Number of Words in FIFO |  |  | $\overline{\mathrm{FF}}$ | $\overline{\text { PAF }}$ | $\overline{\text { PAE }}$ | $\overline{\mathrm{EF}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CY7C4801 | CY7C4811 | CY7C4821 |  |  |  |  |
| 0 | 0 | 0 | H | H | L | L |
| 1 to $\mathrm{n}^{[26]}$ | 1 to $\mathrm{n}^{[26]}$ | 1 to $\mathrm{n}^{[26]}$ | H | H | L | H |
| ( $\mathrm{n}+1)$ to (256-(m+1)) | ( $\mathrm{n}+1)$ to (512-(m+1)) | ( $\mathrm{n}+1)$ to (1024-(m+1)) | H | H | H | H |
| $(256-\mathrm{m})^{[27]}$ to 255 | $(512-\mathrm{m})^{[27]}$ to 511 | $(1024-\mathrm{m})^{[27]}$ to 1023 | H | L | H | H |
| 256 | 512 | 1024 | L | L | H | H |


| Number of Words in FIFO |  |  | $\overline{\mathrm{FF}}$ | $\overline{\text { PAF }}$ | $\overline{\text { PAE }}$ | $\overline{E F}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CY7C4831 | CY7C4841 | CY7C4851 |  |  |  |  |
| 0 | 0 | 0 | H | H | L | L |
| 1 to $\mathrm{n}^{[26]}$ | 1 to $\mathrm{n}^{[26]}$ | 1 to $\mathrm{n}^{[26]}$ | H | H | L | H |
| $(\mathrm{n}+1)$ to $(2048-(\mathrm{m}+1)$ ) | $(\mathrm{n}+1)$ to (4096-(m+1)) | $(\mathrm{n}+1)$ to (8192-(m+1)) | H | H | H | H |
| $(2048-\mathrm{m})^{[27]}$ to 2047 | $(4096-\mathrm{m})^{[27]}$ to 4095 | $(8192-\mathrm{m})^{[27]}$ to 8191 | H | L | H | H |
| 2048 | 4096 | 8192 | L | L | H | H |

Notes:
26. $\mathrm{n}=$ Empty Offset ( $\mathrm{n}=7$ default value).
27. $m=$ Full Offset ( $m=7$ default value).

## Single Device Configuration

When FIFO $A(B)$ is in a Single Device Configuration, the Read Enable 2 RENA2(RENB2) control input can be grounded (see Figure 2). in this configuration, the Write Enable2/Load
(WENA2//LDA,WENB2/ $\overline{\mathrm{LDB}}$ ) pin is set LOW at Reset so that the pin operates as a control to load and read the programmable flag offsets.


Figure 2. Block Diagram of $256 \times 9,512 \times 9,1024 \times 9,2048 \times 9,4096 \times 9,8192 \times 9$ Double Sync FIFO Used in a Single Device Configuration.

CY7C4801/4811/4821
CY7C4831/4841/4851

## Width Expansion Configuration

Word width may be increased simply by connecting the corresponding input control signals of FIFOs A and B. A composite flag should be created for each of the end-point status flags $\overline{\overline{E F A}}$ and $\overline{\mathrm{EFB}}$, also $\overline{\mathrm{FFA}}$ and $\overline{\mathrm{FFB}}$. The partial status flags $\overline{\text { PAEA, }}, \overline{\text { PAFB }}, \overline{\text { PAFA, }}, \overline{\text { PAFB }}$ can be detected from any one device. Figure 3 demonstrates an 18-bit word width using the two FIFOs contained in one CY7C4801/4811/4821/4831/4841 /4851. Any word width can be attained by adding additional CY7C4801/4811/4821/4831/4841/4851s.

When the CY7C4801/4811/4821/4831/4841/4851 is in a Width Expansion Configuration, the Read Enable 2 (RENA2 and RENB2) control unputs can be grounded (see Figure 3). In this configuration, the Write Enable $2 /$ Load (WENA2/ $\overline{\mathrm{LDA}}, \mathrm{WENB} 2 / \overline{\mathrm{LDB}}$ ) pins are set LOW at Reset so that the pin operates as a control to load and read the programmable flag offsets.


Figure 3. Block Diagram of two FIFOs contained in one CY7C4801/4811/4821/4831/4841/4851 configured for an 18-bit width-expansion.

## Bidirectional Configuration

The two FIFOs of the CY7C4801/4811/4821/4831/4841/4851 can be used to buffer data flow in two directions. In the example that follows, processor A can write data to processor B via

FIFO A, and, in turn, processor B can write processor A via FIFO B.


Figure 4. Block Diagram of Bidirectional Configuration.

## Depth Expansion

CY7C4801/4811/4821/4831/4841/4851can be adapted to applications that require greater than 256/512/1024/2048/4096/ 8192 words. The existence of dual enable pins on the read and write ports allow depth expansion. The Write Enable 2/Load (WENA2, WENB2) pins are used as a second write enables in a depth expansion configuration, thus the Programmable flags are set to the default values. Depth expansion is possible by using one enable input for system control while the other enable input is controlled by expansion logic to direct the flow of
data. a typical application would have the expansion logic alternate data access from one device to the next in a sequential manner. The CY7C4801/4811/4821/4831/4841/ 4851 operates in the Depth Expansion configuration when the following conditions are met:

1. WENA $2 / \overline{\mathrm{LDA}}$ and WENB2/ $/ \overline{\mathrm{LDB}}$ pins are held HIGH during Reset so that these pins operate as second Write Enables.
2. External logic is used to control the flow of data.

## Ordering Information

Double 256x9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4801-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4801-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4801-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4801-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4801-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4801-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4801-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4801-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

Double 512x9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4811-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4811-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4811-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4811-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4811-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4811-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4811-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4811-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

Double 1Kx9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4821-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4821-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4821-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4821-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4821-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4821-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4821-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4821-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

Ordering Information (continued)
Double 2Kx9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4831-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4831-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4831-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4831-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4831-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4831-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4831-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4831-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

Double 4Kx9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4841-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4841-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4841-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4841-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4841-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4841-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4841-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4841-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

## Double 8Kx9 FIFO

| Speed <br> (ns) | Ordering Code | Package <br> Name | Package <br> Type | Operating <br> Range |
| :---: | :--- | :---: | :--- | :--- |
| 10 | CY7C4851-10AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4851-10AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 15 | CY7C4851-15AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4851-15AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 25 | CY7C4851-25AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4851-25AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |
| 35 | CY7C4851-35AC | A65 | 64-Lead Thin Quad Flatpack | Commercial |
|  | CY7C4851-35AI | A65 | 64-Lead Thin Quad Flatpack | Industrial |

## Package Diagram

64-Lead Thin Plastic Quad Flat Pack A65


DIMENSIUNS IN MILLIMETERS


LEAD CDPLANARITY 0.100 MAX.


| Document Title: CY7C4801/4811/4821/CY7C4831.4841/4851 256/512/1K/2K/4K/8K x9 x2 Double Sync (TM) Fifos |  |  |  |
| :--- | :---: | :--- | :---: | :--- |
| Document Number: 38-06005 |  |  |  |

