# LH5496/96H #### **FEATURES** - Fast Access Times: 15 \*/20/25/35/50/65/80 ns - Full CMOS Dual Port Memory Array - Fully Asynchronous Read and Write - Expandable-in Width and Depth - Full, Half-Full, and Empty Status Flags - Read Retransmit Capability - TTL Compatible I/O - Packages: 28-Pin, 300-mil PDIP 28-Pin, 600-mil PDIP 32-Pin PLCC - Pin and Functionally Compatible with IDT7201 #### **FUNCTIONAL DESCRIPTION** The LH5496/96H are dual port memories with internal addressing to implement a First-In, First-Out algorithm. Through an advanced dual port architecture, they provide fully asynchronous read/write operation. Empty, Full, and Half-Full status flags are provided to prevent data overflow and underflow. In addition, internal logic provides for unlimited expansion in both word size and depth. Read and write operations automatically access sequential locations in memory in that data is read out in the same order that it was written, that is on a First-In, First-Out basis. Since the address sequence is internally predefined, no external address information is required for the operation of this device. A ninth data bit is provided for parity or control information often needed in communication applications. Empty, Full, and Half-Full status flags monitor the extent to which data has been written into the FIFO, and prevent improper operations (i.e., Read if the FIFO is empty, or Write if the FIFO is full). A retransmit feature resets the Read address pointer to its initial position, thereby allowing repetitive readout of the same data. Expansion In and Expansion Out pins implement an expansion scheme that allows individual FIFOs to be cascaded to greater depth without incurring additional latency (bubblethrough) delays. #### PIN CONNECTIONS Figure 1. Pin Connections for PDIP Packages Figure 2. Pin Connections for PLCC Package <sup>\*</sup> LH5496 only. Figure 3. LH5496/96H Block Diagram # **PIN DESCRIPTIONS** | PIN | PIN TYPE * | DESCRIPTION | |---------------------------------|------------|-----------------| | D <sub>0</sub> – D <sub>8</sub> | I | Input Data Bus | | $Q_0 - Q_8$ | O/Z | Output Data Bus | | $\overline{W}$ | I | Write Request | | R | I | Read Request | | EF | 0 | Empty Flag | | FF | 0 | Full Flag | | * I — Innut | $\Omega = \Omega \cup t \cap \cup t$ | Z = High-Impedance. | V - Power | Voltage Level | |-------------|--------------------------------------|---------------------|------------|---------------| | 1 — 111041. | O - Outbut. | | v — I UWEI | VUILAUE LEVEI | | PIN | PIN TYPE * | DESCRIPTION | |-----------------|------------|------------------------------| | XO/HF | 0 | Expansion Out/Half-Full Flag | | XI | I | Expansion In | | FL/RT | I | First Load/Retransmit | | RS | I | Reset | | V <sub>CC</sub> | V | Positive Power Supply | | V <sub>SS</sub> | V | Ground | # ABSOLUTE MAXIMUM RATINGS 1 | PARAMETER | RATING | |--------------------------------------------------------------|-------------------------------------------------------| | Supply Voltage to V <sub>SS</sub> Potential | -0.5 V to 7 V | | Signal Pin Voltage to V <sub>SS</sub> Potential <sup>3</sup> | -0.5 V to V <sub>CC</sub> + 0.5 V (not to exceed 7 V) | | DC Output Current <sup>2</sup> | ±50 mA | | Storage Temperature Range | -65°C to 150°C | | Power Dissipation (Package Limit) | 1.0 W | | DC Voltage Applied To Outputs In High-Z State | -0.5 V to Vcc + 0.5 V (not to exceed 7 V) | #### NOTES: - Stresses greater than those listed under 'Absolute Maximum Ratings' may cause permanent damage to the device. This is a device stress rating for transient conditions only. Functional operation at these or any other conditions above those indicated in the 'Operating Range' of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. - 2. Outputs should not be shorted for more than 30 seconds. No more than one output should be shorted at any time. - 3. Negative undershoots of 1.5 V in amplitude are permitted for up to 10 ns once per cycle. #### **OPERATING RANGE** | SYMBOL | PARAMETER | MIN | MAX | UNIT | |-----------------|-------------------------------|------|-----------|------| | T <sub>A</sub> | Temperature, Ambient, LH5496 | 0 | 70 | °C | | T <sub>A</sub> | Temperature, Ambient, LH5496H | -40 | 85 | οС | | Vcc | Supply Voltage | 4.5 | 5.5 | V | | Vss | Supply Voltage | 0 | 0 | V | | $V_{IL}$ | Logic '0' Input Voltage 1 | -0.5 | 0.8 | V | | V <sub>IH</sub> | Logic '1' Input Voltage | 2.0 | Vcc + 0.5 | V | #### NOTE: # **DC ELECTRICAL CHARACTERISTICS** (Over Operating Range) | SYMBOL | PARAMETER | TEST CONDITIONS | MIN | MAX | UNIT | |------------------|---------------------------------|-----------------------------------------------------------|-----|-----|------| | ILI | Input Leakage Current | $V_{CC} = 5.5 \text{ V}, V_{IN} = 0 \text{ V to } V_{CC}$ | -10 | 10 | μА | | I <sub>LO</sub> | Output Leakage Current | $\overline{R} \ge V_{IH}, \ 0 \ V \le V_{OUT} \le V_{CC}$ | -10 | 10 | μА | | V <sub>OH</sub> | Output High Voltage | $I_{OH} = -2.0 \text{ mA}$ | 2.4 | | V | | $V_{OL}$ | Output Low Voltage | I <sub>OL</sub> = 8.0 mA | | 0.4 | V | | I <sub>CC</sub> | Average Supply Current 1 | Measured at f = 40 MHz | | 100 | mA | | I <sub>CC2</sub> | Average Standby Current 1 | All Inputs = V <sub>IH</sub> | | 15 | mA | | I <sub>CC3</sub> | Power Down Current <sup>1</sup> | All Inputs = $V_{CC} - 0.2 \text{ V}$ | | 5 | mA | #### NOTE: 1. Icc, Icc2, and Icc3 are dependent upon actual output loading and cycle rates. Specified values are with outputs open. <sup>1.</sup> Negative undershoots of 1.5 V in amplitude are permitted for up to 10 ns once per cycle. ### **AC TEST CONDITIONS** | PARAMETER | RATING | |----------------------------------------|------------| | Input Pulse Levels | Vss to 3 V | | Input Rise and Fall Times (10% to 90%) | 5 ns | | Input Timing Reference Levels | 1.5 V | | Output Reference Levels | 1.5 V | | Output Load, Timing Tests | Figure 4 | # CAPACITANCE 1,2 | PARAMETER | RATING | |---------------------------------------|--------| | C <sub>IN</sub> (Input Capacitance) | 5 pF | | C <sub>OUT</sub> (Output Capacitance) | 7 pF | #### NOTES: - 1. Sample tested only. - Capacitances are maximum values at 25°C measured at 1.0 MHz with V<sub>IN</sub> = 0 V. Figure 4. Output Load Circuit CMOS 512×9 FIFO LH5496/96H # AC ELECTRICAL CHARACTERISTICS <sup>1</sup> (Over Operating Range) | | | t <sub>A</sub> = 15 ns <sup>2</sup> | | t <sub>A</sub> = 20 ns | | t <sub>A</sub> = 25 ns | | t <sub>A</sub> = 35 ns | | t <sub>A</sub> = 50 ns | | t <sub>A</sub> = 65 ns | | | | | |----------------------|------------------------------------------------|---------------------------------------|-----------|------------------------|-------|------------------------|-----|------------------------|------------|------------------------|-----|------------------------|-----|-----|-----|------| | SYMBOL | PARAMETER | MIN | MAX | MIN | мах | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | UNIT | | | | | ⊦<br>REA[ | CY | CLE | ⊦<br>TIMII | NG | | | | | | | | | | | t <sub>RC</sub> | Read Cycle Time | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | _ | ns | | tA | Access Time | _ | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | ns | | t <sub>RR</sub> | Read Recover Time | 10 | _ | 10 | _ | 10 | _ | 10 | <b> </b> _ | 15 | _ | 15 | _ | 15 | _ | ns | | t <sub>RPW</sub> | Read Pulse Width <sup>3</sup> | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | tRLZ | Data Bus Active from Read LOW 4 | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 10 | _ | ns | | twLz | Data Bus Active from Write<br>HIGH 4,5 | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 20 | _ | ns | | t <sub>DV</sub> | Data Valid from Read Pulse HIGH | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 5 | _ | 5 | _ | ns | | t <sub>RHZ</sub> | Data Bus High-Z from Read<br>HIGH <sup>4</sup> | _ | 15 | - | 15 | _ | 15 | _ | 15 | _ | 20 | _ | 30 | _ | 30 | ns | | | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | ∟<br>WRIT | L<br>E CY | CLE | TIMI | NG | | | | | | | | | | | twc | Write Cycle Time | 25 | _ | 30 | Ī _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | _ | ns | | twpw | Write Pulse Width <sup>3</sup> | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | twr | Write Recovery Time | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 15 | _ | 15 | _ | 15 | _ | ns | | t <sub>DS</sub> | Data Setup Time | 10 | _ | 10 | _ | 10 | _ | 15 | _ | 20 | _ | 20 | _ | 20 | _ | ns | | tDH | Data Hold Time | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 0 | _ | 5 | _ | 5 | _ | ns | | | | | R | ESE | Г ТІМ | ING | | I | | I | | I | | | | | | trsc | Reset Cycle Time | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | _ | ns | | trs | Reset Pulse Width <sup>3</sup> | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | trsr | Reset Recovery Time | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 15 | _ | 15 | _ | 15 | _ | ns | | trrss | Read HIGH to RS HIGH | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | twrss | Write HIGH to RS HIGH | 15 | - | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | | | | RETR | RANS | MIT | TIMII | NG | 1 | | 1 | | 1 | | | | | | t <sub>RTC</sub> | Retransmit Cycle Time | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | _ | ns | | t <sub>RT</sub> | Retransmit Pulse Width <sup>3</sup> | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | t <sub>RTR</sub> | Retransmit Recovery Time | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 15 | _ | 15 | _ | 15 | _ | ns | | | - | | F | LAG | TIMI | NG | | | | | | | | | | | | tefl | Reset LOW to Empty Flag LOW | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | ns | | t <sub>HFH,FFH</sub> | Reset LOW to Half-Full and Full Flags HIGH | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | ns | | t <sub>REF</sub> | Read LOW to Empty Flag LOW | _ | 20 | _ | 25 | _ | 25 | _ | 35 | _ | 45 | _ | 60 | _ | 60 | ns | | treff | Read HIGH to Full Flag HIGH | _ | 20 | _ | 25 | _ | 25 | _ | 35 | _ | 45 | _ | 60 | _ | 60 | ns | | twer | Write HIGH to Empty Flag HIGH | _ | 20 | l _ | 25 | _ | 25 | _ | 35 | _ | 45 | _ | 60 | _ | 60 | ns | | twff | Write LOW to Full Flag LOW | _ | 20 | _ | 25 | _ | 25 | _ | 35 | _ | 45 | _ | 60 | _ | 60 | ns | | twhF | Write LOW to Half-Full Flag LOW | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | ns | | t <sub>RHF</sub> | Read HIGH to Half-Full Flag HIGH | _ | 25 | _ | 30 | _ | 35 | _ | 45 | _ | 65 | _ | 80 | _ | 100 | ns | | | <u> </u> | 1 | EXP | ANSI | | IMIN | | 1 | ' | 1 | 1 | 1 | 1 | | 1 | | | t <sub>XOL</sub> | Expansion Out LOW | _ | 18 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | ns | | tхон | Expansion Out HIGH | _ | 18 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | ns | | txı | Expansion In Pulse Width | 15 | _ | 20 | _ | 25 | _ | 35 | _ | 50 | _ | 65 | _ | 80 | _ | ns | | txir | Expansion In Recovery Time | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | 10 | _ | ns | | txis | Expansion in Setup Time | 7 | _ | 10 | _ | 10 | _ | 15 | _ | 15 | _ | 15 | _ | 15 | _ | ns | #### NOTES: - 1. LH5496 only. - 2. All timing measurements performed at 'AC Test Condition' levels. #### **OPERATIONAL DESCRIPTION** #### Reset The device is reset whenever the Reset pin $(\overline{RS})$ is taken to a LOW state. The reset operation initializes both the read and write address pointers to the first memory location. The $\overline{XI}$ and $\overline{FL}$ pins are also sampled at this time to determine whether the device is in Single mode or Depth Expansion mode. A reset pulse is required when the device is first powered up. The Read $(\overline{R})$ and Write $(\overline{W})$ pins may be in any state when reset is initiated, but must be brought to a HIGH state $t_RPW$ and $t_RPW$ before the rising edge of $\overline{RS}$ . The reset operation forces the Empty Flag $\overline{EF}$ to be asserted $(\overline{EF} = LOW)$ , and the Half-Full Flag $\overline{HF}$ and the Full Flag $\overline{FF}$ to be deasserted $(\overline{HF} = \overline{FF} = HIGH)$ ; the Data Out pins $(D_0 - D_8)$ are forced into a high-impedance state. #### Write A write cycle is initiated on the falling edge of the Write $(\overline{W})$ pin. Data setup and hold times must be observed on the data in $(D_0-D_8)$ pins. A write operation is only possible if the FIFO is not full, (i.e. the Full flag pin is HIGH). Writes may occur independently of any ongoing read operations. At the falling edge of the first write after the memory is half filled, the Half-Full flag will be asserted ( $\overline{HF}$ = LOW) and will remain asserted until the difference between the write pointer and read pointer indicates that the remaining data in the device is less than or equal to one half the total capacity of the FIFO. The Half-Full flag is deasserted ( $\overline{HF}$ = HIGH) by the appropriate rising edge of $\overline{R}$ . The Full flag is asserted ( $\overline{FF}$ = LOW) at the falling edge of the write operation which fills the last available location in the FIFO memory array. The Full flag will inhibit further writes until cleared by a valid read. The Full flag is deasserted ( $\overline{FF}$ = HIGH) after the next rising edge of $\overline{R}$ releases another memory location. #### Read A read cycle is initiated on the falling edge of the Read $(\overline{R})$ pin. Read data becomes valid on the data out $(Q_0-Q_8)$ pins after a time $t_A$ from the falling edge of $\overline{R}$ . After $\overline{R}$ goes HIGH, the data out pins return to a high-impedance state. Reads may occur independent of any ongoing write operations. A read is only possible if the FIFO is not empty $(\overline{EF} = \text{HIGH})$ . The internal read and write address pointers are maintained by the device such that consecutive read operations will access data in the same order as it was written. The Empty flag is asserted ( $\overline{\text{EF}} = \text{LOW}$ ) after the falling edge of $\overline{\text{R}}$ which accesses the last available data in the FIFO memory. $\overline{\text{EF}}$ is deasserted ( $\overline{\text{EF}} = \text{HIGH}$ ) after the next rising edge of $\overline{\text{W}}$ loads another word of valid data. #### **Data Flow-Through** Read flow-through mode occurs when the Read $(\overline{R})$ pin is brought LOW while the FIFO is empty, and held LOW in anticipation of a write cycle. At the end of the next write cycle, the Empty flag will be momentarily deasserted, and the data just written will become available on the data out pins after a maximum time of $t_{WEF}$ + $t_{A}$ . Additional writes may occur while the $\overline{R}$ pin remains LOW, but only data from the first write flows through to the outputs. Additional data, if any, can only be accessed by toggling $\overline{R}$ . Write flow-through mode occurs when the Write $(\overline{W})$ pin is brought LOW while the FIFO is full, and held LOW in anticipation of a read cycle. At the end of the read cycle, the Full flag will be momentarily deasserted, but then immediately reasserted in response to $\overline{W}$ held LOW. Data is written into the FIFO on the rising edge of $\overline{W}$ which may occur tree + twpw after the read. #### Retransmit The FIFO can be made to reread previously read data through the retransmit function. Retransmit is initiated by pulsing $\overline{RT}$ LOW. This resets the internal read address pointer to the first physical location in the memory while leaving the internal write address pointer unchanged. Data between the read and write pointers may be reaccessed by subsequent reads. Both $\overline{R}$ and $\overline{W}$ must be inactive (HIGH) during the retransmit pulse. Retransmit is useful if no more than 512 writes are performed between resets. Retransmit may affect the status of $\overline{EF}$ , $\overline{HF}$ , and $\overline{FF}$ flags, depending on the relocation of the read pointer. This function is not available in depth expansion mode. #### **TIMING DIAGRAMS** Figure 5. Reset Timing Figure 6. Asynchronous Write and Read Operation LH5496/96H CMOS 512×9 FIFO # **TIMING DIAGRAMS (cont'd)** Figure 7. Full Flag from Last Write to First Read Figure 8. Empty Flag from Last Read to First Write ### **TIMING DIAGRAMS (cont'd)** Figure 9. Read Data Flow-Through Figure 10. Write Data Flow-Through # **TIMING DIAGRAMS (cont'd)** Figure 11. Empty Flag Timing Figure 12. Full Flag Timing # **TIMING DIAGRAMS (cont'd)** Figure 14. Retransmit Timing Figure 15. Expansion Out Timing Figure 16. Expansion In Timing LH5496/96H CMOS 512 × 9 FIFO #### **OPERATIONAL MODES** #### **Single Device Configuration** When depth expansion is not required for the given application, the device is placed in Single mode by tying the Expansion In pin $(\overline{XI})$ to ground. This pin is internally sampled during reset. #### Width Expansion Word-width expansion is implemented by placing multiple LH5496/96H devices in parallel. Each LH5496/96H should be configured for standalone mode. In this arrangement, the behavior of the status flags is identical for all devices; so, in principle, a representative value for each of these flags could be derived from any one device. In practice, it is better to derive 'composite' flag values using external logic, since there may be minor speed variations between different actual devices. (See Figures 17 and 18.) Figure 17. Single FIFO (512 $\times$ 9) Figure 18. FIFO Width Expansion (512 $\times$ 18) #### **OPERATIONAL MODES (cont'd)** #### **Depth Expansion** Depth expansion is implemented by configuring the required number of FIFOs in Expansion mode. In this arrangement, the FIFOs are connected in a circular fashion with the Expansion Out pin $(\overline{XO})$ of each device tied to the Expansion In pin $(\overline{XI})$ of the next device. One FIFO in this group must be designated as the first load device. This is accomplished by tying the First Load pin $(\overline{FL})$ of this device to ground. All other devices must have their $\overline{FL}$ pin tied to a high level. In this mode, $\overline{W}$ and $\overline{R}$ signals are shared by all devices, while internal logic controls the steering of data. Only one FIFO will be enabled for any given read cycle, so the common Data Out pins of all devices are wire-ORed together. Likewise, the common Data In pins of all devices are tied together. In Expansion mode, external logic is required to generate a composite Full or Empty flag. This is achieved by ORing the FF pins of all devices and ORing the EF pins of all devices respectively. The Half-Full flag and Retransmit functions are not available in Depth Expansion mode. Figure 19. FIFO Depth Expansion (1536 $\times$ 9) LH5496/96H CMOS 512 × 9 FIFO #### **OPERATIONAL MODES (cont'd)** #### **Compound Expansion** A combination of width and depth expansion can be easily implemented by operating groups of depth expanded FIFOs in parallel. #### **Bidirectional Operation** Applications which require bidirectional data buffering between two systems can be realized by operating LH5496/96H devices in parallel but opposite directions. The Data In pins of a device may be tied to the corresponding Data Out pins of another device operating in the opposite direction to form a single bidirectional bus interface. Care must be taken to assure that the appropriate read, write, and flag signals are routed to each system. Both depth and width expansion may be used in this configuration. Figure 20. Compound FIFO Expansion Figure 21. Bidirectional FIFO Buffer #### **PACKAGE DIAGRAMS** 28-pin, 300-mil PDIP 28-pin, 600-mil PDIP 32-pin, 450-mil PLCC #### ORDERING INFORMATION