> CMOS SyncFIFOTM
> $256 \times 18,512 \times 18,1,024 \times 18$, $2,048 \times 18$ and $4,096 \times 18$

IDT72205LB

## FEATURES:

- $256 \times 18$-bit organization array (IDT72205LB)
- $512 \times 18$-bit organization array (IDT72215LB)
- $1,024 \times 18$-bit organization array (IDT72225LB)
- $2,048 \times 18$-bit organization array (IDT72235LB)
- 4,096 x 18-bit organization array (IDT72245LB)
- 10 ns read/write cycle time
- Empty and Full flags signal FIFO status
- Easily expandable in depth and width
- Asynchronous or coincident read and write clocks
- Programmable Almost-Empty and Almost-Full flags with default settings
- Half-Full flag capability
- Dual-Port zero fall-through time architecture
- Output enable puts output data bus in high-impedance state
- High-performance submicron CMOS technology
- Available in a 64-lead thin quad flatpack (TQFP/STQFP) and plastic leaded chip carrier (PLCC)
- Industrial temperature range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ is available


## DESCRIPTION:

The IDT72205LB/72215LB/72225LB/72235LB/72245LB are very high-speed, low-power First-In, First-Out (FIFO) memories with clocked read and write controls. These FIFOs
are applicable for a wide variety of data buffering needs, such as optical disk controllers, Local Area Networks (LANs), and interprocessor communication.

These FIFOs have 18-bit input and output ports. The input port is controlled by a free-running clock (WCLK), and an input enable pin ( $\overline{\mathrm{WEN}})$. Data is read into the synchronous FIFO on every clock when $\overline{W E N}$ is asserted. The output port is controlled by another clock pin (RCLK) and another enable pin ( $\overline{\mathrm{REN}}$ ). The read clock can be tied to the write clock for single clock operation or the two clocks can run asynchronous of one another for dual-clock operation. An Output Enable pin $(\overline{\mathrm{OE}})$ is provided on the read port for three-state control of the output.

The synchronous FIFOs have two fixed flags, Empty ( $\overline{\mathrm{EF}}$ ) and Full ( $\overline{\mathrm{FF}}$ ), and two programmable flags, Almost-Empty ( $\overline{\mathrm{PAE}})$ and Almost-Full ( $\overline{\mathrm{PAF}}$ ). The offset loading of the programmable flags is controlled by a simple state machine, and is initiated by asserting the Load pin ( $\overline{\mathrm{LD}})$. A Half-Full flag ( $\overline{\mathrm{HF}}$ ) is available when the FIFO is used in a single device configuration.

These devices are depth expandable using a Daisy-Chain technique. The XI and $\overline{\mathrm{XO}}$ pins are used to expand the FIFOs. In depth expansion configuration, $\overline{\mathrm{FL}}$ is grounded on the first device and set to HIGH for all other devices in the Daisy Chain.

The IDT72205LB/72215LB/72225LB/72235LB/72245LB is fabricated using IDT's high-speed submicron CMOS technology.

## FUNCTIONAL BLOCK DIAGRAM



SyncFIFO is a trademark and the IDT logo is a registered trademark of Integrated Device Technology, Inc

## PIN CONFIGURATIONS



## PIN DESCRIPTION

