## Ultra-High-Speed CMOS 2K x 9, 4K x 9 FIFO Buffer Memories QS7203 QS7204 #### **FEATURES** - · Ultra-fast 10-ns flag and data access times - · Ground-bounce controlled outputs - · Input noise filters on read/write lines - · Fully asynchronous read and write - · Low power with industry-standard pinouts - Zero fall-through time - · Expandable in depth with no speed loss - · Fletransmit capability - · Available in PDIP, SOJ & PLCC #### **DESCRIPTION** The QS7203 and QS7204 are 2K x 9 and 4K x 9 FIFOs, respectively. These FIFOs use a dual-port RAM- based architecture and have independent read and write pointers. This allows high speed with zero fall-through time. The read and write pointers are incremented on the rising edges of the read and write lines. The flag circuitry is based on a patented highspeed design, giving precise half-full, full, and empty conditions. These flags also prevent the FIFO from being written into when full or being read from when empty. These FIFOs are easily cascadable to any depth and expandable to any width without any speed penalty. Retransmit resets the read pointer to memory location zero. These devices are useful for data communications, digital signal processing, and general data-rate management applications. #### FIGURE 1. FUNCTIONAL BLOCK DIAGRAM Note1: XO and HF share the same pin, so the Half-Full flag is available only in standalone, not depth-expansion mode. FIGURE 2. PINOUTS (All pins top view) ## **PIN DESCRIPTIONS** | Name | I/O | Description | |----------------|-----|----------------------------------------| | Đi | Į. | Data Inputs | | Qi | 0 | Data Outputs | | Ř | I | Read Clock | | $\overline{w}$ | l l | Write Clock | | ĒĒ | 0 | Empty Flag | | FF | 0 | Full Flag | | RS | i l | Reset | | FL/RT | I | First Load/Retransmit | | ΧĪ | 1 | Expansion Clock In | | XO/HF | 0 | Expansion Clock Out/<br>Half-Full Flag | #### SIGNAL DESCRIPTION #### **DATA INPUTS** #### D8-D0 The Data In lines D8 to D0 provide data to be written into the FIFO Note: Unused inputs must be tied to Vcc or GND. #### **CONTROL INPUTS** ## Reset (RS) The reset input resets the read and write pointers and the flags to zero. The FIFO must be reset at power-up to ensure proper operation of the pointers and flags. This is done by asserting the reset line to a LOW state, which causes the FIFO flags to be set to empty. This causes the Empty flag to be asserted and the Full and Half-Full flags to be deasserted. Read and write lines must be HIGH for these before and these after the rising edge of the reset signal for a valid reset operation. ### Write (W) The write line causes data to be written into the FIFO. A write cycle is initiated by the falling edge of the write signal. A write will occur if the full flag was not asserted, indicative of at least one empty location in the FIFO. Data is stored in the FIFO on the rising edge of the write signal using the data setup and hold times specified. Data is stored in a sequential manner in the FIFO, and the read and write operations can be asynchronous. The falling edge of the write signal asserts the Half-Full and Full flags when the next word after half-full is written and when the last word has been written, respectively. The rising edge of the write line de-asserts the Empty flag when the first write is performed after an empty or reset condition. When the Full flag is asserted, subsequent writes are blocked. The user can apply a write pulse after the full condition is deasserted. #### Read (R) The read signal causes data to be read from the FIFO. A read cycle is initiated by the falling edge of the read signal. A read is performed if the Empty flag is not asserted, indicative of at least one word being present in the FIFO. The data is accessed on a first-in-first-out basis asynchronous to the write operations. After the read control is deasserted, the data outputs go from a valid state into high impedance. The outputs remain in high impedance until the next read cycle. When all the data is read on the last read cycle, the Empty flag is asserted, and will inhibit any subsequent reads. The outputs will be in high impedance for subsequent read operations until a write occurs that deasserts the Empty flag, allowing a read cycle to begin. The outputs may also be in high impedance when the FIFOs are cascaded in depth. In this case, only the active FIFO asserts data, and the other FIFO data outputs are in high impedance. The falling edge of the read signal will set the Empty flag during the read of the last word in the FIFO. The rising edge of the read signal will deassert the Half-Full and the Full flags when the FIFO has reached half-full and when the FIFO is full, respectively. ### First Load/Retransmit (FL/RT) This is a dual-purpose input. In the depth-expansion mode, this pin indicates the first FIFO device that will be loaded or read from after a reset operation. In the standalone or width-expansion mode (when the expansion input is grounded), this pin initiates the retransmit function. Retransmit resets the read pointer to zero. The read and write signals must be HIGH before and after the rising edge of the retransmit pulse. The retransmit feature is useful when the same data needs to be read again without rewriting it into the FIFO. Pulsing the retransmit pin will cause the read pointer to be reset to zero, and the previously read data can be read again. The flags will change according to the relative location of the pointers after the retransmit pulse. #### Expansion In (XI) This is a dual-purpose pin. When it is grounded, it indicates that the FIFO is a standalone device. When it is not grounded, it indicates that the FIFO is in the depth-expansion mode. In the depth-expansion mode, this pin is connected to the $\overline{\text{XO}}$ pin of the previous device. #### **DATA OUTPUTS** #### Data Outputs Q8-Q0 The 9-bit data output bus Q8-Q0 receives the read data from the FIFO. It is active whenever the read signal is LOW. It is in a high-impedance state when the read signal is HIGH. It is also in high impedance when the FIFO Empty flag is active (i.e., when the FIFO is empty). #### **CONTROL OUTPUTS** ## Full Flag (FF) The Full flag indicates that the FIFO is full. The Full flag is asserted when there is only one empty location in the FIFO and a falling edge of the write signal initiates the last write operation. The rising edge of the read signal de-asserts the flag, as at least one location has become available. ## Empty Flag (EF) The Empty flag indicates the FIFO is empty. It is asserted when there is only one word in the FIFO, and a falling edge of the read signal initiates the last read operation. The rising edge of the write signal deasserts the flag, as one word is now present in the FIFO. #### Expansion Out/Half-Full Flag (XO/HF) This is a dual-purpose flag. In the single-device mode, the expansion in $(\overline{XI})$ is grounded, and the Half-Full flag output is present on this pin. Whenever the FIFO is more than half-full, the flag remains asserted. When the FIFO is exactly half-full and the next falling edge of the write signal asserts the flag. The rising edge of read that causes the FIFO to be half-full will de-assert the Half-Full flag. It will remain asserted until the FIFO is half-full or less than half-full. The name given to the flag is Half-Full, but it is asserted on the one plus the half-full condition. In the depth-expansion mode, the expansion out $(\overline{XO})$ is connected to the expansion in $(\overline{XI})$ of the next device. This causes the next device to perform write or read operations. #### **OPERATING MODES** #### SINGLE-DEVICE MODE A FIFO is in standalone mode when the expansion in $(\overline{XI})$ control is grounded. In this mode the Half-Full flag is available on the shared $\overline{XO/HF}$ line. Figure 16 shows the standalone mode, and this applies to FIFO width expansion, as shown in Figure 17. #### **DEPTH-EXPANSION MODE** A FIFO is in the depth-expansion mode when the expansion-in $(\overline{XI})$ control is not grounded but tied to the expansion-out $(\overline{XO})$ pin of the previous FIFO. Using the depth-expansion mode, the QS7203/02 can be easily cascaded to create FIFOs of larger depth. The devices are cascaded as shown in Figure 18. In the depth-expansion mode, the device that receives the first word of data has its first load input grounded. The other devices have their first load inputs in the HIGH state. Two 4-input OR gates are required to create the composite Full and Empty flags for the FIFO array. In using the depth-expansion mode, care must be taken to keep the traces short from the expansion in $(\overline{\text{XI}})$ of one device to the expansion out $(\overline{\text{XO}})$ of the next device to minimize crosstalk noise. #### **FLOW-THROUGH MODES** Flow-through modes refer to the internal operation of the FIFO in empty and full conditions. Flow-through modes allow data to flow directly through the FIFO from input to output under the appropriate empty and full conditions. Two types of flow-through modes, a read flow-through and a write flow-through, are supported by the FIFO. In the read flow-through mode, the FIFO is empty and the read side is waiting for data from a write. Read flow-through is represented by an empty FIFO that has its read line held LOW, and a write occurs. This rising edge of the write would de-assert the Empty flag and cause valid data to appear on the outputs after a certain time delay of twef + ta. The read line being LOW would cause the data to be read and also assert the Empty flag once again. The user must raise the read line in order to increment the read pointer. In the write flow-through mode, the FIFO is full and the write side is waiting for a word location to be made available by a read. A write flow-through operation permits the writing of a single word of data immediately after reading one word of data from a full FIFO. This is similar to the read flow-through case, and the write line must toggled to increment the write pointer. #### **FUNCTION TABLES** #### **RESET AND RETRANSMIT FUNCTION TABLE** | | | INPUTS | | INTERNA | AL STATUS | OUTPUTS | | | | | |------------|----|--------|----|--------------------------|--------------------------|---------|-----|-----|--|--| | Mode | RS | FL/RT | Χī | Read Pointer | Write Pointer | EF | FF | HF | | | | Reset | L | X | L | Location Zero | Location Zero | L | Н | Н | | | | Retransmit | Н | L | L | Location Zero | Unchanged | (3) | (3) | (3) | | | | Read/Write | Н | Н | ١ | Increment <sup>(1)</sup> | Increment <sup>(2)</sup> | (4) | (4) | (4) | | | #### Notes: - 1. The read pointer will increment if the FIFO is not empty. - 2. The write flag will increment if the FIFO is not full. - The flags will change after the retransmit operation and will correspond to the read pointer being at location zero. - 4. The flags will reflect the relative locations of the read and write pointers. #### **RESET AND FIRST-LOAD FUNCTION TABLE** | | | INPUTS | | INTERN | INTERNAL STATUS | | | | | | |------------|----|--------|-----|--------------------------|--------------------------|-----|-----|-----|--|--| | Mode | RS | FL/RT | XI | Read Pointer | Write Pointer | EF | FF | HF | | | | Reset | L | L | (1) | Location Zero | Location Zero | L | Н | Н | | | | Retransmit | L | Н | (1) | Location Zero | Location Zero | (3) | (3) | (3) | | | | Read/Write | Н | (2) | (1) | Increment <sup>(1)</sup> | Increment <sup>(2)</sup> | (4) | (4) | (4) | | | #### Notes: - 1. The expansion in $(\overline{XI})$ is connected to the expansion out $(\overline{XO})$ of the previous device. - The device with FL tied LOW will receive the first N writes and first N reads, where N is the FIFO size. On the Nth write, the XO pulse is sent to the next device to indicate that it will receive the (N+1)th write. Similarly, on the Nth read, another XO pulse is sent to the next device to indicate that it will output the (N+1)th read. - 3. The read and write pointers will be activated according to whether the FIFO received an XO pulse, or whether they were the first device in the daisy chain. The flags will reflect the empty or full conditions for the individual FIFOs. To create the composite Full and Empty flags, an OR-ing of the individual flags is required. - 4. The flags will reflect the relative locations of the read and write pointers. #### **ABSOLUTE MAXIMUM RATINGS** | Supply Voltage to Ground | ~0.5 to +7.0V | |----------------------------------------------|---------------------| | DC Output Voltage Vout | | | DC Input Voltage Vin | 0.5 to Vcc + 0.5V | | AC Input Voltage (Pulse Width ≤ 20 ns) | | | DC Input Diode Current with VIN < 0 | –20 mA | | DC Output Current with Vin > Vcc | 20 mA | | DC Output Diode Current with Vout < 0 | –50 mA | | DC Output Current with Vout > Vcc | 50 mA | | DC Output Current Max Sink Current/Pin | +70 mA | | DC Output Current Max Source Current/Pin | –30 mA | | Total DC Ground Current | (Nxlo∟+ Mx∆lcc) mA | | Total DC Vcc Power Supply Current | (NxIон + Mx∆Icc) mA | | (N = Number of Outputs, M = Number of Inputs | ) | | Tstg StorageTemperature | 65°C to +150°C | Note: Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to this device, resulting in functional- or reliability-type failures. ## DC ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE Commercial Vcc = $5V \pm 10\%$ , TA = $0^{\circ}$ C to $+70^{\circ}$ C | Symbol | Parameter | Test Conditions | Min | Max | Units | |----------|---------------------|------------------------------|-----|-----|-------| | ViH | Input HIGH Voltage | Logic HIGH for All Inputs | 2.0 | 6.0 | V | | VIL | Input LOW Voltage | Logic LOW for All Inputs | T - | 0.8 | V | | Vон | Output HIGH Voltage | юн = -2 mA, Vcc = 4.5V | 2.4 | _ | V | | Vol | Output LOW Voltage | IoL = 8 mA, Vcc = 4.5V | T — | 0.4 | V | | loz | Output Leakage | Vcc = 5.5V, Vout = Vcc or 0V | _ | 10 | μА | | <b> </b> | Input Leakage | Vcc = 5.5V, GND < Vin < Vcc | _ | 1 | μА | Note: It = ItH = ItL ## CAPACITANCE $T_A = 25^{\circ}C$ , f = 1.0 MHz | Name | Description | Conditions | Тур | Max | Units | |------|--------------------|------------|-----|-----|-------| | Cin | Input Capacitance | Vin = 0V | 5 | 8 | рF | | Соит | Output Capacitance | Vout = 0V | 5 | 8 | рF | Note: Capacitance is guaranteed but not tested. ## **POWER-SUPPLY CHARACTERISTICS** | Symbol | Parameter | Com | Units | |---------|----------------------------------------------------------------------|-----|-------| | lcc1(1) | Operating Current<br>Vcc = Max, Outputs Open | 100 | mA | | lcc2 | Standby Current R = W = RS = FL/RT = VIH | 15 | mA | | Isb | Power-Down Current All Inputs at VHc or VIC R = W = RS = FL/RT = VHC | 5 | mA | Note: 1. Icc is tested at 30 MHz. ## SWITCHING CHARACTERISTICS OVER OPERATING RANGE Commercial Vcc = $5V \pm 10\%$ , TA = $0^{\circ}$ C to $+70^{\circ}$ C ## **READ CYCLE TIMING** | Sym | Parameter | -10 | -12 | -15 | -20 | -25 | -35 | -50 | Unit | Type | |-----------------|------------------------------------|------|------|-----|-----|-----|-----|-----|------|------| | t <sub>RF</sub> | Read Frequency, MHz <sup>(2)</sup> | 45.5 | 43.5 | 40 | 33 | 28 | 22 | 15 | MHz | Min | | tric | Read Cycle Time | 22 | 23 | 25 | 30 | 35 | 45 | 65 | ns | Min | | ta | Read Access Time | 10 | 12 | 15 | 20 | 25 | 35 | 50 | ns | Max | | tra | Read Recovery Time | 7 | 8 | 10 | 10 | 10 | 10 | 15 | ns | Min | | trpw | Read Pulse Width(1) | 15 | 15 | 15 | 20 | 25 | 35 | 50 | | | | <b>t</b> F:LZ | R Data Bus Low-Z <sup>(2)</sup> | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 1 | | | twlz | ₩ Data Bus Low-Z <sup>(2,3)</sup> | 3 | 3 | 3 | 3 | 3 | 3 | 3 | | | | tısv | R HIGH to Data Hold Time | 5 | 5 | 5 | 5 | 5 | 5 | 5 | 1 | | | triHZ | R to Data High-Z(2) | 10 | 12 | 14 | 18 | 18 | 20 | 30 | | Max | #### WRITE CYCLE TIMING | Sym | Parameter | -10 | -12 | -15 | -20 | -25 | -35 | -50 | Unit | Туре | |------|-------------------------|------|------|-----|-----|-----|-----|-----|------|------| | twr | Write Frequency, MHz(2) | 45.5 | 43.5 | 40 | 33 | 28 | 22 | 15 | ns | Min | | twc | Write Cycle Time | 22 | 23 | 25 | 30 | 35 | 45 | 65 | | | | twpw | Write Pulse Width(1) | 15 | 15 | 15 | 20 | 25 | 35 | 50 | 1 | | | twn | Write Recovery Time | 7 | 8 | 10 | 10 | 10 | 10 | 15 | 1 | | | 1DS | Write Data Setup Time | 8 | 8 | 9 | 12 | 15 | 18 | 30 | 1 | | | 1DH | Write Data Hold Time | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | ## **RESET AND RETRANSMIT CYCLE TIMING** | Sym | Parameter | -10 | -12 | -15 | -20 | -25 | -35 | -50 | Unit | Туре | |------|---------------------------------------|-----|-----|-----|-----|-----|-----|-----|------|------| | t⊲sc | Reset Cycle Time | 17 | 20 | 25 | 30 | 35 | 45 | 65 | ns | Min | | TRS | Reset Pulse Width(1) | 10 | 12 | 15 | 20 | 25 | 35 | 50 | 1 ' | | | tass | Reset Setup Time | 10 | 12 | 15 | 20 | 25 | 35 | 50 | | | | tasa | Reset Recovery Time | 7 | 8 | 10 | 10 | 10 | 10 | 15 | ] | | | terc | Retransmit Cycle Time | 19 | 20 | 25 | 30 | 35 | 45 | 65 | | | | ter | Retransmit Pulse Width <sup>(1)</sup> | 12 | 12 | 15 | 20 | 25 | 35 | 50 | | | | 1RTS | Retransmit Setup Time | 10 | 12 | 15 | 20 | 25 | 35 | 50 | | | | 1RTR | Retransmit Recovery Time | 7 | 8 | 10 | 10 | 10 | 10 | 15 | | | Notes: These timings are measured as defined in AC Test Conditions. - 1. Pulse widths less than the specified minimum value may upset the internal pointers and are not allowed. - 2 These values are guaranteed by design and not tested. - 3 This applies to the read data flow-through mode only. ## SWITCHING CHARACTERISTICS OVER OPERATING RANGE Commercial Vcc = $5V \pm 10\%$ , $T_A = 0$ °C to +70°C ## **FLAG TIMING** | Sym | Parameter | -10 | -12 | -15 | -20 | -25 | -35 | -50 | Unit | Туре | |------|---------------------------|-----|-----|-----|-----|-----|-----|-----|------|------| | tref | Read Low to EF Low | 10 | 12 | 15 | 20 | 25 | 30 | 45 | ns | Мах | | tref | Read High to FF High | 13 | 14 | 15 | 20 | 25 | 30 | 45 | | | | trhF | Read High to HF High | 16 | 17 | 19 | 20 | 25 | 30 | 45 | | | | tRPE | Read Pulse After EF High | 10 | 12 | 15 | 20 | 25 | 30 | 50 | ns | Min | | twer | Write Low to EF Low | 10 | 12 | 15 | 20 | 25 | 30 | 45 | ns | Max | | twFF | Write High to FF High | 13 | 14 | 15 | 20 | 25 | 30 | 45 | | | | twhF | Write High to HF High | 16 | 17 | 19 | 20 | 25 | 30 | 45 | | | | twpe | Write Pulse After EF High | 10 | 12 | 15 | 20 | 25 | 30 | 50 | ns | Min | | terl | Reset Low to EF Low | 10 | 12 | 15 | 20 | 25 | 30 | 45 | ns | Max | | trrH | Reset High to FF High | 13 | 14 | 15 | 20 | 25 | 30 | 45 | | | | tHFH | Reset High to HF High | 16 | 17 | 19 | 20 | 25 | 30 | 45 | | | ## **EXPANSION TIMING** | Sym | Parameter | -10 | -12 | -15 | -20 | -25 | -35 | -50 | Unit | Туре | |------|-----------------------------------|-----|-----|-----|-----|-----|-----|-----|------|------| | txoL | Read/Write to $\overline{XO}$ Low | 12 | 12 | 15 | 20 | 25 | 35 | 50 | ns | Min | | tхон | Read/Write to XO High | 12 | 12 | 15 | 20 | 25 | 35 | 50 | | | | txı | XI Pulse Width | 10 | 12 | 15 | 20 | 25 | 35 | 50 | | | | txir | XI Recovery Time | 7 | 8 | 10 | 10 | 10 | 10 | 10 | | | | txis | XI Setup Time | 7 | 8 | 10 | 15 | 15 | 15 | 15 | | | ## FIGURE 3. AC TEST CONDITIONS | Input Pulse Levels | GND to 3.0V | |-------------------------------|-------------| | Input Rise/Fall Times | 3 ns | | Input Timing Reference Levels | | | Output Reference Levels | | 30 pF (Includes jig and scope capacitances) (5 pF for tOLZ and tOHZ) ## **TIMING DIAGRAMS** ## FIGURE 4. ASYNCHRONOUS READ AND WRITE OPERATIONS ## FIGURE 5. RESET TIMING #### Notes: 1. Read and write have to be at a HIGH level around the rising edge of reset. The flags may change during reset but are valid at tasc. FIGURE 6. FULL FLAG BEHAVIOR FROM LAST WRITE TO FIRST READ FIGURE 7. FULL FLAG AND REQUIRED WRITE PULSE AT FULL CONDITION FIGURE 8. EMPTY FLAG BEHAVIOR FROM LAST READ TO FIRST WRITE FIGURE 9. EMPTY FLAG AND REQUIRED WRITE PULSE AT EMPTY CONDITION #### FIGURE 10. HALF-FULL FLAG TIMING ## FIGURE 11. RETRANSMIT FUNCTION TIMING #### FIGURE 12. EXPANSION-OUT TIMING #### Note: 1. The expansion out $(\overline{XO})$ of device 1 is connected to the expansion in $(\overline{XI})$ of device 2. ## FIGURE 13. EXPANSION-IN TIMING FIGURE 14. READ DATA FLOW-THROUGH MODE FIGURE 15. WRITE DATA FLOW-THROUGH MODE ## FIGURE 16. THE FIFO IN STANDALONE MODE ## FIGURE 17. AN 18-BIT-WIDE FIFO USING TWO FIFOS VCC ΧĨ ĒΕ Ŕ $\overline{\mathsf{W}}$ - R 720X DATA IN DATA OUT **FIFO** RS -RS ĒĒ $\overline{\mathsf{XO}}$ VCC $\overline{XI}$ FL W Ŕ 720X **FIFO** ŔŜ ĒF $\overline{XO}$ VCC $\overline{XI}$ FL W Ē 720X **FIFO** RS ĒĒ $\overline{XO}$ VCC FL W R 720X **FIFO** ĒF $\overline{\mathsf{XO}}$ FIGURE 18. BUILDING A 4N-DEEP FIFO USING FOUR N-DEEP FIFOS Note: The composite Empty and Full flags require the OR-ing of the individual Empty and Full flags, respectively. # ORDERING INFORMATION Example: