3.3 VOLT DUAL CMOS SyncFIFO™ DUAL 256 X 9, DUAL 512 X 9, DUAL 1,024 X 9, DUAL 2,048 X 9, DUAL 4.096 X 9 and DUAL 8.192 X 9 IDT72V801 IDT72V811 IDT72V821 IDT72V831 IDT72V841 IDT72V851 # **FEATURES:** - The IDT72V801 is equivalent to two IDT72V201 256 x 9 FIFOs - The IDT72V811 is equivalent to two IDT72V211 512 x 9 FIFOs - The IDT72V821 is equivalent to two IDT72V221 1,024 x 9 FIFOs - The IDT72V831 is equivalent to two IDT72V231 2,048 x 9 FIFOs - The IDT72V841 is equivalent to two IDT72V241 4.096 x 9 FIFOs - The IDT72V851 is equivalent to two IDT72V251 8,192 x 9 FIFOs - Offers optimal combination of large capacity, high speed, design flexibility and small footprint - Ideal for prioritization, bidirectional, and width expansion applications - 10 ns read/write cycle time - 5V input tolerant - Separate control lines and data lines for each FIFO - Separate Empty, Full, programmable Almost-Empty and Almost-Full flags for each FIFO - · Enable puts output data lines in high-impedance state - Space-saving 64-pin plastic Thin Quad Flat Pack (TQFP/ STQFP) - Industrial temperature range (-40°C to +85°C) is available #### **DESCRIPTION:** The IDT72V801/72V811/72V821/72V831/72V841/72V851/72V851 are dual synchronous (clocked) FIFOs. The device is functionally equivalent to two IDT72V201/72V211/72V221/72V231/72V241/72V251 FIFOs in a single package with all associated control, data, and flag lines assigned to separate pins. Each of the two FIFOs (designated FIFO A and FIFO B) contained in the IDT72V801/72V811/72V821/72V831/72V841/72V851 has a 9-bit input data port (DA0 - DA8, DB0 - DB8) and a 9-bit output data port (QA0 - QA8, QB0 - QB8). Each input port is controlled by a free-running clock (WCLKA, WCLKB), and two Write Enable pins ( $\overline{\text{WENA1}}$ , WENA2, $\overline{\text{WENB1}}$ , WENB2). Data is written into each of the two arrays on every rising clock edge of the Write Clock (WCLKA, WCLKB) when the appropriate Write Enable pins are asserted. The output port of each FIFO bank is controlled by its associated clock pin (RCLKA, RCLKB) and two Read Enable pins (RENA1, RENA2, RENB1, RENB2). 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{\text{OEA}}, \overline{\text{OEB}})$ is provided on the read port of each FIFO for three-state output control. Each of the two FIFOs has two fixed flags, Empty (EFA, EFB) and Full (FFA, FFB). Two programmable flags, Almost-Empty (PAEA, PAEB) and Almost-Full (PAFA, PAFB), are provided for each FIFO bank to improve memory utilization. If not programmed, the programmable flags default to Empty+7 for PAEA and PAEB, and Full-7 for PAFA and PAFB. The IDT72V801/72V811/72V821/72V831/72V841/72V851 architecture lends itself to many flexible configurations such as: - · 2-level priority data buffering - Bidirectional operation - · Width expansion - Depth expansion This FIFO is fabricated using IDT's high-performance submicron CMOS technology. # **FUNCTIONAL BLOCK DIAGRAM** **June 1999** 1999 Integrated Device Technology, Inc. DSC-4093/- # PIN CONFIGURATION TQFP (PN64-1, order code: PF) STQFP (PP64-1, order code: TF) TOP VIEW # **PIN DESCRIPTIONS** The IDT72V801/72V811/72V821/72V831/72V841/72V851's two FIFOs, referred to as FIFO A and FIFO B, are identical in every respect. The following description defines the input and output signals for FIFO A. The corresponding signal names for FIFO B are provided in parentheses. | DA0-DA8 A Data Ing DB0-DB8 B Data Ing RSA, RSB Reset | outs I | 9-bit data inputs to RAM array A. | |--------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | 9-bit data inputs to haivi array A. | | RSA, RSB Reset | outs I | 9-bit data inputs to RAM array B. | | | I | When RSA (RSB) is set LOW, the associated internal read and write pointers of array A (B) are set to the first location; FFA (FFB) and PAFA (PAFB) go HIGH, and PAEA (PAEB) and EFA (EFB) go LOW. After powerup, a reset of both FIFOs A and B is required before an initial WRITE. | | WCLKA Write Cloc<br>WCLKB | ck I | Data is written into the FIFO A (B) on a LOW-to-HIGH transition of WCLKA (WCLKB) when the write enable(s) are asserted. | | WENB1 Write Ena | ble 1 I | If FIFO A (B) is configured to have programmable flags, WENAT (WENB1) is the only write enable pin that can be used. When WENAT (WENB1) is LOW, data A (B) is written into the FIFO on every LOW-to-HIGH transition WCLKA (WCLKB). If the FIFO is configured to have two write enables, WENAT (WENB1) must be LOW and WENA2 (WENB2) must be HIGH to write data into the FIFO. Data will not be written into the FIFO if FFA (FFB) is LOW. | | WENA2/LDA Write Ena<br>WENB2/LDB Load | ble 2/ I | FIFO A (B) is configured at reset to have either two write enables or programmable flags. If $\overline{\text{LDA}}$ ( $\overline{\text{LDB}}$ ) is HIGH at reset, this pin operates as a second Write Enable. If WENA2/ $\overline{\text{LDA}}$ (WENB2/ $\overline{\text{LDB}}$ ) is LOW at reset this pin operates as a control to load and read the programmable flag offsets for its respective array. If the FIFO is configured to have two write enables, $\overline{\text{WENA1}}$ (WENB1) must be LOW and WENA2 (WENB2) must be HIGH to write data into FIFO A (B). Data will not be written into FIFO A (B) if $\overline{\text{FFA}}$ ( $\overline{\text{FFB}}$ ) is LOW. If the FIFO is configured to have programmable flags, $\overline{\text{LDA}}$ ( $\overline{\text{LDB}}$ ) is held LOW to write or read the programmable flag offsets. | | QA0-QA8 A Data Ou | tputs O | 9-bit data outputs from RAM array A. | | QB0-QB8 B Data Ou | tputs O | 9-bit data outputs from RAM array B. | | RCLKA Read Clock | ck I | Data is read from FIFO A (B) on a LOW-to-HIGH transition of RCLKA (RCLKB) when RENA1(RENB1) and RENA2 (RENB2) are asserted. | | RENA1 Read Ena | ble 1 I | When RENA1 (RENB1) and RENA2 (RENB2) are LOW, data is read from FIFO A (B) on every LOW-to-HIGH transition of RCLKA (RCLKB). Data will not be read from Array A (B) if EFA (EFB) is LOW. | | RENA2 Read Ena | ble2 | When RENA1 (RENB1) and RENA2 (RENB2) are LOW, data is read from the FIFO A (B) on every LOW-to-HIGH transition of RCLKA (RCLKB). Data will not be read from array A (B) if the EFA (EFB) is LOW. | | OEA Output En | able I | When OEA (OEB) is LOW, outputs DA0-DA8 (DB0-DB8) are active. If OEA (OEB) is HIGH, the OEB outputs DA0-DA8 (DB0-DB8) will be in a high-impedance state. | | EFA Empty Fla | ıg O | When EFA (EFB) is LOW, FIFO A (B) is empty and further data reads from the output are inhibited. When EFA (EFB) is HIGH, FIFO A (B) is not empty. EFA (EFB) is synchronized to RCLKA (RCLKB). | | PAEA Programm PAEB Almost-Ei | | When PAEA (PAEB) is LOW, FIFO A (B) is Almost-Empty based on the offset programmed into the appropriate offset register. The default offset at reset is Empty+7. PAEA (PAEB) is synchronized to RCLKA (RCLKB). | | PAFA Programm PAFB Almost-Fu | | When PAFA (PAFB) is LOW, FIFO A (B) is Almost-Full based on the offset programmed into the appropriate offset register. The default offset at reset is Full-7. PAFA (PAFB) is synchronized to WCLKA (WCLKB). | | FFA Full Flag | 0 | When FFA (FFB) is LOW, FIFO A (B) is full and further data writes into the input are inhibited. When FFA (FFB) is HIGH, FIFO A (B) is not full. FFA (FFB) is synchronized to WCLKA (WCLKB). | | VCC Power | | +3.3V power supply pin. | | GND Ground | | 0V ground pin. | # **ABSOLUTE MAXIMUM RATINGS** | Symbol | Rating | Commercial | Unit | |--------|-----------------------|------------|------| | VTERM | Terminal Voltage with | -0.5 to +5 | ٧ | | | Respect to GND | | | | Tstg | Storage Temperature | −55to+125 | °C | | Iout | DC Output Current | -50 to +50 | mΑ | #### NOTE: 4093 tbl 02 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 the specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. # RECOMMENDED OPERATING CONDITIONS | Symbol | Parameter | Min. | Тур. | Max. | Unit | |--------|-------------------------------------|------|------|------|------| | Vcc | Supply Voltage | 3.0 | 3.3 | 3.6 | ٧ | | GND | Supply Voltage | 0 | 0 | _ | ٧ | | VIH | Input High Voltage | 2.0 | ı | 5.0 | ٧ | | VIL | Input Low Voltage | | _ | 0.8 | ٧ | | Та | Operating Temperature<br>Commercial | 0 | ١ | 70 | °C | 4093 tbl 03 4093 tbl 05 # DC ELECTRICAL CHARACTERISTICS (Commercial: $Vcc = 3.3V \pm 0.3V$ . TA = 0°C to +70°C) | Symbol | Parameter | IDT72V801 IDT72V811 IDT72V821 IDT72V831 IDT72V841 IDT72V851 Commercial tclk = 10, 15, 20 ns Min. Typ. Max. | | | | |-------------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------|---|-----|----| | ILI <sup>(1)</sup> | Input Leakage Current (Any Input) | <b>-</b> 1 | _ | -1 | μА | | ILO <sup>(2)</sup> | Output Leakage Current | -10 | _ | 10 | μА | | <b>V</b> OH | Output Logic "1" Voltage, IOH = -2 mA | 2.4 | _ | _ | ٧ | | Vol | Output Logic "0" Voltage, IoL = 8 mA | _ | _ | 0.4 | ٧ | | ICC1 <sup>(3,4,5)</sup> | Active Power Supply Current (both FIFOs) | _ | _ | 40 | mA | | ICC2 <sup>(3,6)</sup> | Standby Current | _ | _ | 10 | mA | #### NOTES: - 1. Measurements with $0.4 \le V$ IN $\le V$ CC. - 2. OEA, OEB $\geq$ ViH, 0.4 $\leq$ Vout $\leq$ Vcc. - 3. Tested with outputs disabled (IOUT = 0). - 4. RCLK and WCLK toggle at 20 MHz and data inputs switch at 10 MHz. - 5. Typical Icc1 = 2[0.17 + 0.48 fs + 0.02 CL fs] (in mA). These equations are valid under the following conditions: Vcc = 3.3V, Ta = 25 °C, fs = WCLK frequency = RCLK frequency (in MHz, using TTL levels), data switching at fs/2, CL = capacitive load (in pF). 6. All Inputs = Vcc - 0.2V or GND + 0.2V, except RCLK and WCLK, which toggle at 20 MHz. # **CAPACITANCE** (TA = +25°C, f = 1.0MHz) | Symbol | Parameter | Conditions | Max. | Unit | |-----------------------|--------------------|------------|------|------| | CIN <sup>(2)</sup> | Input Capacitance | VIN = 0V | 10 | pF | | Couт <sup>(1,2)</sup> | Output Capacitance | Vout = 0V | 10 | pF | ### NOTE: 1. With output deselected ( $\overline{OEA}$ , $\overline{OEB} \ge V_{IH}$ ). 2. Characterized values, not currently tested. # **AC ELECTRICAL CHARACTERISTICS(1)** (Commercial: $Vcc = 3.3V \pm 0.3V$ , $Ta = 0^{\circ}C$ to $+70^{\circ}C$ ) | ` | 1. VCC = 3.3V ± 0.3V, 1A = 0 0 10 +70 0) | | Commercial | | | | | | |--------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------|------|------|------| | | | IDT72\<br>IDT72\<br>IDT72\<br>IDT72\ | IDT72V801L10 IDT72V801L15 IDT72V811L15 IDT72V811L15 IDT72V821L15 IDT72V831L15 IDT72V841L15 IDT72V841L15 IDT72V851L10 IDT72V851L15 IDT7 | | IDT72V801L20<br>IDT72V811L20<br>IDT72V821L20<br>IDT72V831L20<br>IDT72V841L20<br>IDT72V851L20 | | | | | Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | fS | Clock Cycle Frequency | _ | 100 | _ | 66.7 | _ | 50 | MHz | | tA | Data Access Time | 2 | 6.5 | 2 | 10 | 2 | 12 | ns | | tCLK | Clock Cycle Time | 10 | _ | 15 <sup>(1)</sup> | _ | 20 | _ | ns | | tCLKH | Clock High Time | 4.5 | _ | 6 | - | 8 | _ | ns | | tCLKL | Clock Low Time | 4.5 | _ | 6 | - | 8 | _ | ns | | tDS | Data Set-up Time | 3 | _ | 4 | - | 5 | _ | ns | | tDH . | Data Hold Time | 0.5 | _ | 1 | - | 1 | _ | ns | | tENS | Enable Set-up Time | 3 | _ | 4 | - | 5 | _ | ns | | tENH | Enable Hold Time | 0.5 | _ | 1 | _ | 1 | _ | ns | | tRS | Reset Pulse Width <sup>(1)</sup> | 10 | _ | 15 | _ | 20 | _ | ns | | trss | Reset Set-upTime | 8 | | 10 | _ | 12 | | ns | | trsr | Reset Recovery Time | 8 | | 10 | | 12 | | ns | | tRSF | Reset to Flag Time and Output Time | | 10 | | 15 | | 20 | ns | | tolz | Output Enable to Output in Low-Z <sup>(2)</sup> | 0 | | 0 | _ | 0 | | ns | | tOE | Output Enable to Output Valid | 3 | 6 | 3 | 8 | 3 | 10 | ns | | tohz | Output Enable to Output in High-Z <sup>(2)</sup> | 3 | 6 | 3 | 8 | 3 | 10 | ns | | tWFF | Write Clock to Full Flag | _ | 6.5 | _ | 10 | _ | 12 | ns | | tREF | Read Clock to Empty Flag | _ | 6.5 | _ | 10 | _ | 12 | ns | | tPAF | Write Clock to Programmable Almost-Full Flag | _ | 6.5 | _ | 10 | _ | 12 | ns | | tPAE | Read Clock to Programmable Almost-Empty Flag | _ | 6.5 | _ | 10 | _ | 12 | ns | | tskew1 | Skew Time Between Read Clock and Write Clock for Empty Flag and Full Flag | 5 | _ | 6 | _ | 8 | _ | ns | | tskew2 | Skew Time Between Read Clock and Write Clock for<br>Programmable Almost-Empty Flag and Programmable<br>Almost-Full Flag | 14 | _ | 18 | _ | 20 | _ | ns | NOTES: 4093 tbl 06 - 1. Pulse widths less than minimum values are not allowed. - 2. Values guaranteed by design, not currently tested. # **AC TEST CONDITIONS** | In Pulse Levels | GND to 3.0V | |-------------------------------|--------------| | Input Rise/Fall Times | 3ns | | Input Timing Reference Levels | 1.5V | | Output Reference Levels | 1.5V | | Output Load | See Figure 1 | | | 4093 tbl 07 | 3.3V 330Ω D.U.T. 510Ω 30pF\* or equivalent circuit Figure 1. Output Load \*Includes jig and scope capacitances. # SIGNAL DESCRIPTIONS FIFO A and FIFO B are identical in every respect. The following description explains the interaction of input and output signals for FIFO A. The corresponding signal names for FIFO B are provided in parentheses. ### **INPUTS:** **Data In (Dao – Das, DBo – DBs)** — Dao - Das are the nine data inputs for memory array A. DBo - DBs are the nine data inputs for memory array B. # **CONTROLS:** $\label{eq:RSA} \begin{tabular}{l} \textbf{RSB} \end{tabular} \en$ **Write Clock (WCLKA, WCLKB)** — A write cycle to Array A (B) is initiated on the LOW-to-HIGH transition of WCLKA (WCLKB). Data set-up and hold times must be met with respect to the LOW-to-HIGH transition of WCLKA (WCLKB). The Full Flag, $\overline{\text{FFA}}$ ( $\overline{\text{FFB}}$ ) and Programmable Almost-Full Flag, $\overline{\text{PAFA}}$ ( $\overline{\text{PAFB}}$ ) are synchronized with respect to the LOW-to-HIGH transition of the Write Clock, WCLKA (WCLKB). The Write and Read clock can be asynchronous or coincident. Write Enable 1 (WENA1, WENB1) — If FIFO A (B) is configured for programmable flags, WENA1 (WENB1) is the only enable control pin. In this configuration, when WENA1 (WENB1) is LOW, data can be loaded into the input register of RAM Array A (B) on the LOW-to-HIGH transition of every Write Clock, WCLKA (WCLKB). Data is stored in Array A (B) sequentially and independently of any on-going read operation. In this configuration, when WENA1 (WENB1) is HIGH, the input register holds the previous data and no new data is allowed to be loaded into the register. If the FIFO is configured to have two write enables, which allows for depth expansion. See Write Enable 2 paragraph below for operation in this configuration. To prevent data overflow, $\overline{FFA}(\overline{FFB})$ will go LOW, inhibiting further write operations. Upon the completion of a valid read cycle, the $\overline{FFA}(\overline{FFB})$ will go HIGH after twFF, allowing a valid write to begin. $\overline{WENA1}(\overline{WENB1})$ is ignored when FIFO A (B) is full. $\label{eq:RCLKA} \textbf{RCLKB} \leftarrow \textbf{Data} \ \text{can be read from Array A (B)} \\ \text{on the LOW-to-HIGH transition of RCLKA (RCLKB)}. \ The Empty Flag, $\overline{\text{EFA}}$ ($\overline{\text{EFB}}$) and $\overline{\text{Programmable Almost-Empty Flag}}$, $\overline{\text{PAEA}}$ ($\overline{\text{PAEB}}$) are synchronized with respect to the LOW-to-HIGH transition of RCLKA (RCLKB).}$ The Write and Read Clock can be asynchronous or coincident. Read Enables (RENA1, RENA2, RENB1, RENB2) — When both Read Enables, RENA1, RENA2 (RENB1, RENB2) are LOW, data is read from Array A (B) to the output register on the LOW-to-HIGH transition of the Read Clock, RCLKA (RCLKB). When either of the two Read Enable, $\overline{RENA1}$ , $\overline{RENA2}$ ( $\overline{RENB1}$ , $\overline{RENB2}$ ) associated with FIFO A (B) is HIGH, the output register holds the previous data and no new data is allowed to be loaded into the register. When all the data has been read from FIFO A (B), the Empty Flag, $\overline{\text{EFA}}$ ( $\overline{\text{EFB}}$ ) will go LOW, inhibiting further read operations. Once a valid write operation has been accomplished, $\overline{\text{EFA}}$ ( $\overline{\text{EFB}}$ ) will go HIGH after tree and a valid read can begin. The Read Enables, $\overline{\text{RENA1}}$ , $\overline{\text{RENA2}}$ ( $\overline{\text{RENB1}}$ ), $\overline{\text{RENB2}}$ ) are ignored when FIFO A (B) is empty. **Output Enable (\overline{OEA}, \overline{OEB})** — When Output Enable, $\overline{OEA}$ ( $\overline{OEB}$ ) is enabled (LOW), the parallel output buffers of FIFO A (B) receive data from their respective output register. When Output Enable, $\overline{OEA}$ ( $\overline{OEB}$ ) is disabled (HIGH), the QA (QB) output data bus is in a high-impedance state. Write Enable 2/Load (WENA2/LDA, WENB2/LDB) — This is a dual-purpose pin. FIFO A (B) is configured at Reset to have programmable flags or to have two write enables, which allows depth expansion. If WENA2/LDA (WENB2/LDB) is set HIGHat Reset, RSA=LOW (RSB=LOW), this pin operates as a second Write Enable pin. If FIFO A (B) is configured to have two write enables, when Write Enable 1, WENA1 (WENB1) is LOW and WENA2/LDA (WENB2/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 array sequentially and independently of any on-going read operation. In this configuration, when WENA1 (WENB1) is HIGH and/or WENA2/LDA (WENB2/LDB) is LOW, the input register of Array A holds the previous data and no new data is allowed to be loaded into the register. To prevent data overflow, the Full Flag, $\overline{FFA}(\overline{FFB})$ will go LOW, inhibiting further write operations. Upon the completion of a valid read cycle, $\overline{FFA}(\overline{FFB})$ will go HIGH after twFF, allowing a valid write to begin. $\overline{WENA1}$ , ( $\overline{WENB1}$ ) and $\overline{WENA2}/\overline{LDA}$ ( $\overline{WENB2}/\overline{LDB}$ ) are ignored when the FIFO is full. FIFO A (B) is configured to have programmable flags when the WENA2/ LDA(WENB2/LDB) is set LOW at Reset, RSA = LOW (RSB = LOW). Each FIFO | LDA | WENA1 | WCLKA | OPERATION ON FIFO A | |-----|-------|----------|---------------------------------------------------------------------------| | LDB | WENB1 | WCLKB | OPERATION ON FIFO B | | 0 | 0 | <b> </b> | Empty Offset (LSB) Empty Offset (MSB) Full Offset (MSB) Full Offset (MSB) | | 0 | 1 | <u>_</u> | No Operation | | 1 | 0 | | Write Into FIFO | | 1 | 1 | | No Operation | NOTE: - 1. For the purposes of this table, WENA2 and WENB2 = VIH. - The same selection sequence applies to reading from the registers. RENA1 and RENA2 (RENB1 and RENB2) are enabled and read is performed on the LOW-to-HIGH transition of RCLKA (RCLKB). Figure 2. Writing to Offset Registers for FIFOs A and B contains four 8-bit offset registers which can be loaded with data on the inputs, or read on the outputs. See Figure 3 for details of the size of the registers and the default values. If FIFO A (B) is configured to have programmable flags, when the $\overline{WENA1}$ ( $\overline{WENB1}$ ) and $\overline{WENA2/LDA}$ (WENB2/LDB) are set LOW, data on the DA (DB) inputs are written into the Empty (Least Significant Bit) Offset register on the first LOW-to-HIGH transition of the WCLKA (WCLKB). Data are written into the Empty (Most Significant Bit) Offset register on the second LOW-to-HIGH transition of WCLKA(WCLKB), into the Full (Least Significant Bit) Offset register on the third transition, and into the Full (Most Significant Bit) Offset register on the fourth transition. The fifth transition of WCLKA (WCLKB) again writes to the Empty (Least Significant Bit) 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 $\overline{LDA}(\overline{LDB})$ HIGH, FIFO A (B) is returned to normal read/write operation. When $\overline{LDA}(\overline{LDB})$ is set LOW, and $\overline{WENA1}$ ( $\overline{WENB1}$ ) is LOW, the next offset register in sequence is written The contents of the offset registers can be read on the QA (QB) outputs when WENA2/ $\overline{\text{LDA}}$ (WENB2/ $\overline{\text{LDB}}$ ) is set LOW and both Read Enables $\overline{\text{RENA1}}$ , $\overline{\text{RENA2}}$ ( $\overline{\text{RENB1}}$ , $\overline{\text{RENB2}}$ ) are set LOW. Data can be read on the LOW-to-HIGH transition of the Read Clock RCLKA (RCLKB). A read and write should not be performed simultaneously to the offset registers. Figure 3. Offset Register Formats and Default Values for the A and B FIFOs ## **OUTPUTS:** Full Flag (FFA, FFB) — FFA (FFB) will go LOW, inhibiting further write operations, when Array A (B) is full. If no reads are performed after reset, FFA (FFB) will go LOW after 256 writes to the IDT72V801's FIFO A (B), 512 writes to the IDT72V811's FIFO A (B), 1,024 writes to the IDT72V821's FIFO A (B), 2,048 writes to the IDT72V831's FIFO A (B), 4,096 writes to the IDT72V841's FIFO A (B), or 8,192 writes to the IDT72V851's FIFO A (B). FFA (FFB) is synchronized with respect to the LOW-to-HIGH transition of the Write Clock WCLKA (WCLKB). **Empty Flag (EFA, EFB)** — EFA (EFB) will go LOW, inhibiting further read operations, when the read pointer is equal to the write pointer, indicating that Array A (B) is empty. EFA (EFB) is synchronized with respect to the LOW-to-HIGH transition of the Read Clock RCLKA (RCLKB). Programmable Almost–Full Flag (PAFA, PAFB) — PAFA (PAFB) will go LOW when the amount of data in Array A (B) reaches the Almost-Full condition. If no reads are performed after reset, PAFA (PAFB) will go LOW after (256-m) writes to the IDT72V801's FIFO A (B), (512-m) writes to the IDT72V811's FIFO A (B), (1,024-m) writes to the IDT72V821's FIFO A (B), (2,048-m) writes to the IDT72V831's FIFO A (B), (4,096-m) writes to the IDT72V841's FIFO A (B), or (8,1912-m) writes to the IDT72V851's FIFO A (B). FFA (FFB) is synchronized with respect to the LOW-to-HIGH transition of the Write Clock WCLKA (WCLKB). The offset "m" is defined in the Full Offset Registers. If there is no Full offset specified, $\overline{PAFA}(\overline{PAFB})$ will go LOW at Full-7 words. $\overline{PAFA}(\overline{PAFB})$ is synchronized with respect to the LOW-to-HIGH transition of the Write Clock WCLKA (WCLKB). Programmable Almost–Empty Flag (PAEA, PAEB) — PAEA (PAEB) 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 Registers. If no reads are performed after reset, PAEA (PAEB) will go HIGH after "n+1" writes to FIFO A (B). If there is no Empty offset specified, $\overline{PAEA}$ ( $\overline{PAEB}$ ) will go LOW at Empty+7 words. PAEA (PAEB) is synchronized with respect to the LOW-to-HIGH transition of the Read Clock RCLKA (RCLKB). **Data Outputs (QAo – QAs, QBo – QBs)** — QAo - QAs are the nine data outputs for memory array A, QBo - QBs are the nine data outputs for memory array B. **TABLE 1: STATUS FLAGS FOR A AND B FIFOS** | | NUMBER OF WORDS IN ARRAY A | | | PAFA | PAEA | EFA | |-------------------------------|-------------------------------|-----------------------------------|---|------|------|-----| | | NUMBER OF WORDS IN ARRAY B | | | PAFB | PAEB | EFB | | 72V801 | 72V811 | 72V821 | | | | | | 0 | 0 | 0 | Н | Н | L | L | | 1 to n <sup>(1)</sup> | 1 to n <sup>(1)</sup> | 1 to n <sup>(1)</sup> | Н | Н | L | Н | | (n+1) to (256-(m+1)) | (n+1) to (512-(m+1)) | (n+1) to (1,024-(m+1)) | Н | Н | Н | Н | | (256-m) <sup>(2)</sup> to 255 | (512-m) <sup>(2)</sup> to 511 | (1,024-m) <sup>(2)</sup> to 1,023 | Н | L | Ι | Н | | 256 | 512 | 1,024 | L | L | Н | Н | | | NUMBER OF WORDS IN ARRAY | 4 | FFA | PAFA | PAEA | EFA | |-----------------------------------|-----------------------------------|-----------------------------------|-----|------|------|-----| | | NUMBER OF WORDS IN ARRAY B | | | PAFB | PAEB | EFB | | 72V831 | 72V841 | 72V851 | | | | | | 0 | 0 | 0 | Н | Н | L | L | | 1 to n <sup>(1)</sup> | 1 to n <sup>(1)</sup> | 1 to n <sup>(1)</sup> | Н | Н | L | Н | | (n+1) to (2,048-(m+1)) | (n+1) to (4,096-(m+1)) | (n+1) to (8,192-(m+1)) | Н | Н | Н | Н | | (2,048-m) <sup>(2)</sup> to 2,047 | (4,096-m) <sup>(2)</sup> to 4,095 | (8,192-m) <sup>(2)</sup> to 8,191 | Н | L | Н | Н | | 2,048 | 4,096 | 8,192 | L | L | Н | Н | NOTES 1. n = Empty Offset (n = 7 default value) 2. m = Full Offset (m = 7 default value) #### NOTES: - 1. Holding WENA2/\bar{LDA} (WENB2/\bar{LDB}) HIGH during reset will make the pin act as a second Write Enable pin. Holding WENA2/\bar{LDA} (WENB2/\bar{LDB}) LOW during reset will make the pin act as a load enable for the programmable flag offset registers. 2. After reset, QAo - QAs (QBo - QBs) will be LOW if $\overline{OEA}$ ( $\overline{OEB}$ ) = 0 and tri-state if $\overline{OEA}$ ( $\overline{OEB}$ ) = 1. - 3. The clocks RCLKA, WCLKA (RCLKB, WCLKB) can be free-running during reset. Figure 4. Reset Timing Figure 5. Write Cycle Timing <sup>1.</sup> tskew1 is the minimum time between a rising RCLKA (RCLKB) edge and a rising WCLKA (WCLKB) edge for FFA (FFB) to change 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) #### NOTE: Figure 6. Read Cycle Timing # NOTE: 1. When tskew₁ ≥ minimum specification, tfrl = tclk + tskew1 tskew1 < minimum specification, tfRL = 2tclk + tskew1 or tclk + tskew1 The Latency Timings apply only at the Empty Boundary (EFA, EFB = LOW). Figure 7. First Data Word Latency Timing <sup>1.</sup> tskew1 is the minimum time between a rising WCLKA (WCLKB) edge and a rising RCLKA (RCLKB) edge for EFA (EFB) to change 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 EFA (EFB) may not change state until the next RCLKA (RCLKB) edge. NOTE: 1. Only one of the two Write Enable inputs, WEN1 or WEN2, needs to go inactive to inhibit writes to the FIFO. Figure 8. Full Flag Timing NOTE: 1. When tskew1 ≥ minimum specification, tFRL maximum = tclk + tskew1 tskew1 < minimum specification, tFRL maximum = 2tclk + tskew1 or tclk + tskew1 The Latency Timings apply only at the Empty Boundary (EFA, EFB = LOW). Figure 9. Empty Flag Timing #### NOTES: - 1. $m = \overline{PAF}$ offset. - 2. (256-m) words for the IDT72V801, (512-m) words the IDT72V811, (1,024-m) words for the IDT72V821, (2,048-m) words for the IDT72V831, (4,096-m) words for the IDT72V841, or (8,192-m) words for the IDT72V851. - 3. tskew2 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) rising edge. - 4. If a write is performed on this rising edge of the Write Clock, there will be Full (m-1) words in FIFO A (B) when $\overline{PAFA}$ ( $\overline{PAFB}$ ) goes LOW. Figure 10. Programmable Full Flag Timing #### NOTES: - 1. n = PAE offset. - 2. tskew2 is the minimum time between a rising WCLKA (WCLKB) edge and a rising RCLKA (RCLKB) edge for PAEA (PAEB) to change during that clock cycle. If the time between the rising edge of WCLKA (WCLKB) and the rising edge of RCLKA (RCLKB) is less than tskew2, then PAEA (PAEB) may not change state until the next RCLKA (RCLKB) rising edge. - 3. If a read is performed on this rising edge of the Read Clock, there will be Empty + (n-1) words in FIFO A (B) when PAEA (PAEB) goes LOW. Figure 11. Programmable Empty Flag Timing Figure 12. Write Offset Register Timing Figure 13. Read Offset Register Timing ## **OPERATING CONFIGURATIONS** **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 14). In this configuration, the Write Enable 2/Load WENA2/LDA (WENB2/LDB) pin is set LOW at Reset so that the pin operates as a control to load and read the programmable flag offsets. Figure 14. Block Diagram of One of the IDT72V801/72V811/72V821/72V831/72V841/72V851's two FIFOs configured as a single device 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 endpointstatusflags FFA and FFB, also FFA and FFB). The partial statusflags PAEA, PAFB, PAEA and PAFB can be detected from any one device. Figure 15 demonstrates an 18-bit word width using the two FIFOs contained in one IDT72V801/72V811/72V821/72V831/72V841/72V851. Any word width can be attained by adding additional IDT72V801/72V811/72V821/72V831/72V841/72V851s. When these devices are in a Width Expansion Configuration, the Read Enable 2 (RENA2 and RENB2) control inputs can be grounded (see Figure 15). In this configuration, the Write Enable 2/Load (WENA2/LDA, WENB2/LDB) pins are set LOW at Reset so that the pin operates as a control to load and read the programmable flag offsets. Figure 15. Block diagram of the two FIFOs contained in one IDT72V801/72V811/72V821/72V831/72V841/72V851 configured for an 18-bit width-expansion # TWO PRIORITY DATA BUFFER CONFIGURATION The two FIFOs contained in the IDT72V801/72V811/72V821/72V831/72V841/72V851 can be used to prioritize two different types of data shared on a system bus. When writing from the bus to the FIFO, control logic sorts the intermixed data according to type, sending one kind to FIFO A and the other kind to FIFO B. Then, at the outputs, each data type is transferred to its appropriate destination. Additional IDT72V801/72V811/72V821/72V831/72V841/72V851s permit more than two priority levels. Priority buffering is particularly useful in network applications. Figure 16. Block Diagram of Two Priority Configuration # **BIDIRECTIONAL CONFIGURATION** The two FIFOs of the IDT72V801/72V811/72V821/72V831/72V841/72V851 can be used to buffer data flow in two directions. In the example that follows, a processor can write data to a peripheral controller via FIFO A, and, in turn, the peripheral controller can write the processor via FIFO B. Figure 17. Block Diagram of Bidirectional Configuration **DEPTH EXPANSION**—These FIFOs can be adapted to applications that require greater than 256/512/1,024/2,048/4,096/8,192 words. The existence of double 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 IDT72V801/72V811/72V821/72V831/72V841/72V851 operates in the Depth Expansion configuration when the following conditions are met: - 1. WENA2/LDA and WENB2/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. Please see the Application Note "DEPTH EXPANSION OF IDT'S SYNCHRONOUS FIFOS USING THE RING COUNTER APPROACH" for details of this configuration. # **ORDERING INFORMATION** #### NOTE 1. Industrial temperature range is available by special order. CORPORATE HEADQUARTERS 2975 Stender Way Santa Clara, CA 95054 for SALES: 800-345-7015 or 408-727-6116 fax: 408-492-8674 www.idt.com for TECH SUPPORT: (408) 330-1753 FIFOhelp@idt.com PF Pkg: www.idt.com/docs/PSC4036.pdf TFPkg: www.idt.com/docs/PSC4046.pdf The SyncFIFO is a trademark and the IDT logo is a registered trademark of Integrated Device Technology, Inc.