| Symbol | Name | I/O | Description |
| :---: | :---: | :---: | :---: |
| D0-D17 | Data Inputs | 1 | Data inputs for a 18 -bit bus. |
| $\overline{\mathrm{RS}}$ | Reset | 1 | When $\overline{\mathrm{RS}}$ is set LOW, internal read and write pointers are set to the first location of the RAM array, $\overline{\mathrm{FF}}$ and $\overline{\text { PAF }}$ go HIGH, and $\overline{\text { PAE }}$ and $\overline{\mathrm{EF}}$ go LOW. A reset is required before an initial WRITE after power-up. |
| WCLK | Write Clock | 1 | When $\overline{\text { WEN }}$ is LOW, data is written into the FIFO on a LOW-to-HIGH transition of WCLK, if the FIFO is not full. |
| $\overline{\text { WEN }}$ | Write Enable | 1 | When $\overline{\text { WEN }}$ is LOW and $\overline{\mathrm{LD}}$ is HIGH, data is written into the FIFO on every LOW-to-HIGH transition of WCLK. When WEN is HIGH, the FIFO holds the previous data. Data will not be written into the FIFO if the FF is LOW. |
| RCLK | Read Clock | 1 | When $\overline{\text { REN }}$ is LOW, data is read from the FIFO on a LOW-to-HIGH transition of RCLK, if the FIFO is not empty. |
| REN | Read Enable | 1 | When $\overline{\text { REN }}$ is LOW and $\overline{\mathrm{LD}}$ is HIGH, data is read from the FIFO on every LOW-to-HIGH transition of RCLK. When REN is HIGH, the output register holds the previous data. Data will not be read from the FIFO if the EF is LOW. |
| $\overline{\mathrm{OE}}$ | Output Enable | 1 | When $\overline{O E}$ is LOW, the data output bus is active. If $\overline{\mathrm{OE}}$ is HIGH, the output data bus will be in a high-impedance state. |
| $\overline{\text { LD }}$ | Load | 1 | When $\overline{\mathrm{LD}}$ is LOW, data on the inputs D0-D11 is written to the offset and depth registers on the LOW-to-HIGH transition of the WCLK, when WEN is LOW. When LD is LOW, data on the outputs Q0-Q11 is read from the offset and depth registers on the LOW-toHIGH transition of the RCLK, when REN is LOW. |
| $\overline{\text { FL }}$ | First Load | 1 | In the single device or width expansion configuration, FL is grounded. In the depth expansion configuration, FL is grounded on the first device (first load device) and set to HIGH for all other devices in the Daisy Chain. |
| $\overline{\text { WXI }}$ | Write Expansion | 1 | In the single device or width expansion configuration, $\overline{\mathrm{WXI}}$ is grounded. In the depth expansion configuration, $\overline{W X I}$ is connected to $\overline{W X O}$ (Write Expansion Out) of the previous device. |
| RXI | Read Expansion | 1 | In the single device or width expansion configuration, $\overline{\mathrm{RXI}}$ is grounded. In the depth expansion configuration, $\overline{\mathrm{RXI}}$ is connected to $\overline{\mathrm{RXO}}$ (Read Expansion Out) of the previous device. |
| $\overline{\text { FF }}$ | Full Flag | 0 | When $\overline{F F}$ is LOW, the FIFO is full and further data writes into the input are inhibited. When $\overline{\text { FF }}$ is HIGH, the FIFO is not full. $\overline{\text { FF }}$ is synchronized to WCLK. |
| EF | Empty Flag | $\bigcirc$ | When $\overline{E F}$ is LOW, the FIFO is empty and further data reads from the output are inhibited. When EF is HIGH, the FIFO is not empty. $\overline{\mathrm{EF}}$ is synchronized to RCLK. |
| $\overline{\text { PAE }}$ | Programmable <br> Almost-Empty Flag | $\bigcirc$ | When $\overline{\text { PAE }}$ is LOW, the FIFO is almost empty based on the offset programmed into the FIFO. The default offset at reset is 31 from empty for IDT72205LB, 63 from empty for IDT72215LB, and 127 from empty for IDT72225LB/72235LB/72245LB. |
| $\overline{\text { PAF }}$ | Programmable Almost-Full Flag | $\bigcirc$ | When $\overline{\text { PAF }}$ is LOW, the FIFO is almost full based on the offset programmed into the FIFO. The default offset at reset is 31 from full for IDT72205LB, 63 from full for IDT72215LB, and 127 from full for IDT72225LB/72235LB/72245LB. |
| $\overline{\mathrm{W} \times \mathrm{O}} / \overline{\mathrm{HF}}$ | Write Expansion Out/Half-Full Flag | 0 | In the single device or width expansion configuration, the device is more than half full when $\overline{\mathrm{HF}}$ is LOW. In the depth expansion configuration, a pulse is sent from $\overline{\mathrm{WXO}}$ to $\overline{\text { WXI }}$ of the next device when the last location in the FIFO is written. |
| $\overline{\mathrm{RXO}}$ | Read Expansion Out | 0 | In the depth expansion configuration, a pulse is sent from $\overline{\mathrm{RXO}}$ to $\overline{\mathrm{RXI}}$ of the next device when the last location in the FIFO is read. |
| Q0-Q17 | Data Outputs | $\bigcirc$ | Data outputs for a 18 -bit bus. |
| Vcc | Power |  | +5V power supply pins. |
| GND | Ground |  | Eight ground pins for the PLCC and seven pins for the TQFP/STQFP. |

## ABSOLUTE MAXIMUM RATINGS

| Symbol | Rating | Com'I \& Ind'I | Unit |
| :--- | :--- | :---: | :---: |
| VTERM | Terminal Voltage <br> with respect to GND | -0.5 to +7.0 | V |
| TSTG | Storage <br> Temperature | -55 to +125 | ${ }^{\circ} \mathrm{C}$ |
| IOUT | DC Output Current | -50 to +50 | mA |

1. 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 may affect reliability.

## RECOMMENDED DC

OPERATING CONDITIONS

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VcC | Supply Voltage <br> Com'//lnd'l | 4.5 | 5.0 | 5.5 | V |
| GND | Supply Voltage | 0 | 0 | 0 | V |
| VIH | Input High Voltage <br> Com'//lnd'l | 2.0 | - | - | V |
| $\mathrm{VILI}^{(1)}$ | Input Low Voltage <br> Com'//lnd'l | - | - | 0.8 | V |
| TA | Operating Temperature <br> Commercial | 0 | - | 70 | ${ }^{\circ} \mathrm{C}$ |
| TA | Operating Temperature <br> Industrial | -40 | - | 85 | ${ }^{\circ} \mathrm{C}$ |
| NOTE: |  |  |  |  |  |

1. 1.5 V undershoots are allowed for 10 ns once per cycle.

## DC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Industrial: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | IDT72205LBIDT72215LBIDT72225LBIDT72235LBIDT72245LBCommercial and Industrial ${ }^{(1)}$tcLK $=10,15,25 \mathrm{~ns}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| ILI ${ }^{(2)}$ | Input Leakage Current (any input) | -1 | - | 1 | $\mu \mathrm{A}$ |
| $\mathrm{ILO}^{(3)}$ | Output Leakage Current | -10 | - | 10 | $\mu \mathrm{A}$ |
| VOH | Output Logic "1" Voltage, $\mathrm{IOH}=-2 \mathrm{~mA}$ | 2.4 | - | - | V |
| VoL | Output Logic "0" Voltage, IOL = 8 mA | - | - | 0.4 | V |
| ICC1 ${ }^{(4,5,6)}$ | Active Power Supply Current | - | - | 60 | mA |
| ICC2 $^{(4,7)}$ | Standby Current | - | - | 5 | mA |

NOTES:

1. Industrial temperature range product for the 15 ns and the 25 ns speed grade is available as a standard device.
2. Measurements with $0.4 \leq \mathrm{VIN} \leq \mathrm{Vcc}$.
3. $\overline{\mathrm{OE}} \geq \mathrm{V} \mathrm{IH}, 0.4 \leq$ Vout $\leq \mathrm{Vcc}$.
4. Tested with outputs open (lout $=0$ ).
5. RCLK and WCLK toggle at 20 MHZ and data inputs switch at 10 MHz .
6. For the $72205 / 72215 / 72225$ the typical $\mathrm{ICC} 1=1.81+1.12^{\star} \mathrm{fS}+0.02^{*} \mathrm{CL}^{*} \mathrm{fs}($ in mA );
for the $72235 / 72245$ the typical ICC1 $=2.85+1.30 * f s+0.02^{*} \mathrm{CL}^{*} \mathrm{fs}$ (in mA ).
These equations are valid under the following conditions:
$\mathrm{Vcc}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, fs = WCLK frequency = RCLK frequency (in MHz , using TTL levels), data switching at fs/2, CL=capacitive load (in pF).
7. All Inputs $=\mathrm{Vcc}-0.2 \mathrm{~V}$ or GND +0.2 V , except RCLK and WCLK, which toggle at 20 MHz .

CAPACITANCE ( $\mathrm{T} A=+25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ )

| Symbol | Parameter ${ }^{(1)}$ | Conditions | Max. | Unit |
| :--- | :--- | :--- | :--- | :--- |
| CIN $^{(2)}$ | Input <br> Capacitance | VIN $=0 \mathrm{~V}$ | 10 | pF |
| Cout $^{(1,2)}$ | Output <br> Capacitance | VOUT = 0V | 10 | pF |

## NOTES:

2766 tbl 05

1. With output deselected, $(\overline{\mathrm{OE}} \geq \mathrm{V} \mathrm{IH})$.
2. Characterized values, not currently tested.

## AC TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | :---: |
| Input Rise/Fall Times | 3 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Reference Levels | 1.5 V |
| Output Load | See Figure 1 |
| 2766 tbl 06 |  |

## AC ELECTRICAL CHARACTERISTICS

(Commercial: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; Industrial: $\mathrm{VcC}=5 \mathrm{~V} \pm 10 \%, \mathrm{TA}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Commercial <br> 72205LB10 <br> 72215LB10 <br> 72225LB10 <br> 72235LB10 <br> 72245LB10 |  | Com'l \& Ind'l ${ }^{(1)}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 72205LB15 <br> 72215LB15 <br> 72225LB15 <br> 72235LB15 <br> 72245LB15 |  | $\begin{aligned} & \text { 72205LB25 } \\ & \text { 72215LB25 } \\ & \text { 72225LB25 } \\ & \text { 72235LB25 } \\ & \text { 72245LB25 } \\ & \hline \end{aligned}$ |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Unit |
| fs | Clock Cycle Frequency | - | 100 | - | 66.7 | - | 40 | MHz |
| tA | Data Access Time | 2 | 6.5 | 2 | 10 | 2 | 15 | ns |
| tclk | Clock Cycle Time | 10 | - | 15 | - | 25 | - | ns |
| tclek | Clock HIGH Time | 4.5 | - | 6 | - | 10 | - | ns |
| tclkL | Clock LOW Time | 4.5 | - | 6 | - | 10 | - | ns |
| tDs | Data Set-up Time | 3 | - | 4 | - | 6 | - | ns |
| tDH | Data Hold Time | 0 | - | 1 | - | 1 | - | ns |
| tens | Enable Set-up Time | 3 | - | 4 | - | 6 | - | ns |
| tenh | Enable Hold Time | 0 | - | 1 | - | 1 | - | ns |
| trs | Reset Pulse Width ${ }^{(2)}$ | 10 | - | 15 | - | 25 | - | ns |
| trss | Reset Set-up Time | 8 | - | 10 | - | 15 | - | ns |
| trsR | Reset Recovery Time | 8 | - | 10 | - | 15 | - | ns |
| tRSF | Reset to Flag and Output Time | - | 15 | - | 20 | - | 25 | ns |
| tolz | Output Enable to Output in Low-Z ${ }^{(3)}$ | 0 | - | 0 | - | 0 | - | ns |
| toe | Output Enable to Output Valid | 3 | 6 | 3 | 8 | 3 | 12 | ns |
| tohz | Output Enable to Output in High-Z ${ }^{(3)}$ | 3 | 6 | 3 | 8 | 3 | 12 | ns |
| twfF | Write Clock to Full Flag | - | 6.5 | - | 10 | - | 15 | ns |
| tref | Read Clock to Empty Flag | - | 6.5 | - | 10 | - | 15 | ns |
| tpaf | Clock to Programmable Almost-Full Flag | - | 17 | - | 24 | - | 26 | ns |
| tpae | Clock to Programmable Almost-Empty Flag | - | 17 | - | 24 | - | 26 | ns |
| thF | Clock to Half-Full Flag | - | 17 | - | 24 | - | 26 | ns |
| txo | Clock to Expansion Out | - | 6.5 | - | 10 | - | 15 | ns |
| txı | Expansion In Pulse Width | 3 | - | 6.5 | - | 10 | - | ns |
| txis | Expansion In Set-Up Time | 3.5 | - | 5 | - | 10 | - | ns |
| tskew1 | Skew time between Read Clock \& Write Clock for Full Flag | 5 | - | 6 | - | 10 | - | ns |
| tskew2 | Skew time between Read Clock \& Write Clock for Empty Flag | 5 | - | 6 | - | 10 | - | ns |

## NOTES:

2766 tbl 07

1. Industrial temperature range is available as standard product for the 15 ns
and the 25 ns speed grade.
2. Pulse widths less than minimum values are not allowed.
3. Values guaranteed by design, not currently tested.


Figure 1. Output Load

* Includes jig and scope capacitances.


## SIGNAL DESCRIPTIONS:

## INPUTS:

## DATA IN (D0 - D17)

Data inputs for 18-bit wide data.

## CONTROLS:

## RESET ( $\overline{\mathrm{RS}})$

Reset is accomplished whenever the Reset ( $\overline{\mathrm{RS}}$ ) input is taken to a LOW state. During reset, both internal read and write pointers are set to the first location. A reset is required after power-up before a write operation can take place. The Full Flag ( $\overline{\mathrm{FF}}$ ), Half-Full Flag (HF) and Programmable AlmostFull Flag ( $\overline{\mathrm{PAF}}$ ) will be reset to HIGH after trsf. The Empty Flag ( $\overline{\mathrm{EF}}$ ) and Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will be reset to LOW after tRSF. During reset, the output register is initialized to all zeros and the offset registers are initialized to their default values.

## WRITE CLOCK (WCLK)

A write cycle is initiated on the LOW-to-HIGH transition of the write clock (WCLK). Data set-up and hold times must be met with respect to the LOW-to-HIGH transition of the write clock (WCLK).

The write and read clocks can be asynchronous or coincident.

## WRITE ENABLE ( $\overline{\mathrm{WEN}}$ )

When the $\overline{\text { WEN }}$ input is LOW and $\overline{\mathrm{LD}}$ input is HIGH, data may be loaded into the FIFO RAM array on the rising edge of every WCLK cycle if the device is not full. Data is stored in the RAM array sequentially and independently of any ongoing read operation.

When $\overline{\text { WEN }}$ is HIGH, no new data is written in the RAM array on each WCLK cycle.

To prevent data overflow, $\overline{F F}$ will go LOW, inhibiting further write operations. Upon the completion of a valid read cycle, $\overline{\text { FF }}$ will go HIGH allowing a write to occur. The FF flag is updated on the rising edge of WCLK. WEN is ignored when the FIFO is full.

## READ CLOCK (RCLK)

Data can be read on the outputs on the LOW-to-HIGH transition of the read clock (RCLK), when Output Enable ( $\overline{\mathrm{OE}}$ ) is set LOW.

The write and read clocks can be asynchronous or coincident.

## READ ENABLE ( $\overline{\operatorname{REN}}$ )

When Read Enable is LOW and $\overline{\mathrm{LD}}$ input is HIGH, data is loaded from the RAM array into the output register on the rising edge of every RCLK cycle if the device is not empty.

When the REN input is HIGH, the output register holds the previous data and no new data is loaded into the output register. The data outputs Qo-Qn maintain the previous data value.

Every word accessed at Qn, including the first word written to an empty FIFO, must be requested using $\overline{R E N}$. When the last word has been read from the FIFO, the Empty Flag (EF) will go LOW, inhibiting further read operations. REN is ignored when the FIFO is empty. Once a write is performed, EF will go HIGH allowing a read to occur. The EF flag is updated on the rising edge of RCLK.

## OUTPUT ENABLE ( $\overline{\mathrm{OE}})$

When Output Enable $(\overline{\mathrm{OE}})$ is enabled (LOW), the parallel output buffers receive data from the output register. When $\overline{O E}$ is disabled (HIGH), the Q output data bus is in a highimpedance state.

## LOAD ( $\overline{\mathrm{LD}}$ )

The IDT72205LB/72215LB/72225LB/72235LB/72245LB devices contain two 12-bit offset registers with data on the inputs, or read on the outputs. When the Load ( $\overline{\mathrm{LD}})$ pin is set LOW and WEN is set LOW, data on the inputs DO-D11 is written into the Empty offset register on the first LOW-to-HIGH transition of the write clock (WCLK). When the $\overline{\mathrm{LD}}$ pin and (WEN) are held LOW then data is written into the Full offset register on the second LOW-to-HIGH transition of the write clock (WCLK). The third transition of the write clock (WCLK) again writes to the Empty offset register.

However, writing all offset registers does not have to occur at one time. One or two offset registers can be written and then by bringing the LD pin HIGH, the FIFO is returned to normal read/write operation. When the LD pin is set LOW, and WEN is LOW, the next offset register in sequence is written.

| $\overline{\text { LD }}$ | $\overline{\text { WEN }}$ | WCLK | Selection |
| :--- | :---: | :---: | :--- |
| 0 | 0 | $\boxed{\square}$ | Writing to offset registers: <br> Empty Offset <br> Full Offset |
| 0 | 1 | $\square$ | No Operation |
| 1 | 0 | $\square$ | Write Into FIFO |
| 1 | 1 | $\boxed{\square}$ | No Operation |

NOTE:
2766 tbl 08

1. The same selection sequence applies to reading from the registers. $\overline{\text { REN }}$ is enabled and read is performed on the LOW-to-HIGH transition of RCLK.

Figure 2. Write Offset Register

| 17 | 11 | 0 |
| :---: | :---: | :---: |
|  | EMPTY OFFSET REGISTER |  |
|  | $\begin{gathered} \text { DEFAULT VALUE } \\ 001 \mathrm{FH}(72205) \text { 003FH (72215): } \\ 007 \mathrm{FH}(72225 / 72235 / 72245) \end{gathered}$ |  |
| 17 |  | 0 |
|  | FULL OFFSET REGISTER |  |
|  | ```DEFAULT VALUE 001FH (72205) 003FH (72215): 007FH (72225/72235/72245)``` |  |

NOTE:
2766 drw 05

1. Any bits of the offset register not being programmed should be set to zero.

Figure 3. Offset Register Location and Default Values

When the $\overline{\mathrm{LD}}$ pin is LOW and $\overline{W E N}$ is HIGH , the WCLK input is disabled; then a signal at this input can neither increment the write offset register pointer, nor execute a write.

The contents of the offset registers can be read on the output lines when the $\overline{L D}$ pin is set LOW and $\overline{R E N}$ is set LOW; then, data can be read on the LOW-to-HIGH transition of the read clock (RCLK). The act of reading the control registers employs a dedicated read offset register pointer. (The read and write pointers operate independently).

A read and a write should not be performed simultaneously to the offset registers.

## FIRST LOAD ( $\overline{\mathrm{FL}})$

FL is grounded to indicate operation in the Single Device or Width Expansion mode. In the Depth Expansion configuration, $\overline{F L}$ is grounded to indicate it is the first device loaded and is set to HIGH for all other devices in the Daisy Chain. (See Operating Configurations for further details.)

## WRITE EXPANSION INPUT ( $\overline{\mathrm{WXI}})$

This is a dual purpose pin. $\overline{\text { WXI }}$ is grounded to indicate operation in the Single Device or Width Expansion mode. WXI is connected to Write Expansion Out (WXO) of the previous device in the Daisy Chain Depth Expansion mode.

## READ EXPANSION INPUT ( $\overline{\mathrm{RXI}})$

This is a dual purpose pin. $\overline{\mathrm{RXI}}$ is grounded to indicate operation in the Single Device or Width Expansion mode. $\overline{\mathrm{RXI}}$ is connected to Read Expansion Out ( $\overline{\mathrm{RXO}}$ ) of the previous device in the Daisy Chain Depth Expansion mode.

## OUTPUTS:

FULL FLAG (FF)
When the FIFO is full, $\overline{F F}$ will go LOW, inhibiting further write operations. When $\overline{F F}$ is HIGH, the FIFO is not full. If no reads are performed after a reset, $\overline{\mathrm{FF}}$ will go LOW after D writes to the FIFO. $D=256$ writes for the IDT72205LB, 512 for the IDT72215LB, 1,024 for the IDT72225LB, 2,048 for the IDT72235LB and 4,096 for the IDT72245LB.

The FF is updated on the LOW-to-HIGH transition of the write clock (WCLK).

## EMPTY FLAG (EF)

When the FIFO is empty, $\overline{\mathrm{EF}}$ will go LOW, inhibiting further read operations. When $\overline{E F}$ is HIGH, the FIFO is not empty.

The EF is updated on the LOW-to-HIGH transition of the read clock (RCLK).

## PROGRAMMABLE ALMOST-FULL FLAG ( $\overline{\text { PAF }})$

The Programmable Almost-Full Flag ( $\overline{\mathrm{PAF}}$ ) will go LOW when FIFO reaches the Almost-Full condition. If no reads are performed after Reset ( $\overline{\mathrm{RS}}$ ), the $\overline{\text { PAF }}$ will go LOW after ( $256-\mathrm{m}$ ) writes for the IDT72205LB, (512-m) writes for the IDT72215LB, ( $1,024-m$ ) writes for the IDT72225LB, ( $2,048-\mathrm{m}$ ) writes for the IDT72235LB and (4,096-m) writes for the IDT72245LB. The offset " $m$ " is defined in the FULL offset register.

If there is no Full offset specified, the $\overline{\text { PAF }}$ will be LOW when the device is 31 away from completely full for IDT72205LB, 63 away from completely full for IDT72215LB, and 127 away from completely full for IDT72225LB/72235LB/72245LB.

The $\overline{\text { PAF }}$ is asserted LOW on the LOW-to-HIGH transition of the write clock (WCLK). $\overline{\text { PAF }}$ is reset to HIGH on the LOW-to-HIGH transition of the read clock (RCLK). Thus $\overline{\text { PAF }}$ is asynchronous.

## PROGRAMMABLE ALMOST-EMPTY FLAG (PAE)

The Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will go LOW when the read pointer is " $n+1$ " locations less than the write pointer. The offset " n " is defined in the EMPTY offset register.

If there is no Empty offset specified, the Programmable Almost-Empty Flag ( $\overline{\mathrm{PAE}}$ ) will be LOW when the device is 31 away from completely empty for IDT72205LB, 63 away from completely empty for IDT72215LB, and 127 away from completely empty for IDT72225LB/72235LB/72245LB.

The $\overline{\text { PAE }}$ is asserted LOW on the LOW-to-HIGH transition of the read clock (RCLK). $\overline{\text { PAE }}$ is reset to HIGH on the LOW-to-HIGH transition of the write clock (WCLK). Thus PAE is asynchronous.

## WRITE EXPANSION OUT/HALF-FULL FLAG ( $\overline{\mathrm{WXO}} / \overline{\mathrm{HF}}$ )

This is a dual-purpose output. In the Single Device and Width Expansion mode, when Write Expansion In ( $\overline{\mathrm{WXI}})$ and Read Expansion In $(\overline{\mathrm{RXI}})$ are grounded, this output acts as an indication of a half-full memory.

## TABLEI-STATUS FLAGS

| Number of Words in FIFO Memory |  |  |  |  | FF | $\overline{\text { PAF }}$ | $\overline{\text { HF }}$ | PAE | $\overline{\text { EF }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 72205 | 72215 | 72225 | 72235 | 72245 |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | H | H | H | L | L |
| 1 to $\mathrm{n}^{(1)}$ | 1 to $\mathrm{n}^{(1)}$ | 1 to $\mathrm{n}^{(1)}$ | 1 to $\mathrm{n}^{(1)}$ | 1 to $\mathrm{n}^{(1)}$ | H | H | H | L | H |
| $(\mathrm{n}+1)$ to 128 | $(\mathrm{n}+1)$ to 256 | $(\mathrm{n}+1)$ to 512 | $(\mathrm{n}+1)$ to 1,024 | $(\mathrm{n}+1)$ to 2,048 | H | H | H | H | H |
| 129 to (256-(m+1)) | 257 to (512-(m+1)) | 513 to (1,024-(m+1)) | 1,025 to (2,048-(m+1)) | 2,049 to (4,096-(m+1)) | H | H | L | H | H |
| $(256-m)^{(2)}$ to 255 | $(512-m)^{(2)}$ to 511 | $(1,024-m)^{(2)}$ to 1,023 | $(2,048-\mathrm{m})^{(2)}$ to 2,047 | $(4,096-m)^{(2)}$ to 4,095 | H | L | L | H | H |
| 256 | 512 | 1,024 | 2,048 | 4,096 | L | L | L | H | H |

## NOTES:

1. $\mathrm{n}=$ Empty Offset (Default Values: IDT72205 $\mathrm{n}=31$, IDT72215 $\mathrm{n}=63$, IDT72225/72235/72245 $\mathrm{n}=127$ )
2. $m=$ Full Offset (Default Values : IDT72205 $n=31$, IDT72215 $n=63$, IDT72225/72235/72245 $n=127$ )

After half of the memory is filled, and at the LOW-to-HIGH transition of the next write cycle, the Half-Full Flag goes LOW and will remain set until the difference between the write pointer and read pointer is less than or equal to one half of the total memory of the device. The Half-Full Flag ( $\overline{\mathrm{HF}}$ ) is then rese to HIGH by the LOW-to-HIGH transition of the read clock (RCLK). The $\overline{\mathrm{HF}}$ is asynchronous.

In the Daisy Chain Depth Expansion mode, $\overline{\mathrm{WXI}}$ is connected to WXO of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse when the previous device writes to the last location of memory.

## READ EXPANSION OUT ( $\overline{\mathrm{RXO}})$

In the Daisy Chain Depth Expansion configuration, Read Expansion In $(\overline{\mathrm{RXI}})$ is connected to Read Expansion Out ( $\overline{\mathrm{RXO}})$ of the previous device. This output acts as a signal to the next device in the Daisy Chain by providing a pulse when the previous device reads from the last location of memory.

## DATA OUTPUTS (Q0-Q17)

Q0-Q17 are data outputs for 18-bit wide data.


## NOTES:

1. After reset, the outputs will be LOW if $\overline{\mathrm{OE}}=0$ and tri-state if $\overline{\mathrm{OE}}=1$.
2. The clocks (RCLK, WCLK) can be free-running during reset.

Figure 4. Reset Timing ${ }^{(2)}$


## NOTES:

1. tskEw 1 is the minimum time between a rising RCLK edge and a rising WCLK edge to guarantee that $\overline{\mathrm{FF}}$ will go HIGH during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEW1, then $\overline{F F}$ may not change state until the next WCLK edge.

Figure 5. Write Cycle Timing


## NOTE:

1. tskewz is the minimum time between a rising WCLK edge and a rising RCLK edge to guarantee that $\overline{\mathrm{EF}}$ will go HIGH during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than tskEw2, then $\overline{E F}$ may not change state until the next RCLK edge.

Figure 6. Read Cycle Timing


## NOTES:

1. When tskew2 minimum specification, tFRL (maximum) $=$ tCLK + tSkEW2. When tSKEW2 $<$ minimum specification, tFRL (maximum) $=$ either $2^{*}$ tcLk + tSkEW2 or tcLK + tskewz. The Latency Timing applies only at the Empty Boundary ( $\overline{\mathrm{EF}}=\mathrm{LOW}$ ).
2. The first word is available the cycle after $\overline{E F}$ goes HIGH, always.

Figure 7. First Data Word Latency after Reset with Simultaneous Read and Write


## NOTE:

1. tSKEW1 is the minimum time between a rising RCLK edge and a rising WCLK edge to guarantee that $\overline{F F}$ will go HIGH during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than tsKEW1, then $\overline{F F}$ may not change state until the next WCLK edge.

Figure 8. Full Flag Timing


NOTE:

1. When tskew2 minimum specification, tFRL (maximum) $=$ tcLK + tskew 2 . When tskew $2<$ minimum specification, tFRL (maximum) $=$ either 2 * tCLK + tSkEW 2 , or tcLK + tskEw2. The Latency Timing apply only at the Empty Boundary ( $\overline{\mathrm{EF}}=\mathrm{LOW}$ ).

Figure 9. Empty Flag Timing


Figure 10. Write Programmable Registers


Figure 11. Read Programmable Registers


Figure 12. Programmable Almost-Empty Flag Timing

 $1,024-m+1$ for the IDT72225, $2,048-m+1$ for the IDT72235 and $4,096-m+1$ for the IDT72245.
2. 256 - m words in IDT72205, 512 - m words in IDT72215, 1,024-m words in IDT72225, 2,048 - m words in IDT72235 and 4,096-m words in IDT72245.

Figure 13. Programmable Almost-Full Flag Timing


Figure 14. Half-Full Flag Timing


NOTE:

1. Write to Last Physical Location.

Figure 15. Write Expansion Out Timing


NOTE:

1. Read from Last Physical Location.

Figure 16. Read Expansion Out Timing


Figure 17. Write Expansion In Timing


Figure 18. Read Expansion In Timing

## OPERATING CONFIGURATIONS

## SINGLE DEVICE CONFIGURATION

A single IDT72205LB/72215LB/72225LB/72235LB/72245LB may be used when the application requirements are for 256/

512/1,024/2,048/4,096 words or less. These FIFOs are in a single Device Configuration when the First Load ( $\overline{\mathrm{FL}}$ ), Write Expansion $\operatorname{In}(\overline{\mathrm{WXI}})$ and Read Expansion $\ln (\overline{\mathrm{RXI}})$ control inputs are grounded (Figure 19).


Figure 19. Block Diagram of Single $256 \times 18,512 \times 18,1,024 \times 18,2,048 \times 18,4,096 \times 18$ Synchronous FIFO

## WIDTH EXPANSION CONFIGURATION

Word width may be increased simply by connecting together the control signals of multiple devices. Status flags can be detected from any one device. The exceptions are the Empty Flag and Full Flag. Because of variations in skew between RCLK and WCLK, it is possible for flag assertion and deassertion to vary by one cycle between FIFOs. To avoid problems the
user must create composite flags by ANDing the Empty Flags of every FIFO, and separately ANDing all Full Flags. Figure 20 demonstrates a36-word width by using two IDT72205B/72215B/ 72225B/72235B/72245Bs. Any word width can be attained by adding additional IDT72205B/72215B/72225B/72235B/ 72245Bs. Please see the Application Note AN-83.


NOTE:

1. Do not connect any output control signals directly together.

Figure 20. Block Diagram of $256 \times 36,512 \times 36,1,024 \times 36,2,048 \times 36,4,096 \times 36$ Synchronous FIFO Memory Used in a Width Expansion Configuration

## DEPTH EXPANSION CONFIGURATION (WITH PROGRAMMABLE FLAGS)

These devices can easily be adapted to applications requiring more than 256/512/1,024/2,048/4,096 words of buffering. Figure 21 shows Depth Expansion using three IDT72205LB/ $72215 \mathrm{LB} / 72225 \mathrm{LB} / 72235 \mathrm{LB} / 72245 \mathrm{LBs}$. Maximum depth is limited only by signal loading. Follow these steps:

1. The first device must be designated by grounding the First Load ( $\overline{\mathrm{FL}}$ ) control input.
2. All other devices must have $\overline{\mathrm{FL}}$ in the HIGH state.
3. The Write Expansion Out ( $\overline{\mathrm{WXO}})$ pin of each device must be tied to the Write Expansion In (WXI) pin of
the next device. See Figure 21.
4. The Read Expansion Out ( $\overline{\mathrm{RXO}})$ pin of each device must be tied to the Read Expansion In ( $\overline{\mathrm{RXI}})$ pin of the next device. See Figure 21.
5. All Load ( $\overline{\mathrm{LD}})$ pins are tied together.
6. The Half-Full Flag ( $\overline{\mathrm{HF}})$ is not available in this Depth Expansion Configuration.
7. $\overline{\mathrm{EF}}, \overline{\mathrm{FF}}, \overline{\mathrm{PAE}}$, and $\overline{\mathrm{PAF}}$ are created with composite flags by ORing together every respective flags for monitoring. The composite $\overline{\text { PAE }}$ and PAF flags are not precise.


Figure 21. Block Diagram of $768 \times 18,1,536 \times 18,3,072 \times 18,6,144 \times 18,12,288 \times 18$ Synchronous FIFO Memory With Programmable Flags used in Depth Expansion Configuration

## ORDERING INFORMATION



## NOTE:

1. Industrial temperature range is available as standard product for the 15 ns and the 25 ns speed grade.
