# Q

#### High-Speed CMOS 512 x 18, 1K x 18 Parallel Clocked FIFO

QS72215 QS72225

#### FEATURES

- CMOS dual-port SRAM technology, 512 x 18 or 1024 x 18
- Fast cycle times: 20/25/35 ns
- Choice of standard or enhanced operating mode
- Device comes up into one of two known default states at reset depending on the state of the *EMODE* control input
- IoL = 16 mA, three-state outputs
- Independently synchronized operation of input port and output port
- May be cascaded for increased depth, or paralleled for increased width
- TTL/CMOS-compatible I/O
- Five status flags: Full, Almost-Full, Half-Full, Almost-Empty, and Empty; Partial flags are programmable

- In enhanced operating mode (EMODE), Almost Full, Half-Full, and Almost-Empty flags can be made completely synchronous
- In enhanced operating mode, duplicate enables for interlocked paralleled FIFO operation, for 36-bit data width
- Data retransmit function
- In enhanced operating mode, disabling three-state outputs may be made to suppress reading
- Pin-compatible drop-in replacements for IDT72215LB/25LB FIFOs
- Space-saving 68-pin PLCC and 64-pin TQFP packages



#### DESCRIPTION

The QS72215/25 are FIFO (first-in, first-out) memory devices, based on fully static CMOS dual-port SRAM technology, capable of containing up to 512 or 1024 18-bit words, respectively. They can replace two or more byte-wide FIFOs in many applications for microprocessor-to-microprocessor or microprocessor-to-bus communication. Their architecture supports synchronous operation, tied to two independent free-running clocks at the input and output ports, respectively. However, these "clocks" also may be asynchronous signals. Almost all control input signals and status-output signals are synchronized to these clocks to simplify system design.

The input and output ports operate altogether independently of each other, unless the FIFO becomes either totally full or totally empty. Data flow is initiated at a port by the rising edge of its corresponding clock, and is gated by the appropriate edge-sampled enable signals.

The following FIFO status flags monitor the extent to which the internal memory has been filled: Full, Almost-Full, Half-Full, Almost-Empty, and Empty. The Almost-Full and Almost-Empty flag offsets are programmable over the entire FIFO depth; but, during a reset operation, each of these is initialized to a default offset value of 63 (QS72215) or 127 (QS72225) FIFO-memory words, from the respective FIFO boundary. If this default offset value is satisfactory, no further programming is required.

After a reset operation during which the **EMODE** control input was not asserted (was HIGH), these FIFOs operate in the standard operating mode. In this mode, each part is pin-compatible and functionally compatible with the IDT72215/25 part of similar depth and speed grade; and the **control register** is not even accessible or visible to the external-system logic, which is controlling the FIFO, although it still performs the same control functions.

However, assertion of the EMODE control input during a reset operation leaves control register bits 00-05 set, and causes the FIFO to operate in the enhanced operating mode. In essence, asserting EMODE chooses a different default state for the control register. The system optionally then may program the control register in any desired manner to activate or deactivate any or all of the enhanced operating mode features which it can control, including selectable-clock-edge flag synchronization and read inhibition when the data outputs are disabled.

Whenever **EMODE** is being asserted, interlocked operation paralleling also is available, by appropriate interconnection of the FIFO's expansion inputs.

The retransmit facility is available during standalone operation, in either standard operating mode or *an enhanced operating mode* (see Tables 1 and 2). It is inoperative if the FL/RT input signal is grounded. It is not an IDT72215/25 feature. *The retransmit control signal causes the internal FIFO read-address pointer to be set back to zero, without affecting the internal FIFO write-address pointer. Thus, the retransmit control signal also provides a mechanism whereby a block of data delimited by the zero physical address and the current write-address-pointer address may be read out repeatedly, an arbitrary number of times. The only restrictions are that neither the read-address pointer nor the write-address pointer may wrap around during this entire process, and that the retransmit facility is not available during depth-cascaded operation, either in standard operating mode or in enhanced operating mode (See Tables 1 and 2). Also, the flags behave differently for a short time after a retransmit operation. Otherwise, the retransmit facility is available during standalone operation, in either standard or enhanced operating mode.* 

Programming the programmable-flag offsets, *the timing synchronization of the various status flags, the optional read-suppression functionality of OE,* and the behavior of the pointers which access the offset-value registers and *the control register* may be individually controlled by asserting the signal LD without any reset operation. When LD is being asserted, and writing is being enabled by asserting WEN, some portion of the input bus word D17-D0 is used at the next rising edge of WCLK to program one or more of the programmable registers on successive write clocks. Likewise, the values programmed into these programmable registers may be read out for verification by asserting LD and REN, with the outputs Q17-Q0 enabled. Reading out these programmable registers should not be initiated while they are being written into. Table 3 defines the possible modes of operation for loading and reading out the contents of programmable registers.

In the enhanced operating mode, coordinated operation of two 18-bit FIFOs as one 36-bit FIFO may be ensured by interlocked cross coupling of the status flag outputs from one FIFO to the expansion inputs of the other one: that is, FF to WXI/WEN2 and EF to RXI/REN2, in both directions between two parallel FIFOs. This "interlocked" operation takes effect automatically if two paralleled FIFOs are cross connected in this manner, with the EMODE control input being asserted (LOW) (See Tables 1 and 2, also Figures 27 and 30). Standard operating mode depth cascading no longer is available when operating in this "interlocked-paralleled" mode; however, pipelined depth cascading remains available.



#### FIGURE 2. 68-PIN PLCC PACKAGE DESCRIPTIONS

| Name             | I/O | Function                                        |
|------------------|-----|-------------------------------------------------|
| D17-D0           | I   | Data Inputs                                     |
| RS               | I   | Reset                                           |
| EMODE            | I   | Enhanced Operating<br>Mode                      |
| WCLK             | I   | Write Clock                                     |
| WEN              | I   | Write Enable                                    |
| RCLK             | I   | Read Clock                                      |
| REN              | I   | Read Enable                                     |
| ŌĒ               | I   | Output Enable                                   |
| LD               | I   | Load                                            |
| FL/ <b>RT</b>    | I   | First Load/ <i>Retransmit</i>                   |
| WXI/ <b>WEN2</b> | I   | Write Expansion Input/<br><i>Write Enable 2</i> |

| Name             | I/O | Function                                      |
|------------------|-----|-----------------------------------------------|
| RXI/ <b>REN2</b> | Ι   | Read Expansion Input/<br><i>Read Enable 2</i> |
| FF               | 0   | Full Flag                                     |
| PAF              | 0   | Programmable Almost-<br>Full Flag             |
| WXO/HF           | 0   | Write Expansion<br>Output/Half-Full Flag      |
| ĒĒ               | 0   | Empty Flag                                    |
| PAE              | 0   | Programmable Almost-<br>Empty Flag            |
| RXO/ <b>EF2</b>  | 0   | Read Expansion<br>Output/ <i>Empty Flag 2</i> |
| Q17-Q0           | 0   | Data Outputs                                  |
| Vcc              |     | Power                                         |
| Vss              |     | Ground                                        |





#### **PIN DESCRIPTIONS**

| Name   | <b>I/O</b> <sup>(1)</sup> | Function                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|---------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D17-D0 | Ι                         | Data Inputs                   | Data inputs from an 18-bit bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RS     | Ι                         | Reset                         | When RS is taken LOW, the FIFO's internal read and write pointers<br>are set to address the first physical location of the RAM array; FF,<br>PAF, and HF go HIGH; and PAE and EF go LOW. The program-<br>mable-flag-offset registers <b>and the control register</b> are set to their<br>default values. (But see the description of <b>EMODE</b> below.) A reset<br>is required before initial read or write operation after power-up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| EMODE  | 1                         | Enhanced<br>Operating<br>Mode | When EMODE is tied LOW, the default setting for control register<br>bits 00-05 after a reset operation changes to HIGH rather than<br>LOW, thus enabling all control-register-controllable enhanced<br>operating mode features, and allowing access to the control<br>register for reprogramming or readback. (See Tables 1, 2, and 5.)<br>If this behavior is desired, EMODE may be grounded; however,<br>control-register bits 00-05 still may be individually programmed<br>to selectively enable or disable certain of the enhanced mode<br>features, even though those features associated with inter-<br>locked-paralleled operation always are enabled whenever<br>EMODE is being asserted (see Table 2). Alternatively, EMODE<br>may be tied to Vcc, so that the FIFO is functionally compatible,<br>and the control register is not accessible or visible, and all of its<br>bits remain LOW. Controlling EMODE dynamically during<br>system operation is not recommended. |
| WCLK   | I                         | Write Clock                   | Data is written into the FIFO on a LOW-to-HIGH transition of WCLK, whenever $\overline{WEN}$ (write enable) is being asserted (LOW), and $\overline{LD}$ is HIGH. If $\overline{LD}$ is LOW, a programmable register rather than the internal FIFO memory is written into. <i>In the enhanced operating mode, WEN2 is ANDed with WEN to produce an effective internal write-enable signal.</i> <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| WEN    | Ι                         | Write Enable                  | When WEN is LOW and LD is HIGH, an 18-bit data word is written<br>into the FIFO on every LOW-to-HIGH transition of WCLK. When<br>WEN is HIGH, the FIFO internal memory continues to hold the<br>previous data (see Table 3). Data will not be written into the FIFO if<br>FF is LOW. <i>In the enhanced operating mode, WEN2 is</i><br><i>ANDed with WEN to produce an effective internal write-enable</i><br><i>signal.</i> <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RCLK   | Ι                         | Read Clock                    | Data is read from the FIFO on a LOW-to-HIGH transition of RCLK whenever REN (read enable) is being asserted (LOW), and LD is HIGH. If LD is LOW, a programmable register rather than the internal FIFO memory is read from. <i>In the enhanced operating mode, REN2 is ANDed with REN (and whenever control register bit 05 is HIGH, also with OE) to produce an effective internal read-enable signal.</i> <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### Notes:

1. I = input, O = output, Z = high-impedance, V = power voltage level.

2. The ostensible differences in signal assertiveness are reconciled before ANDing.

**BOLD ITALIC = ENHANCED OPERATING MODE** Standard Operating Mode = IDT-Compatible (Continued)

#### **PIN DESCRIPTIONS** (Continued)

| Name  | I/O <sup>(1)</sup> | Function                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|--------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REN   | 1                  | Read Enable                      | When REN is LOW and LD is HIGH, an 18-bit data word is read<br>from the FIFO on every LOW-to-HIGH transition of RCLK. When<br>REN is HIGH, and/or also when EF is LOW, the FIFO's output<br>register continues to hold the previous data word, whether or not<br>Q17-Q0 (the data outputs) are enabled (see Table 3). <i>In the<br/>enhanced operating mode, REN2 is ANDed with REN (and<br/>whenever control register bit 05 is HIGH, also with OE) to<br/>produce an effective internal read-enable signal.</i> <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ŌĒ    | I                  | Output Enable                    | When $\overline{OE}$ is LOW, the FIFO's data outputs drive the bus to which<br>they are connected. If $\overline{OE}$ is HIGH, the FIFO's outputs are in a<br>high-Z (high-impedance) state. In the enhanced operating mode,<br>$\overline{OE}$ not only continues to control the outputs in this same<br>manner, but also can function as an additional ANDing input to<br>the combined effective read-enable signal, along with $\overline{REN}$ and<br>REN2, whenever control register bit 05 is HIGH (see Table 5). <sup>(2)</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LD    | I                  | Load                             | When $\overline{\text{LD}}$ is LOW, the data word on D17-D0 (the data inputs) is<br>written into a programmable-flag-offset register, <i>or into the</i><br><i>control register (when in the enhanced operating mode)</i> , on<br>the LOW-to-HIGH transition of WCLK, whenever $\overline{\text{WEN}}$ is LOW<br>(see Table 3). Also, when $\overline{\text{LD}}$ is LOW, a word is read to Q17-Q0<br>(the data outputs) from the offset registers <i>and/or the control</i><br><i>register (when in the enhanced operating mode)</i> , on the LOW-<br>to-HIGH transition of RCLK, whenever $\overline{\text{REN}}$ is LOW. (See again<br>Table 3, and particularly the Notes following this table.) When $\overline{\text{LD}}$<br>is HIGH, normal FIFO write and read operations are enabled.                                                                                                                                                                                                                                                                                                                                       |
| FL/RT | I                  | First Load/<br><i>Retransmit</i> | In the standalone or paralleled configuration, FL / <i>RT</i> should be<br>LOW during a reset operation (see Tables 1 and 2). <i>However,</i><br><i>thereafter, in the standalone or paralleled configuration, if FL</i><br><i>is taken HIGH, it functions instead as RT (retransmit), and</i><br><i>resets the FIFO's internal read pointer to the first physical</i><br><i>location of the RAM array. Note that although retransmit is an</i><br><i>'enhanced' feature, it is always available for a FIFO during</i><br><i>standalone operation, whether the FIFO is in standard operat-<br/>ing mode or in enhanced operating mode; it is not regulated</i><br><i>by the control register or by EMODE control input.</i> In standard<br>operating mode cascaded configurations, FL has an entirely<br>different function: it is grounded for the first FIFO device (the<br>"master" device or the "first-load" device), and is set to HIGH for<br>all other FIFO devices in the daisy chain. Thus, the <i>retransmit</i><br>feature is not available for FIFOs operating in a standard operat-<br>ing mode cascaded configuration. |

(Continued)

Notes:

1. I = input, O = output, Z = high-impedance, V = power voltage level.

2. The ostensible differences in signal assertiveness are reconciled before ANDing.

#### **PIN DESCRIPTIONS** (Continued)

| Name         | I/O <sup>(1)</sup> | Function                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|--------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WXI/<br>WEN2 | I                  | Write Expansion<br>Input/ <i>Write</i><br><i>Enable 2</i> | This signal is dual-purpose; its functionality is determined during a reset operation, according to its own state, and also according to the states of the three other control inputs RXI/ <i>REN2</i> , FL/ <i>RT</i> , and <b>EMODE</b> (see Tables 1 and 2). In the standalone or paralleled configuration, WXI/ <i>WEN2</i> is grounded. In the cascaded configuration, WXI/ <i>WEN2</i> is connected to WXO (write expansion output) of the previous device, and functions as WXI. In the enhanced operating mode, WXI/WEN2 functions as a second write-enable signal, WEN2, which is ANDed with WEN to produce an effective internal write-enable signal. <sup>(2)</sup>                              |
| RXI/<br>REN2 | I                  | Read Expansion<br>Input/ <i>Read</i><br><i>Enable 2</i>   | This signal is dual-purpose; its functionality is determined during a reset operation, according to its own state, and also according to the states of the three other control inputs WXI/WEN2, FL/RT, and <b>EMODE.</b> (see Tables 1 and 2). In the standalone or paralleled configuration, RXI/REN2 is grounded. In the cascaded configuration, RXI/REN2 is connected to RXO (read expansion output) of the previous device, and functions as RXI. In the enhanced operating mode, REN/REN2 functions as a second read-enable signal, REN2, which is ANDed with REN — and perhaps also with OE, if control-register bit 05 is HIGH — to produce an effective internal read-enable signal. <sup>(2)</sup> |
| FF           | 0                  | Full Flag                                                 | When $\overline{\text{FF}}$ is LOW, the FIFO is full; further advancement of its internal write-address pointer and further data writes through its data inputs into its internal memory array are inhibited. When $\overline{\text{FF}}$ is HIGH, the FIFO is not full. $\overline{\text{FF}}$ is synchronized to WCLK.                                                                                                                                                                                                                                                                                                                                                                                    |
| PAF          | 0                  | Programmable<br>Almost-Full Flag                          | When PAF is LOW, the FIFO is "almost-full", based on the almost-full-offset value programmed into the FIFO's almost-full offset register. The default value of this offset at reset is one-eighth of the total number of words in the FIFO-memory array, minus one, measured from "full" (see Table 4). In the standard operating mode, PAF is asynchronous. <i>In the enhanced operating mode, PAF is synchronized to WCLK after a reset operation, according to the state of control register bit 04 (see Table 5).</i>                                                                                                                                                                                   |
| EF           | 0                  | Empty Flag                                                | When $\overline{\text{EF}}$ is LOW, the FIFO is empty; further advancement of its internal read-address pointer and further readout of data words from its internal memory array to its data outputs, are inhibited. When the $\overline{\text{EF}}$ is HIGH, the FIFO is not empty. $\overline{\text{EF}}$ synchronized to RCLK.                                                                                                                                                                                                                                                                                                                                                                           |

(Continued)

Notes:

1. I = input, O = output, Z = high-impedance, V = power voltage level.

2. The ostensible differences in signal assertiveness are reconciled before ANDing.

#### **PIN DESCRIPTIONS** (Continued)

| Name        | I/O <sup>(1)</sup> | Function                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|--------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PAE         | 0                  | Programmable<br>Almost-Empty Flag            | When PAE is LOW, the FIFO is "almost empty," based on the<br>almost-empty-offset value programmed into the FIFO's almost-empty<br>offset register. The default value of this offset at reset is one-eighth of<br>the total number of words in the FIFO-memory array, minus one,<br>measured from "empty" (see Table 4). In the standard operating<br>mode, PAE is asynchronous. In the Enhanced Operating Mode,<br>PAE is synchronized to RCLK after a reset operation, according<br>to the state of control register bit 01. (See Table 5.)                                                                                                                                                                               |
| WXO/<br>HF  | 0                  | Write Expansion<br>Output/<br>Half-Full Flag | This signal is dual-purpose; its functionality is determined during a reset operation, according to the states of the two control inputs WXI/WEN2 and RXI/REN2 (see Tables 1 and 2). In the standalone or paralleled configuration, whenever HF is LOW, the device is more than half-full. In the standard operating mode, HF is asynchronous. In the enhanced operating mode, HF may be synchronized to WCLK or to RCLK after a reset operation, according to the state of control register bits 02 and 03 (see Table 5). In the standard operating mode cascaded configuration, a pulse is sent from WXO to the WXI input of the next FIFO in the daisy-chain cascade whenever the last location in the FIFO is written. |
| RXO/<br>EF2 | 0                  | Read Expansion<br>Output                     | This signal is dual-purpose; its functionality is determined by the state of the <b>EMODE</b> control input during a reset operation (see Tables 1 and 2). In the standard operating mode, in a cascaded configuration, a pulse is sent from RXO to the RXI input of the next FIFO in the daisy-chain cascade, whenever the last location of the FIFO is read. In the enhanced operating mode, whenever <b>EMODE</b> is being asserted (LOW), <b>EF2</b> behaves as an exact duplicate of <b>EF</b> , but delayed by one full cycle of RCLK with respect to <b>EF</b> .                                                                                                                                                    |
| Q17-Q0      | O/Z                | Data Outputs                                 | Data outputs to an 18-bit Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Vcc         | V                  | Power                                        | +5V power supply pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Vss         | V                  | Ground                                       | 0V ground pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### Notes:

1. I = input, O = output, Z = high-impedance, V = power voltage level.

#### **ABSOLUTE MAXIMUM RATINGS**

| Supply Voltage to GND Potential                       | –0.5V to +7.0V      |
|-------------------------------------------------------|---------------------|
| Signal Pin Voltage to GND Potential                   | –0.5V to Vcc + 0.5V |
| DC Output Current Max Sink Current/Pin <sup>(1)</sup> | ±75 mA              |
| Maximum Power Dissipation                             |                     |
| Temperature Range with Power Applied <sup>(2)</sup>   | –55° to +125°C      |
| Tstg Storage Temperature Range                        | –65° to +155°C      |

**Note:** Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to QSI devices that result in functional- or reliability-type failures.

#### Notes:

1. Only one output may be shorted at a time, for a period not exceeding 30 seconds.

2. Measured with clocks idle.

#### CAPACITANCE

 $T_A = 25^{\circ}C, f = 1.0 \text{ MHz}$ 

| Name | Description <sup>(1)</sup> | Conditions | Тур | Max | Units |
|------|----------------------------|------------|-----|-----|-------|
| CIN  | Input Capacitance          | VIN = 0V   | _   | 8   | pF    |
| Соит | Output Capacitance         | Vout = 0V  | _   | 8   | pF    |

Notes:

1. Capacitance is guaranteed but not tested.

#### DC ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE

| Symbol | Parameter Test Conditions |                                             | Min  | Max       | Units |
|--------|---------------------------|---------------------------------------------|------|-----------|-------|
| Vін    | Input HIGH Voltage        | Logic HIGH for All Inputs                   | 2.0  | Vcc + 0.5 | V     |
| Vil    | Input LOW Voltage         | Logic LOW for All Inputs                    | -0.5 | 0.8       | V     |
| Vон    | Output HIGH Voltage       | Іон = –12.0 mA                              | 2.4  | —         | V     |
| Vol    | Output LOW Voltage        | IoL = 16.0 mA                               |      | 0.4       | V     |
| Ilo    | I/O Leakage               | $0V \le VOUT \le Vcc, \overline{OE} \ge VH$ | -10  | +10       | μA    |
| lı∟    | Input Leakage             | Vcc = 5.5V, $VIN = 0V$ to $Vcc$             | -10  | +10       | μA    |

#### **AC TEST CONDITIONS**

| Input Pulse Levels                           | GND to 3V |
|----------------------------------------------|-----------|
| Input Rise/Fall Times                        | 3 ns      |
| Input Timing Reference Levels                | 1.5V      |
| Output Reference Levels                      | 1.5V      |
| Output Load R <sub>1</sub> (Top Resistor)    | 1.1k Ω    |
| Output Load R <sub>2</sub> (Bottom Resistor) |           |
| Output Load CL (Load Capacitance)            |           |
|                                              |           |

#### FIGURE 4. OUTPUT LOAD CIRCUIT



#### POWER SUPPLY CHARACTERISTICS

| Symbol | Parameter                                                       | Min | Max | Units |
|--------|-----------------------------------------------------------------|-----|-----|-------|
| Icc    | Operating Current <sup>(1)</sup><br>Vcc = Max., Iout = 0 mA     |     | 190 | mA    |
| lcc2   | Standby Current<br>All Inputs = VIHMIN (Clocks Idle)            | _   | 25  | mA    |
| Іссз   | Power Down Current<br>All Inputs at Vcc – 0.2V<br>(Clocks Idle) |     | 1   | mA    |

Note:

1. Output load is disconnected.

|               |                                                                            | Speed (ns) |     |     |     |     |      |       |
|---------------|----------------------------------------------------------------------------|------------|-----|-----|-----|-----|------|-------|
|               |                                                                            |            | 0   | -2  | 5   | -3  | 5    | -     |
| Symbol        | Parameter                                                                  | Min        | Max | Min | Max | Min | Max  | Units |
| fcc           | Clock Cycle Frequency                                                      | —          | 50  | —   | 40  | —   | 28.6 | MHz   |
| tA            | Data Access Time                                                           | 2          | 12  | 3   | 15  | 3   | 20   | ns    |
| tclk          | Clock Cycle Time                                                           | 20         | _   | 25  | —   | 35  | _    | ns    |
| tськн         | Clock HIGH Time                                                            | 8          | —   | 10  |     | 14  | _    | ns    |
| <b>t</b> CLKL | Clock LOW Time                                                             | 8          | —   | 10  |     | 14  | _    | ns    |
| tDS           | Data Setup Time                                                            | 5          | —   | 6   |     | 7   | _    | ns    |
| tdн           | Data Hold Time                                                             | 1          | —   | 1   |     | 2   | _    | ns    |
| tens          | Enable Setup Time                                                          | 5          | —   | 6   |     | 7   | _    | ns    |
| <b>t</b> ENH  | Enable Hold Time                                                           | 1          | —   | 1   |     | 2   | _    | ns    |
| trs           | Reset Pulse Width <sup>(1)</sup>                                           | 20         | —   | 25  |     | 35  | _    | ns    |
| trss          | Reset Setup Time <sup>(2)</sup>                                            | 12         | —   | 15  |     | 20  | _    | ns    |
| trsr          | Rest Recovery Time <sup>(2)</sup>                                          | 12         | —   | 15  | —   | 20  | _    | ns    |
| trsf          | Reset to Flag and Output Time                                              | _          | 30  | —   | 35  | —   | 40   | ns    |
| toe           | Output Enable to Output Valid                                              |            | 9   | —   | 12  | _   | 15   | ns    |
| to∟z          | Output Enable to Output LOW-Z <sup>(2)</sup>                               | 0          | —   | 0   | —   | 0   | _    | ns    |
| tонz          | Output Enable to Output HIGH-Z <sup>(2)</sup>                              | 1          | 9   | 1   | 12  | 1   | 15   | ns    |
| twff          | Write Clock to Full Flag                                                   |            | 12  | —   | 15  | _   | 20   | ns    |
| tref          | Read Clock to Empty Flag                                                   | _          | 12  | —   | 15  | —   | 20   | ns    |
| <b>t</b> PAF  | Clock to Programmable Almost-Full Flag<br>(Standard Operating Mode)        |            | 14  | _   | 17  | _   | 23   | ns    |
| <b>t</b> PAE  | Clock to Programmable Almost-Empty Flag<br>(Standard Operating Mode)       |            | 14  | _   | 17  | _   | 23   | ns    |
| thf           | Clock to Half-Full Flag<br>(Standard Operating Mode)                       |            | 14  | _   | 17  |     | 23   | ns    |
| <b>t</b> PAFS | Clock to Programmable Almost-Full Flag<br>(Enhanced Operating Mode)        | _          | 14  | _   | 17  | _   | 23   | ns    |
| <i>t</i> PAES | Clock to Programmable Almost-Empty<br>Flag (Enhanced Operating Mode)       | _          | 14  | _   | 17  |     | 23   | ns    |
| tHFS          | Clock to Half-Full Flag<br>(Enhanced Operating Mode)                       | _          | 14  | _   | 17  | _   | 23   | ns    |
| txo           | Clock to Expansion-Out                                                     | _          | 12  | _   | 15  | _   | 20   | ns    |
| txı           | Expansion-In Pulse Width                                                   | 7          | —   | 9   | —   | 13  | _    | ns    |
| txis          | Expansion-In Setup Time                                                    | 7          | —   | 9   | —   | 14  | _    | ns    |
| tskew1        | Skew Time between Read Clock and Read Clock for Full Flag <sup>(3)</sup>   | 9          | _   | 11  | —   | 16  | -    | ns    |
| tskew2        | Skew Time between Read Clock and Write Clock for Empty Flag <sup>(4)</sup> | 9          |     | 11  |     | 16  |      | ns    |

#### AC ELECTRICAL CHARACTERISTICS ( $0^{\circ}C \le T_A \le 70^{\circ}C$ , Vcc = 5V ± 10%)

#### Notes:

1. Pulse widths less than the stated minimum values may cause incorrect operation.

2. Values are generated by design, not currently tested.

3. These times also apply to the Programmable-Almost-Full and Half-Full flags when they are synchronized to WCLK.

4. These times also apply to the Half-Full and Programmable-Almost-Empty flags when they are synchronized to RCLK.

#### SIGNAL AND OPERATING SEQUENCE DESCRIPTION

#### TABLE 1. GROUPING-MODE DETERMINATION DURING A RESET OPERATION

|                         |          |          |                         |                                          | WXO/<br>HF | WXI/<br>WEN2 | RXI/<br>REN2 | FL/<br><i>RT</i> | RXO/<br>EF2        |
|-------------------------|----------|----------|-------------------------|------------------------------------------|------------|--------------|--------------|------------------|--------------------|
| EMODE                   | WXI/WEN2 | RXI/REN2 | FL/RT                   | MODE                                     | USAGE      | USAGE        | USAGE        | USAGE            | USAGE              |
| <b>H</b> <sup>(1)</sup> | Н        | Н        | Н                       | Cascaded<br>Slave <sup>(2)</sup>         | WXO        | WXI          | RXI          | FL               | RXO                |
| <b>H</b> <sup>(1)</sup> | Н        | Н        | L                       | Cascaded<br>Master <sup>(2)</sup>        | WXO        | WXI          | RXI          | FL               | RXO                |
| Н                       | Н        | L        | Х                       | (Reserved)                               |            |              | —            | —                | —                  |
| н                       | L        | Н        | Х                       | (Reserved)                               | _          | —            | —            | —                | _                  |
| Н                       | L        | L        | H <sup>(3)</sup>        | (Not Allowed)                            | (HF)       | (none)       | (none)       | ( <i>RT</i> )    | (none)             |
| Н                       | L        | L        | L <sup>(3)</sup>        | Standalone                               | HF         | (none)       | (none)       | RT               | (none)             |
| L                       | X        | X        | <b>H</b> <sup>(3)</sup> | (Not Allowed<br>During Reset)            | (HF)       | (WEN2)       | (REN2)       | (RT)             | ( <del>EF2</del> ) |
| L                       | X        | X        | L <sup>(3)</sup>        | Interlocked<br>Paralleled <sup>(4)</sup> | ĦF         | WEN2         | REN2         | RT               | EF2                |

Notes:

1. A reset operation forces WXO/HF and RXO/*EF2* HIGH for the nth FIFO, thus forcing WXI/*WEN2* and RXI/*REN2* HIGH for the (n + 1)st FIFO.

2. The terms "master" and "slave" refer to the standard operating mode cascading. In pipeline cascading<sup>(3)</sup>, there is no such distinction.

3. Once grouping mode has been determined during a reset operation, FL/RT then may go HIGH to achieve a <u>retransmit</u> operation.

4. EMODE must be asserted for access to the control register to be enabled. Also, FIFOs being used in pipelined-cascading configurations should be in interlocked paralleled mode.

5. Setup time and recovery time specifications apply during a reset operation.

6. H = HIGH, L = LOW, X = don't care.

#### TABLE 2. EXPANSION-PIN USAGE ACCORDING TO GROUPING-MODE

|     |                  | stan                                              | Enhanced<br>Operating Mode            |                           |                           |
|-----|------------------|---------------------------------------------------|---------------------------------------|---------------------------|---------------------------|
| I/O | Pin              | Depth-CascadedDepth-CascadedMasterSlaveStandalone |                                       | Interlocked<br>Paralleled |                           |
| I   | WXI/WEN2         | From WXO<br>([n – 1]st FIFO)                      | From WXO<br>([n – 1]st FIFO)          | Grounded                  | From FF<br>(other FIFO)   |
| 0   | WXO/HF           | To <del>WXI</del><br>([n + 1]st FIFO)             | To <del>WXI</del><br>([n + 1]st FIFO) | Becomes HF                | Becomes HF                |
| I   | RXI/ <b>REN2</b> | From RXO<br>([n – 1]st FIFO)                      | From RXO<br>([n – 1]st FIFO)          | Grounded                  | From EF<br>(other FIFO)   |
| 0   | RXO/ <b>EF2</b>  | To RXI<br>([n + 1]st FIFO)                        | To <del>RXI</del><br>([n + 1]st FIFO) | Unused                    | Becomes EF2               |
| I   | FL/ <b>RT</b>    | Grounded (Logic LOW)                              | Logic HIGH                            | Becomes RT <sup>(1)</sup> | Becomes RT <sup>(1)</sup> |

Note:

1. FL/RT may be grounded if the retransmit facility is not being used.

| LD | WEN <sup>(3,4)</sup> | REN <sup>(3,4)</sup> | WCLK       | RCLK       | Action                                                                                       |
|----|----------------------|----------------------|------------|------------|----------------------------------------------------------------------------------------------|
| L  | X                    | Х                    | —          | —          | No operation.                                                                                |
| L  | L                    | Н                    | $\uparrow$ |            | Write to a programmable register <sup>(1)</sup> .                                            |
| L  | Н                    | Н                    | Ŷ          |            | Hold present value of programmable-register write counter, and do not write <sup>(2)</sup> . |
| L  | Н                    | L                    | —          | ↑          | Read from a programmable register <sup>(1)</sup> .                                           |
| L  | Н                    | Н                    | _          | Ŷ          | Hold present value of programmable-register read counter, and do not read <sup>(2)</sup> .   |
| L  | Х                    | Х                    | $\uparrow$ | $\uparrow$ | Illegal combination, which will cause errors.                                                |
| Н  | L                    | Х                    | $\uparrow$ | Х          | Normal FIFO write operation.                                                                 |
| Н  | Х                    | L                    | Х          | $\uparrow$ | Normal FIFO read operation.                                                                  |
| Н  | L                    | Х                    |            | Х          | No write operation.                                                                          |
| Н  | Н                    | Х                    | Х          | Х          | No write operation.                                                                          |
| Н  | Х                    | L                    | Х          | _          | No read operation.                                                                           |
| Н  | Х                    | Н                    | Х          | Х          | No read operation.                                                                           |
| Н  | L                    | L                    |            | —          | No operation.                                                                                |
| Н  | Н                    | Н                    | Х          | Х          | No operation.                                                                                |

Key:

H = Logic HIGH, L = Logic LOW, X = Dont Care (Logic HIGH, Logic LOW, or any transition), ↑ = A LOW-to-HIGH transition; — = Any condition EXCEPT a LOW-to-HIGH transition.

Notes:

- The selection of a programmable register to be written or read is controlled by two simple state machines. One state
  machine controls the selection for writing; the other state machine controls the selection for reading. These two state
  machines operate independently of each other. Both state machines are reset to point to word 0 by a reset operation.
  In the enhanced operating mode, if control register bit 00 is set, both state machines are also rest to point to
  word 0 bit de-assertion of LD after LD has been asserted (that is, by a rising edge of LD), followed by a valid
  memory array write cycle for the writing-control state machine and/or by a valid memory-array read cycle for
  the reading-control state machine.
- The order of the two programmable registers which are accessible in standard operating mode, as selected by either state machine, is always:

Word 0: Almost-empty offset register

Word 1: Almost-full offset register

Word 0: Almost-empty offset register

(Repeats Indefinitely)

The order of the three programmable registers which are accessible in enhanced operating mode, as selected by either state machine, is always:

Word 0: Almost-empty offset register Word 1: Almost-full offset register Word 2: Control register Word 0: Almost-empty offset register

(Repeats Indefinitely)

Note that, in the standard operating mode, word 2 is not accessed, and words 0 and 1 alternate.

- After normal FIFO operation has begun, writing new contents into either of the two offset registers should only be done when the FIFO is empty.
- 4. WEN2, REN2, and OE may be ANDed terms in the enabling of read and write operations, according to the state of the EMODE control input and of control register bit 05.

|                        | read Data Words<br>ithin FIFO <sup>(1,2)</sup> | Full<br>Flag | Middle<br>Flags |    |     | Empty<br>Flags |
|------------------------|------------------------------------------------|--------------|-----------------|----|-----|----------------|
| 512 x 18 FIFO          | 1024 x 18 FIFO                                 | FF           | PAF             | HF | PAE | ĒF             |
| 0                      | 0                                              | Н            | Н               | Н  | L   | L              |
| 1 to q                 | 1 to q                                         | Н            | Н               | Н  | L   | Н              |
| (q + 1) to 256         | (q + 1) to 512                                 | Н            | Н               | Н  | Н   | Н              |
| 257 to [512 – (p + 1)] | 513 to [1024 – (p + 1)]                        | Н            | Н               | L  | Н   | Н              |
| (512 – p) to 511       | (1024 – p) to 1023                             | Н            | L               | L  | Н   | Н              |
| 512                    | 1024                                           | L            | L               | L  | Н   | Н              |

#### **TABLE 4. STATUS FLAGS**

#### Notes:

1. q = Programmable-almost-empty offset values. (Default values: 512 x 18, q = 63; 1024 x 18, q = 127.)

2. p = Programmable-almost-full offset values. (Default values: 512 x 18, p = 63; 1024 x 18, p = 127.)

3. Only 9 (512 x 18) or 10 (1024 x 18) of the 12 offset-value-register bits should be programmed. The unneeded most-significant-end bits should be LOW (zero).

4. The flag output is delayed by one full clock cycle in enhanced operating mode, when synchronous operation is specified for intermediate flags.

#### **TABLE 5. CONTROL-REGISTER FORMAT**

| Command<br>Register<br>Bits | Code  | Value af<br>EMODE<br>= H | ter Reset<br>EMODE<br>= L | Flag<br>Affected,<br>If Any | Description                                                                                                                                                                                                                                                                                | Notes                                                                                                                             |  |
|-----------------------------|-------|--------------------------|---------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| 00                          | L     | L                        | H                         |                             | De-assertion of LD does<br>not reset the program-<br>mable-register write<br>pointer and read pointer.                                                                                                                                                                                     | Standard Addressing of programmable registers.                                                                                    |  |
| 00                          | Н     | L                        | Η                         |                             | De-assertion of LD resets<br>the programmable-<br>register write pointer and<br>read pointer to address<br>word 0, the program-<br>mable-almost-empty-flag-<br>offset register. The<br>change takes effect after<br>a valid write operation or<br>a valid read operation,<br>respectively. | Non-ambiguous addressing<br>of programmable registers.                                                                            |  |
| 01                          | L     | L                        | Н                         | PAE                         | Set by ↑RCLK, reset by<br>↑WCLK.                                                                                                                                                                                                                                                           | Asynchronous flag clock-<br>ing.                                                                                                  |  |
| 01                          | H     | L                        | Н                         | PAE                         | Set and reset by ↑RCLK.                                                                                                                                                                                                                                                                    | Synchronous flag clocking                                                                                                         |  |
| 02, 03                      | LL    | LL                       | НН                        | ĦF                          | Set by <sup>↑</sup> WCLK, reset by<br><sup>↑</sup> RCLK.                                                                                                                                                                                                                                   | Asynchronous flag clock-<br>ing.                                                                                                  |  |
| 02, 03                      | LH    | LL                       | НН                        | ĦF                          | Set and reset by <i>TRCLK</i> .                                                                                                                                                                                                                                                            | Synchronous flag clocking at output port.                                                                                         |  |
| <i>02, 03</i>               | HL,HH | LL                       | НН                        | ĦF                          | Set and reset by <i>TWCLK</i> .                                                                                                                                                                                                                                                            | Synchronous flag clocking at input port.                                                                                          |  |
| 04                          | L     | L                        | Н                         | PAF                         | Set by <sup>↑</sup> WCLK, reset by<br><sup>↑</sup> RCLK.                                                                                                                                                                                                                                   | Asynchronous flag clock-<br>ing.                                                                                                  |  |
| 04                          | Н     | L                        | Н                         | PAF                         | Set and reset by ↑WCLK.                                                                                                                                                                                                                                                                    | Synchronous flag clocking.                                                                                                        |  |
| 05                          | L     | L                        | Н                         | _                           | OE has no effect on an<br>internal operation, apart<br>from disabling the out-<br>puts.                                                                                                                                                                                                    | Allows the read-address<br>pointer to advance even<br>when Q17-Q0 are not<br>driving the output bus.                              |  |
| 05                          | Н     | L                        | Η                         | _                           | <b>OE</b> inhibits a read opera-<br>tion whenever the data<br>outputs Q17-Q0 are in the<br>HIGH-Z state.                                                                                                                                                                                   | Inhibits the read-address<br>pointer from advancing<br>when Q17-Q0 are not<br>driving the bus; thus,<br>guards against data loss. |  |
| 06                          | L     | L                        | L                         |                             | Reserved.                                                                                                                                                                                                                                                                                  | Future use to control depth<br>cascading and interlocked<br>paralleling.                                                          |  |
| 06                          | н     | L                        | L                         |                             | Reserved.                                                                                                                                                                                                                                                                                  |                                                                                                                                   |  |
| 07-11                       | LLLLL | LLLLL                    | LLLLL                     | _                           | Reserved.                                                                                                                                                                                                                                                                                  | Reserved.                                                                                                                         |  |

Notes:

1. When **EMODE** is HIGH, and **control register bits 00-05 are LOW**, the FIFO behaves in a manner functionally equivalent to the IDT72215LB/25LB FIFO of similar depth and speed grade. Under these conditions, the **control register** is not visible or accessible to the external system which includes the FIFO.

2. If **EMODE** is not asserted (is HIGH), control register bits 00-05 remain LOW after a reset operation. However, if **EMODE** is asserted (is LOW) during a reset operation, control register bits 00-05 are forced HIGH, and remain HIGH until changed. Control register bits 06-11 are unaffected by EMODE.

#### DESCRIPTION OF SIGNALS AND OPERATING SEQUENCES

#### **Data Inputs**

#### DATA IN (D17-D0)

Data, programmable flag-offset values, and *control register* codes are input to the FIFO as 18-bit words on D17-D0. Unused bit positions in offset-value and *control register* words should be zero-filled.

#### **Control Inputs**

#### RESET (RS)

The FIFO is reset whenever the asynchronous reset ( $\overline{RS}$ ) input is taken to a LOW state. A reset operation is required after power-up, before the first write operation may occur. The state of the FIFO is fully defined after a reset operation. If the default values which are entered into the programmable flag-offset-value registers **and the control register** by a reset operation are acceptable, then no device programming is required. A reset operation initializes the FIFO's internal read-address and write-address pointers to the FIFO's first physical memory location. The five status flags,  $\overline{FF}$ ,  $\overline{PAF}$ ,  $\overline{HF}$ ,  $\overline{PAE}$ , and  $\overline{EF}$  are updated to indicate that the FIFO is completely empty; thus, the first three of these are reset to HIGH, and the last two are reset to LOW. The flag-offset values for  $\overline{PAF}$  and  $\overline{PAE}$  each are initialized to one-eighth of the depth of a single FIFO, minus one; 63 for a 512-word FIFO, and 127 for a 102-word FIFO. If **EMODE** is not being asserted (i.e., if **EMODE** is HIGH), all the **control register** bits are initialized to configure the FIFO to operate in the standard operating mode. Until a write operation occurs, the data outputs D17-D0 all are LOW whenever  $\overline{OE}$  is LOW.

#### ENHANCED OPERATING MODE (EMODE)

Whenever **EMODE** is asserted during a reset operation, control register bits 00-05 remain HIGH rather than LOW after the completion of the reset operation. Thus, **EMODE** has the effect of activating enhanced-operating-mode features during a reset operation. Subsequently, they may be individually disabled or re-enabled by changing the setting of control register bits. The behavior of these enhanced-operating-mode features is described in Table 5. For permanent enhanced-operating-mode operation, **EMODE** must be grounded; dynamic control of **EMODE** during system operation is not recommended.

Asserting EMODE during a reset operation also causes WXI/WEN2 to be configured as WEN2, and RXI/ REN2 to be configured as REN2, to support interlocked-paralleled operation of two FIFOs "side by side" (see Figure 27).

#### WRITE CLOCK (WCLK)

A rising edge (LOW-to-HIGH transition) of WCLK initiates a FIFO write cycle if  $\overline{LD}$  is HIGH or a programmableregister write cycle if  $\overline{LD}$  is LOW. The 18 data inputs, and all input-side synchronous control inputs, must meet setup and hold times with respect to the rising edge of WCLK. The input-side status flags are meaningful after specified time intervals, following a rising edge of WCLK.

Conceptually, the WCLK input receives a free-running, periodic "clock waveform", which is used to control other signals which are edge-sensitive. However, there actually is not any absolute requirement that the WCLK waveform *must* be periodic. An "asynchronous" mode of operation is in fact possible, if WEN is continuously asserted (that is, is continuously held LOW), and WCLK receives aperiodic "clock" pulses of suitable duration. There likewise is no requirement that WCLK must have any particular synchronization relation to the read clock RCLK. These two clock inputs may in fact receive the same "clock" signal, or they may receive totally different signals, which are not synchronized to each other in any way.

#### WRITE ENABLE (WEN)

Whenever WEN is being asserted (is LOW) and LD is HIGH, and the FIFO is not full, an 18-bit data word is loaded into the effective input register for the memory array at every WCLK rising edge (LOW-to-HIGH transition). Data words are stored into the two-port memory array sequentially, regardless of any ongoing read operation. Whenever WEN is not being asserted (is HIGH), the input register retains whatever data word it contained previously, and no new data word gets loaded into the memory array.

To prevent overrunning the internal FIFO boundaries, further write operations are inhibited whenever the Full flag ( $\overline{FF}$ ) is being asserted (is LOW). If a valid read operation then occurs, upon the completion of that read cycle,  $\overline{FF}$  again goes HIGH after a time twFF, and another write operation is allowed to begin whenever WCLK makes another LOW-to-HIGH transition. Effectively,  $\overline{WEN}$  is overridden by  $\overline{FF}$ ; thus, during normal FIFO operation,  $\overline{WEN}$  has no effect when the FIFO is full.

In the enhanced operating mode, whenever **EMODE** is being asserted (is LOW), **WXI**/WEN2 functions as WEN2, an additional duplicate (albeit assertive-HIGH) write-enable input in order to provide an "Interlocking" mechanism for reliable synchronization of two paralleled FIFOs. To control writing, WEN2 is ANDed with WEN; the logic-AND function (WEN • WEN2) then behaves like WEN in the foregoing description.

#### **READ CLOCK (RCLK)**

A rising edge (LOW-to-HIGH transition) of RCLK initiates a FIFO read cycle if  $\overline{LD}$  is HIGH, or a programmableregister read cycle if  $\overline{LD}$  is LOW. All output-side synchronous control inputs must meet setup and hold times with respect to the rising edge of RCLK. The 18 data outputs, and the output-side status flags, are meaningful after specified time intervals, following a rising edge of RCLK.

Conceptually, the RCLK input receives a free-running, periodic "clock" waveform, which is used to control other signals which are edge-sensitive. However, there actually is not any absolute requirement that the RCLK waveform must be periodic. An "asynchronous" mode of operation is in fact possible, if REN is continuously asserted (that is, is continuously held LOW), and RCLK receives aperiodic "clock" pulses of suitable duration. There likewise is no requirement that RCLK must have any particular synchronization relation to the write clock WCLK. These two clock inputs may in fact receive the same "clock" signal; or they may receive totally different signals, which are not synchronized to each other in any way.

#### READ ENABLE (REN)

Whenever REN is being asserted (is LOW), and the FIFO is not empty, an 18-bit data word is loaded into the output register from the memory array at every RCLK rising edge (LOW-to-HIGH transition). Data words are read from the two-port memory array sequentially, regardless of any ongoing write operation. Whenever REN is not being asserted (is HIGH), the output register retains whatever data word it contained previously, and no new data word gets loaded into it from the memory array.

To prevent overrunning the internal FIFO boundaries, further read operations are inhibited whenever the Empty flag ( $\overline{EF}$ ) is being asserted (is LOW). If a valid write operation then occurs, upon the completion of that write cycle  $\overline{EF}$  again goes HIGH after a time tREF, and another read operation is allowed to begin whenever RCLK makes another LOW-to-HIGH transition. Effectively, REN is overridden by  $\overline{EF}$ ; thus, during normal FIFO operation, REN has no effect when the FIFO is empty.

In the enhanced operating mode, one (or, sometimes two) additional read-enable inputs may be ANDed with  $\overline{REN}$  to control reading, depending on the state of the control register bit 05. The additional read-enable input(s) are REN2 (and  $\overline{OE}$ ).

Whenever EMODE is being asserted (is LOW) RXI/REN2 functions as REN2, an additional duplicate (albeit assertive-HIGH) read-enable input, in order to provide an "interlocking" mechanism for reliable synchronization of two paralleled FIFOs.

Also, if control register bit 05 has been set,  $\overline{OE}$  takes on the extra role of serving as yet another duplicate read-enable input, in addition to its usual function of controlling the FIFO's data outputs, in order to inhibit further read operations whenever the FIFO's data outputs are disabled, and thereby to prevent data loss under some circumstances.

#### OUTPUT ENABLE (OE)

 $\overline{OE}$  is an assertive-LOW, asynchronous, output enable. In the standard operating mode,  $\overline{OE}$  has only the effect of enabling or disabling the data outputs Q17-Q0. That is, disabling Q17-Q0 does not inhibit a read operation for data being transmitted to the output register; the same data will remain available later, when the outputs are again enabled, unless subsequently overwritten. When Q17-Q0 are enabled, each of these 18 data outputs is in a normal HIGH or LOW state, according to the bit pattern of the data word in the output register. When Q17-Q0 are disabled, each of these outputs is in the HIGH-Z (high-impedance) state.

In the enhanced operating mode, if control register bit 05 has been set,  $\overline{OE}$  behaves as an additional read-enable control input, as well as enabling and disabling the data outputs Q17- Q0. Under these circumstances, incrementing the read-address pointer is inhibited whenever Q17-Q0 are in the HIGH-Z state. Thus, "reading" successive words which fail to reach the outputs is prevented, as a safeguard against data loss.

#### LOAD (LD)

The QS72215/25 FIFOs contain *three* 18-bit programmable registers. The contents of these three registers may be loaded with data from the data inputs D17-D0, or read out onto the data outputs Q17-Q0. The first two registers are the programmable flag-offset value registers, for the Programmable Almost-Empty flag ( $\overrightarrow{PAE}$ ) and the Programmable Almost-Full flag ( $\overrightarrow{PAE}$ ), respectively. *The third register is the control register, which includes several configuration-control bits for enhanced-operating-mode features.* 

None of these three registers makes use of all of its available 18 bits. Figure 5 shows which bit positions of each register are operational. The two programmable flag-offset-value registers each contain an offset value in bits 0-8 (QS72215) or 0-9 (QS72225); bits 9-17 (QS72215) or 10-17 (QS72225) are unused. The default values for both offsets are one-eighth of the total number of words in the FIFO memory array minus one: 63 for a 512 x 18 FIFO, and 127 for a 1024 x 18 FIFO.

The *control register* configuration is shown in Figure 5 and in Table 5. For the *control register*, in the standard operating mode, with **EMODE** de-asserted (HIGH), the default value for any operational bit which has not been programmed is zero (LOW). In the enhanced operating mode, with **EMODE** asserted (LOW), the default value for bits 00-05 is HIGH, and the default value for bits 06-11 is LOW.

Whenever  $\overline{\text{LD}}$  and  $\overline{\text{WEN}}$  are simultaneously being asserted (are both LOW), the 18-bit data word from the data inputs D17-D0 is written into the programmable almost-empty flag-offset-value register at the first rising edge (LOW-to-HIGH transition) of the write clock (WCLK) (see Table 3). If  $\overline{\text{LD}}$  and  $\overline{\text{WEN}}$  continue to be simultaneously asserted, another 18-bit data word from the data inputs D17-D0 is written into the programmable almost from the data inputs D17-D0 is written into the programmable almost (WCLK) (see Table 3). If  $\overline{\text{LD}}$  and  $\overline{\text{WEN}}$  continue to be simultaneously asserted, another 18-bit data word from the data inputs D17-D0 is written into the programmable almost-full flag-offset-value register at the second rising edge of WCLK.

What happens next is determined by the state of the **EMODE** control input. If it is de-asserted (HIGH), the next 18-bit word from the data inputs D17-D0 is written back into the programmable almost-empty flag-offset-value register again.



#### FIGURE 5. PROGRAMMABLE REGISTERS

#### **Control-Register Bits**

- 6 Future use to control depth cascading and interlocking paralleling.
- 5 Enables suppressing reading whenever data outputs are enabled.
- 4 Makes PAF synchronous.
- 3 2 Makes HF synchronous. (See the control-register format table for the encoding of bits 02-03.)
- 1 Makes PAE synchronous.
- **0** Selects reinitialized addressing of the programmable registers.

#### Notes:

- 1. Default offset values are  $63_{10} = 3F_{16}$  (QS72215) or  $127_{10} = 7F_{16}$  (QS72225).
- 2. Bits 17-9 (QS72215) or 17-10 (QS72225) of both offset-value registers should in all cases be programmed LOW (zero).
- 3. This bit position is used for offset values in the QS72225 only. In the QS72215, it should always be programmed LOW.
- 4. See the control register format table for the default states of the control register, for EMODE = HIGH (standard operating mode) and for EMODE = LOW (enhanced operating mode). The control register is not accessible in standard operating mode.
- 5. The assertion of **EMODE** (LOW) forces control register bits 00-05 HIGH during a reset operation. After that, these bits may be programmed at will.



= reserved. Do not load with non-zero information.

But, if EMODE is asserted (LOW), then still another 18-bit data word from the data inputs D17-D0 is written into the control register at the third rising edge of WCLK. At the fourth rising edge of WCLK, writing again occurs to the programmable almost-empty flag-offset-value register; and the same three-step writing sequence gets repeated on subsequent WCLK rising edges.

The lower nine bits of these offset-value words are made use of by the 512-word QS72215, and the lower ten bits by the 1024-word QS72225. *Five active bits are used for the control register by both the QS72215 and the QS72225*. There is no restriction on the values which may occur in these offset value and control-register fields. However, reserved bit positions must be encoded LOW in order to maintain forward compatibility.

Writing contents to these two *or three* programmable registers does not have to occur all <u>at one</u> time, or to be effected by one single sequence of steps. Whenever LD is being asserted (is LOW) but WEN is not being asserted (is HIGH), the FIFO's internal programmable-register write-address pointer maintains its present value, without any writing actually taking place at each rising edge of WCLK (see Table 3). Thus, for instance, one or two programmable registers may be written, after which the FIFO may be returned to normal FIFO-array-read/write operation by de-asserting LD (to HIGH).

Likewise, whenever LD and REN are simultaneously being asserted (are both LOW) the 18-bit data word (zerofilled as necessary) from the Programmable Almost-Empty flag-offset-value register is read to the data outputs Q17-Q0 at the first rising edge (LOW-to-HIGH transition) of the read clock (RCLK) (see Table 3). If LD and REN continue to be simultaneously asserted, another 18-bit data word from the programmable almost-full flagoffset-value register is read to the data outputs Q17-Q0 at the second rising edge of RCLK.

What happens next is determined by the state of the **EMODE** control input. If it is de-asserted (HIGH), the next 18-bit word again comes from the programmable Almost-Empty flag-offset-value register; it is read to the data outputs Q17-Q0.

## But, if **EMODE** is asserted (LOW), then the next 18-bit data word instead comes from the control register; it is read to the data outputs Q17-Q0 at the third rising edge of RCLK. At the fourth rising edge of RCLK, reading again occurs from the programmable Almost-Empty flag-offset-value register and the same three-step reading sequence gets repeated on subsequent RCLK rising edges.

Reading contents from these two or *three* programmable registers does not have to occur all at one time, or to be effected by one single sequence of steps. Whenever LD is being asserted (is LOW) but REN is not being asserted (is HIGH), the FIFO's internal programmable register-read-address pointer maintains its present value, without any reading actually taking place at each rising edge of RCLK (see Table 3). Thus, for instance, one or two programmable registers may be read, after which the FIFO may be returned to normal FIFO-array-read/write operation by de-asserting LD (to HIGH).

To ensure correct operation, rising edges of WCLK and RCLK should not both be occurring at the same time while LD is being asserted.

#### FIRST LOAD/RETRANSMIT (FL/RT)

FL/*RT is a dual-purpose signal*. It is one of four input signals which select the grouping mode in which the FIFO operates after being reset; the other three of these input signals are **WXI/WEN2**, **RXI/REN2**, and **EMODE**. *There are four* possible grouping modes: standalone, *interlocked paralleled*, cascaded "master" or "first-load," and cascaded "slave." The designations "master" and "slave" pertain to standard depth cascading. Tables 1 and 2 show the signal encodings which select each grouping mode.

In standalone or paralleled operation, the FL/RT pin should be grounded for strict standard operating mode operation. However, if it is taken HIGH, regardless of the state of the EMODE control input, the FIFO's internal read-address pointer is reset to address the FIFO's first physical memory location, without the other usual reset actions being taken, in particular the FIFO's internal write-address pointer is unaffected. Subsequent read operations may then again read out the same block of data, delimited by the FIFO's first physical memory location and the current value of the write pointer, as was read out previously. There is no limit on the number of times that a block of data may be retransmitted. The only restrictions are that neither the read-address pointer nor the write-address pointer may "wraparound" and address the FIFO's first physical memory location a second time during the retransmission process, and that the retransmit facility is unavailable during cascaded operation.

In standard cascaded operation,  $\overline{FL}/RT$  is grounded to distinguish the "master" or "first-load" FIFO from the other "slave" FIFO's in the cascade, which must all have their  $\overline{FL}/RT$  inputs HIGH during a reset operation. (See again Tables 1 and 2.) The cascade will not operate correctly either without any "master" FIFO, or with more than one "master" FIFO.

#### DESCRIPTION OF SIGNALS AND OPERATING SEQUENCES

#### WRITE EXPANSION INPUT/WRITE ENABLE2 (WXI/WEN2)

WXI/WEN2 is a dual-purpose signal. It is one of four input signals which select the grouping mode in which the FIFO operates after being reset; the other three of these input signals are FL/RT and RXI/REN2 and EMODE. There are *four* possible grouping modes: standalone, *interlocked paralleled*, cascaded "master or "first-load," and cascaded "slave." The designations "master" and "slave" pertain to standard depth cascading. Tables 1 and 2 show the signal encodings which select each grouping mode.

In standalone operation,  $\overline{WXI}/WEN2$  and  $\overline{RXI}/REN2$  both must be grounded so that the FIFO comes up in the standalone grouping mode after a reset operation. In interlocked paralleled operation,  $\overline{WXI}/WEN2$  is tied to  $\overline{FF}$  of the other paralleled FIFO, and  $\overline{RXI}/REN2$  is tied to  $\overline{EF}$  of that same other FIFO. This interconnection scheme ensures that both FIFOs will operate together, and remain coordinated, regardless of timing skews

In cascaded operation,  $\overline{WXI}/WEN2$  is connected to the  $\overline{WXO}$  (write expansion output; actually  $\overline{WXO}/\overline{HF}$ ) output of the previous FIFO in the cascade.  $\overline{RXI}/REN2$  is likewise connected to the  $\overline{RXO}$  (read expansion output; actually  $\overline{RXO}/\overline{EF2}$ ) output of that previous FIFO. A reset operation forces  $\overline{WXO}/\overline{HF}$  and  $\overline{RXO}/\overline{EF2}$  HIGH for each FIFO; consequently, all FIFOs with their  $\overline{WXI}/WEN2$  and  $\overline{RXI}/REN2$  inputs thus connected come up in one of the two cascaded grouping modes, according to whether their  $\overline{FL}/RT$  inputs are grounded or tied HIGH (see again Tables 1 and 2).

#### READ EXPANSION INPUT/READ ENABLE 2 (RXI/REN2)

RXI/*REN2* is a dual-purpose signal. It is one of four input signals which select the grouping mode in which the FIFO operates after being reset; the other three of these input signals are FL/*RT* and WXI/*WEN2 and EMODE*. There are four possible grouping modes: standalone, *interlocked paralleled*, cascaded "master" or "first-load," and cascaded "slave." The designations "master" and "slave" pertain to standard depth cascading. Tables 1 and 2 show the signal encodings which select each grouping mode.

In standalone operation,  $\overline{WXI}/WEN2$  and  $\overline{RXI}/REN2$  both must be grounded so that the FIFO comes up in the standalone grouping mode after a reset operation. In interlocked paralleled operation,  $\overline{WXI}/WEN2$  is tied to  $\overline{FF}$  of the other paralleled FIFO, and  $\overline{RXI}/REN2$  is tied to  $\overline{EF}$  of that same other FIFO. This interconnection scheme ensures that both FIFOs will operate together and remain coordinated, regardless of timing skews.

In cascaded operation, RXI/REN2 is connected to RXO (read expansion output; actually RXO/EF2) of the previous FIFO in the cascade. WXI/WEN2 is likewise connected to WXO (write expansion output; actually WXO/HF) output of that previous FIFO. A reset operation forces RXO/EF2 and WXO/HF HIGH for each FIFO; consequently, all FIFOs with their RXI/REN2 and WXI/WEN2 inputs thus connected come up in one of the two standard cascaded grouping modes, according to whether their FL/RT inputs are grounded or tied HIGH (see again Tables 1 and 2).

#### **Data Outputs**

#### DATA OUT (Q17-Q0)

Data, programmable flag-offset values, and *control register* codes are output from the FIFO as 18-bit words on Q17-Q0. Unused bit positions in offset-value words and *control-register* words are zero-filled.

#### **Control/Status Outputs**

#### FULL FLAG (FF)

FF goes LOW whenever the FIFO is completely full. That is, whenever the FIFO's internal write pointer has completely caught up with its internal read pointer; so that, if another word were to be written, it would have to overwrite the unread word which is now in position for reading out by the next requested read operation. Under these conditions, the FIFO is filled to its nominal capacity, which is 512 18-bit words for the QS72215 or 1024 18-bit words for the QS72225. Write operations are inhibited whenever FF is LOW, regardless of the assertion or de-assertion of Write Enable (WEN).

If the FIFO has been reset by asserting  $\overline{RS}$  (LOW),  $\overline{FF}$  initially is HIGH. But, whenever no read operations have been performed since the completion of the reset operation,  $\overline{FF}$  goes LOW after 512 write operations for the QS72215, or after 1024 write operations for the QS72225 (see Table 4).

FF gets updated after a LOW-to-HIGH transition of the write clock (WCLK).

#### PROGRAMMABLE ALMOST-FULL FLAG (PAF)

PAF goes LOW whenever the FIFO is "almost" full; that is, whenever subtracting the value of the FIFO's internal read pointer from the value of its internal write pointer yields a difference which is less than the value of the programmable almost-full flag offset "p." The subtraction is performed using modular arithmetic, modulo the total nominal number of 18-bit words in the FIFO's physical memory, which is 512 for the QS72215 or 1024 for the QS72225.

The default value of "p" after the completion of a reset operation is one-eighth of the total number of words in the FIFO-memory array, minus one: 63 for the QS72215 or 127 for the QS72225. However, "p" may be set to any value which does not exceed this total nominal number of words for the device, as explained in the description of load ( $\overline{LD}$ ).

If the FIFO has been reset by asserting  $\overline{RS}$  (LOW), and no read operations have been performed since the completion of the reset operation,  $\overline{PAF}$  goes LOW after 512 – p write operations for the QS72215, or after 1024–p write operations for the QS72225 (see Table 4).

If "p" is still at its default value, PAF is LOW whenever the FIFO is from seven-eighths full to completely full.

In the standard operating mode, PAF changes from HIGH to LOW only after a LOW-to-HIGH transition of the Write Clock WCLK, and from LOW to HIGH only after a LOW-to-HIGH transition of the read clock RCLK. Thus, in this operating mode, PAF behaves as an "asynchronous flag."

In the enhanced operating mode, on the other hand, PAF gets updated only after a LOW-to-HIGH transition of the write clock WCLK, and thus behaves as a "synchronous flag" whenever control register bit 04 is HIGH (see Table 5).

#### WRITE EXPANSION OUT/HALF-FULL FLAG (WXO/HF)

 $\overline{\text{WXO}/\text{HF}}$  is a dual-purpose signal. In "standalone" operation, it behaves as a Half-Full flag ( $\overline{\text{HF}}$ ), in accordance with Table 4. In standard "cascaded" operation, it behaves as a write expansion output ( $\overline{\text{WXO}}$ ) signal to coordinate writing operations with the next FIFO in the cascade. Under these same conditions, also, the dual-purpose  $\overline{\text{WXI}}/\overline{\text{WEN2}}$  and  $\overline{\text{RXI}}/\overline{\text{REN2}}$  inputs behave as write expansion input ( $\overline{\text{WXI}}$ ) and read expansion input ( $\overline{\text{RXI}}$ ) signals, respectively.

When two or more QS72215 or QS72225 FIFOs are "cascaded" to operate as a deeper "effective FIFO," in a "daisy chain" ring configuration, the write expansion input (WXI) of each FIFO is connected to WXO of the previous FIFO in the ring, with WXI of the "first-load" or "master" FIFO being connected to WXO of the last FIFO so as to complete the ring. Similar connections are made for each FIFO in the ring, parallel to these WXO-to-WXI connections, for read expansion input (RXI) and read expansion output (RXO/**EF2**, when it is behaving as  $\overline{RXO}$ ).

When the last physical location has been written in a FIFO operating in cascaded mode, a LOW-going pulse is emitted by that FIFO on its WXO output, and the FIFO is deactivated for writing at the next valid WCLK; and the next FIFO in the ring is simultaneously activated for writing. Otherwise, WXO remains constantly HIGH whenever the FIFO is operating in cascaded mode. This LOW-going WXO pulse serves as a write token" in the "token-passing" FIFO-cascading scheme; it is passed on to the next FIFO in the ring via its WXI input. When this next FIFO receives the write token, it is activated for writing at the next valid WCLK.

The foregoing description applies both to the "first-load" or "master" FIFO in the ring, and to any and all "slave" FIFOs in the ring. However, WXO has no necessary function for FIFO's operating in the "standalone" mode. Consequently, in that mode, the same output pin is used for HF; it follows that HF is not available as an output from any FIFO which is operating in the standard cascaded mode. A FIFO is initialized into "cascaded master" mode, into "cascaded slave" mode, *into interlocked paralleled* mode, or into standalone mode according to the state of its WXI/*WEN2*, RXI/*REN2*, and FL/*RT* control inputs during a reset operation, *and of EMODE* (see Table 1, Table 2, and Table 5).

In standalone *or interlocked paralleled* operation,  $\overline{\text{HF}}$  goes LOW whenever the FIFO is more than half full; that is, whenever subtracting the value of the FIFO's internal read pointer from the value of its internal write pointer yields a difference which is less than half of the total nominal number of 18-bit words in the FIFO's physical memory, which is 256 for the QS72215 or 512 for the QS72225 (see Table 4). The subtraction is performed using modular arithmetic, this total nominal number of words, which is 512 for the QS72215 or 1024 for the QS72225.

If the FIFO has been reset by asserting  $\overline{RS}$  (LOW), and it is operating in standalone mode or in *interlocked paralleled* mode, and no read operations have been performed since the completion of the reset operation, HF goes LOW after 257 write operations for the QS72215, or after 513 write operations for the QS72225 (see again Table 4).

In the standard operating mode, HF changes from HIGH to LOW only after a LOW-to-HIGH transition of the write clock WCLK, and from LOW to HIGH only after a LOW-to-HIGH transition of the read clock RCLK. Thus, in this operating mode, HF behaves as an "asynchronous flag."

In the enhanced operating mode, on the other hand.  $\overline{\text{HF}}$  gets updated only after a LOW-to-HIGH transition of the read clock RCLK, or else after a LOW-to-HIGH transition of the write clock WCLK, according to the setting of bits 03 and 02 of the control register (see Table 5). Thus, in this mode,  $\overline{\text{HF}}$  behaves as a "synchronous flag," and may be synchronized either to the input side of the FIFO (i.e., to WCLK), or to the output side of the FIFO (i.e., to RCLK).

**BOLD ITALIC = ENHANCED OPERATING MODE** Standard Operating Mode = IDT-Compatible

#### PROGRAMMABLE ALMOST-EMPTY FLAG (PAE)

PAE goes LOW whenever the FIFO is "almost empty"; that is, whenever subtracting the value of the FIFO's internal write pointer from the value of its internal read pointer yields a difference which is less than q + 1, where "q" is the value of the programmable almost-empty flag offset. The subtraction is performed using modular arithmetic, modulo the total nominal number of 18-bit words in the FIFO's physical memory, which is 512 for the QS72215 or 1024 for the QS72225.

The default value of "q" after the completion of a reset operation is one-eighth of the total number of words in the FIFO-memory array, minus one; 63 for the QS72215 or 127 for the QS72225. However, "q" may be set to any value which does not exceed this total nominal number of words for the device, as explained in the description of Load ( $\overline{LD}$ ).

If the FIFO has been reset by asserting  $\overline{RS}$  (LOW), and no write operations have been performed since the completion of the reset operation, then  $\overline{PAE}$  is LOW (see Table 4). If "q" is still at its default value,  $\overline{PAE}$  is LOW whenever the FIFO is from one-eighth full to completely empty.

In the standard operating mode, PAE changes from HIGH to LOW only after a LOW-to-HIGH transition of the read clock RCLK, and from LOW to HIGH only after a LOW-to-HIGH transition of the write clock WCLK. Thus, in this operating mode, PAE behaves as an "asynchronous flag."

In the enhanced operating mode, on the other hand, PAE gets updated only after a LOW-to-HIGH transition of the read clock RCLK, and thus behaves as a "synchronous flag" whenever control register bit 01 is HIGH (see Table 5).

#### EMPTY FLAG (EF)

EF goes LOW whenever the FIFO is completely empty, that is, whenever the FIFO's internal read pointer has completely caught up with its internal write pointer; so that, if another word were to be read out, it would have to come from the physical memory location which is now in position to be written into by the next requested write operation. Read operations are inhibited whenever EF is LOW, regardless of the assertion or deassertion of read enable (REN).

If the FIFO has been reset by asserting  $\overline{RS}$  (LOW), and no write operations have been performed since the completion of the reset operation, then  $\overline{EF}$  is LOW (see Table 4).  $\overline{EF}$  gets updated after a LOW-to-HIGH transition of the read clock RCLK.

#### READ EXPANSION OUT/EMPTY FLAG 2 (RXO/EF2)

When two or more QS72215 or QS72225 FIFOs are operating in standard "cascaded" mode as a deeper "effective FIFO," the dual-purpose RXI/*REN2* and WXI/WEN2 inputs behave as read expansion input (RXI) and write expansion input (WXI) signals respectively. A cascade of these FIFO devices has a "daisy-chain" ring configuration; the read expansion input (RXI) of each FIFO is connected to RXO/*EF2* behaving as RXO) of the previous FIFO in the ring, with RXI of the "first-load" or "master" FIFO being connected to RXO of the last FIFO so as to complete the ring. Similar connections are made for each FIFO in the ring, parallel to these RXO-to-RXI connections, for write expansion input (WXI) and write expansion output (WXO).

When the last physical location has been read in a FIFO operating in standard-style cascaded mode, a LOW-going pulse is emitted by that FIFO on its RXO output; otherwise, RXO remains constantly HIGH. This LOW-going RXO pulse serves as a "read token" in the token-passing FIFO-cascading scheme; it is passed on to the next FIFO in the ring via its RXI input. When this next FIFO receives the token, it is activated for reading at the next valid RCLK.

After a FIFO emits an  $\overline{\text{RXO}}$  pulse, the FIFO is deactivated for reading at the next valid RCLK. Also, its data outputs go into HIGH-Z state, regardless of the assertion or deassertion of its output enable ( $\overline{\text{OE}}$ ) control input, until it again receives the token. Simultaneously, the next FIFO in the ring is activated for reading.

The foregoing description applies both to the "first-load" or "master" FIFO in the ring, and to any and all "slave" FIFOs in the ring. However, RXO has no necessary function for a FIFO which is operating in "standalone" mode. Consequently, in that mode, RXO is never asserted, and remains constantly HIGH. A FIFO is initialized into "standalone" mode, into "cascaded master" mode, or into "cascaded slave" mode according to the state of its WXI/WEN2, RXI/REN2, and FL/RT control inputs during a reset operation. *It also may be forced into interlocked paralleled mode by EMODE (see Table 1, Table 2, and Table 5).* 

#### **TIMING DIAGRAMS**

#### FIGURE 6. RESET TIMING



Notes:

1. After reset, the outputs will be LOW if  $\overline{OE}$  = LOW, and in a high-impedance state if  $\overline{OE}$  = HIGH. 2. The clocks (RCLK, WCLK) may be free running during a reset operation.





Note:

 t<sub>SKEW1</sub> is the minimum time between a rising RCLK edge and a rising WCLK edge for FF to change predictably during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than t<sub>SKEW1</sub>, then it is not guaranteed that FF will change state until the next following WCLK edge.





Note:

 t<sub>SKEW2</sub> is the minimum time between a rising WCLK edge and a rising RCLK edge for EF to change predictably during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than t<sub>SKEW2</sub>, then it is not guaranteed that EF will change state until the next following RCLK edge.

#### FIGURE 9. LATENCY FOR THE FIRST DATA WORD AFTER A RESET OPERATION, WITH SIMULTANEOUS READ AND WRITE



#### Notes:

- 1.  $t_{SKEW2}$  is the minimum time between a rising RCLK edge and a rising WCLK edge for FF to change predictably during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than  $t_{SKEW2}$ , then it is not guaranteed that FF will change state until the next following WCLK edge.
- 2. t<sub>FRL</sub> (first-read latency) is the minimum time between a rising WCLK edge and a rising RCLK edge to assure a correct readout of the first data word D<sub>0</sub> in response to the next RCLK edge. Thus, t<sub>FRL</sub> = t<sub>CLK</sub> + t<sub>SKEW2</sub>. If t<sub>FRL</sub> is not met, D<sub>0</sub> may be available either at t<sub>CLK</sub> + t<sub>SKEW2</sub>, or after one more clock cycle delay at 2 t<sub>CLK</sub> + t<sub>SKEW2</sub>. The first-read latency timing restrictions apply only when the FIFO has been empty ( $\overline{EF} = LOW$ ).
- 3.  $\overline{\text{EF}}$  may be used to determine when the first data word D<sub>0</sub> may be read. D<sub>0</sub> always is available on the next cycle after  $\overline{\text{EF}}$  has gone HIGH.

#### FIGURE 10. FULL FLAG TIMING



#### Note:

 t<sub>SKEW1</sub> is the minimum time between a rising RCLK edge and a rising WCLK edge for FF to change predictably during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than t<sub>SKEW1</sub>, then it is not guaranteed that FF will change state until the next following WCLK edge.

#### FIGURE 11. EMPTY FLAG TIMING



#### Notes:

- t<sub>SKEW2</sub> is the minimum time between a rising WCLK edge and a rising RCLK edge for EF to change predictably during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than t<sub>SKEW2</sub>, then it is not guaranteed that EF will change state until the next following RCLK edge.
- 2. t<sub>FRL</sub> (first-read latency) is the minimum time between a rising WCLK edge and a rising RCLK edge to assure a correct readout of the first data word D<sub>0</sub> in response to the next RCLK edge. Thus, t<sub>FRL</sub> = t<sub>CLK</sub> + t<sub>SKEW2</sub>. If t<sub>FRL</sub> is not met, D<sub>0</sub> may be available either at t<sub>CLK</sub> + t<sub>SKEW2</sub>, or after one more clock cycle delay at 2 t<sub>CLK</sub> + t<sub>SKEW2</sub>. The first-read latency timing restrictions apply only when the FIFO has been empty ( $\overline{\text{EF}}$  = LOW).
- 3.  $\overline{\text{EF}}$  may be used to determine when the first data word D<sub>0</sub> may be read. D<sub>0</sub> always is available on the next cycle after  $\overline{\text{EF}}$  has gone HIGH.





#### FIGURE 13. PROGRAMMABLE-REGISTER READ OPERATION



### FIGURE 14. PROGRAMMABLE ALMOST-EMPTY FLAG TIMING (Standard operating mode)



Note:

1.  $\overline{PAE}$  offset = q. Also, number of data words written into FIFO already = q.

#### FIGURE 15. PROGRAMMABLE-ALMOST-EMPTY FLAG TIMING When Synchronous (Enhanced operating mode)



Enhanced Operating Mode Timing Diagram

#### Notes:

- 1. t<sub>SKEW2</sub> is the minimum time between a rising WCLK edge and a rising RCLK edge for PAE to change predictably during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than t<sub>SKEW2</sub>, then it is not guaranteed that PAE will change state until the next following RCLK edge.
- 2.  $\overrightarrow{PAE}$  offset = q. Also, number of data words written into FIFO already = q.
- 3. The internal state of the FIFO:
  - At (A), q + 1 words.
  - At (B), q words.
  - At (C), q + 1 words again.

#### FIGURE 16. PROGRAMMABLE ALMOST-FULL FLAG TIMING (Standard operating mode)



Notes:

- PAF offset = p. Number of data words written into FIFO already = 511 p for the QS72215 and 1023 p for the QS72225.
   512 p words in FIFO for QS72215. 1024 p words in FIFO for QS72225.
   511 p words in FIFO for QS72215. 1023 p words in FIFO for QS72225.

#### FIGURE 17. PROGRAMMABLE ALMOST-FULL FLAG TIMING WHEN SYNCHRONOUS (Enhanced operating mode)



#### Enhanced Operating Mode Timing Diagram

#### Notes:

- t<sub>SKEW1</sub> is the minimum time between a rising RCLK edge and a rising WCLK edge for PAF to change predictably during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than t<sub>SKEW1</sub>, then it is not guaranteed that PAF will change state until the next following WCLK edge.
- PAF offset = p. Number of data words written into FIFO already = 511 p for the QS72215 and 1023 - p for the QS72225.
- 3. 512 p words in FIFO for QS72215. 1024 p words in FIFO for QS72225.
- 4. 511 p words in FIFO for QS72215. 1023 p words in FIFO for QS72225.
- 5. The internal state of the FIFO:
  - At (A), 511 p words.
  - At (B), 512 p words.
  - At (C), 511 p words again.



#### FIGURE 18. HALF-FULL FLAG TIMING (Standard operating mode)

# FIGURE 19. HALF-FULL FLAG TIMING, WHEN SYNCHRONIZED TO INPUT PORT (Enhanced operating mode)



#### Enhanced Operating Mode Timing Diagram

Notes:

- t<sub>SKEW1</sub> is the minimum time between a rising RCLK edge and a rising WCLK edge for HF to change predictably during the current clock cycle. If the time between the rising edge of RCLK and the rising edge of WCLK is less than t<sub>SKEW1</sub>, then it is not guaranteed that HF will change state until the next following WCLK edge.
- 2. The internal state of the FIFO:
  - At (A), exactly half full.
  - At (B), half+1 words.
  - At (C), exactly half full again.

# FIGURE 20. HALF-FULL FLAG TIMING, WHEN SYNCHRONIZED TO OUTPUT PORT (Enhanced operating mode)





#### Notes:

- t<sub>SKEW2</sub> is the minimum time between a rising WCLK edge and a rising RCLK edge for HF to change predictably during the current clock cycle. If the time between the rising edge of WCLK and the rising edge of RCLK is less than t<sub>SKEW2</sub>, then it is not guaranteed that HF will change state until the next following RCLK edge.
- 2. The internal state of the FIFO:
  - At (A), half+1 words.
  - At (B), exactly half full.
  - At (C), half+1 words again.

**BOLD ITALIC = ENHANCED OPERATING MODE** Standard Operating Mode = IDT-Compatible



- 1. It is not necessary for  $\overline{\text{REN}}$  to be LOW for the device to recognize a retransmit request.
- In order to actually read data words from the memory arrary, in IDT-compatible operating mode, REN = LOW; in enhanced operating mode, also <u>REN<sub>2</sub></u> = HIGH (and OE = LOW, if control register bit 05 = HIGH). In any case, LD = HIGH.
- 3. D<sub>RT1</sub> is the data item in physical location zero of the FIFO memory array.

FIGURE 21. RETRANSMIT TIMING

- 4. The asynchronous intermediate flags (corresponding to LOW control-register bits) will show correct status three RCLK cycles after a retransmit operation, as is shown above. (RT<sub>3</sub>, in the above RCLK waveform.)
- The intermediate flags which have been synchronized to RCLK by setting the appropriate control-register bits to HIGH will show correct status after (B), four RCLK cycles after a retransmit operation. (RT<sub>4</sub>, in the above RCLK waveform.)
- 6. The intermediate flags which have been synchronized to WCLK, by setting the appropriate control-register bits HIGH, will show correct status on the second WCLK rising edge after (A), assuming that t<sub>SKEW1</sub> was satisfied at (A); otherwise the flags will become valid on the third WCLK rising edge after (A).
- 7. Immediately after a reset operation, before any write operations have taken place, a retransmit operation is a "no-op," and does not change the state of any FIFO registers or flags.
- In the special case that the FIFO memory array contains only one valid data item, the status
  of HF and PAF should be ignored on a retransmit.





Note: Write to last physical location.

# FIGURE 23. READ-EXPANSION-OUT TIMING (Standard operating mode)



**Note:** Read from last physical location.

# FIGURE 24. WRITE-EXPANSION-IN TIMING (Standard operating mode)



#### FIGURE 25. READ-EXPANSION-IN TIMING (Standard operating mode)



#### **APPLICATIONS INFORMATION**

#### **Standalone Configuration**

When depth cascading is not required for a given application, the QS72215/25 is placed in standalone mode by tying the two expansion in pins WXI/WEN2 and RXI/REN2 to ground, while also holding the first load/ retransmit pin FL/RT LOW for the duration of any reset operation (see Table 1). Subsequently, FL/RT may be taken HIGH at will, whenever a retransmit operation is desired. If not being used, FL/RT also may be tied to ground, as shown in Figure 26.

#### Width Expansion

Word-width expansion is implemented by placing multiple QS72215/25 devices in parallel. Each device should be configured for standalone mode, unless the depth of one single FIFO is not adequate for the application. In this event, word-width expansion may in principle be used with either of the two depth-cascading schemes supported by the QS72215/25 architecture. In practice, the reliability benefits of interlocked-paralleled operation are available only with the pipelining scheme, making it the preferred alternative. (Refer to discussion in a later section).

# FIGURE 26. STANDARD FIFO (512 x 18/1024 x 18)



When standalone-mode QS72215/25 devices are paralleled, 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. After writing or reading have been in a disabled state, the process of re-enabling should be gated by the slowest FIFO.

For m paralleled FIFOs, the form of this external composite-flag logic may be an OR gate with m assertive-LOW inputs and an assertive-LOW output. In keeping with deMorgan's theorem, such a gate may be implemented as an AND gate with m assertive-HIGH inputs and an assertive-HIGH output. Figure 27 illustrates the case m = 2.

The QS72215/25 architecture supports two very different methods of depth cascading:

- Token passing, which follows the scheme used in the pin-compatible and functionally-compatible Integrated Device Technology IDT72205/15/25/35/45 FIFOs, which the QS72215/25 can directly replace.
- Pipelining, which follows the scheme used in the Texas Instruments SN74ACT7801/11/81 FIFOs, and also in the Sharp LH543620 1024 x 36 FIFO. The SN74ACT7801/11/81 pinout closely resembles the pinout for the QS72215/25, but is not identical.

#### **Depth Cascading Using Token Passing**

Using the token-passing approach, depth cascading is implemented by configuring the required number of QS72215/25's in a circular "ring" fashion, with the expansion out outputs (WXO/HF and RXO/**EF2**) of each device tied to the expansion in inputs (WXI/**WEN2** and **RXI**/**REN2**) of the next device (see Figure 28). Because a reset operation forces the WXO/HF and RXO/**EF2** outputs HIGH for each device, the WXI/**WEN2** and **RXI**/**REN2** inputs for the next device are HIGH during the reset operation; thus, these two inputs are HIGH for all devices in the ring (see Tables 1 and 2, and also Figure 28). All devices in the cascade must be in the standard operating mode; thus, their **EMODE** inputs must be tied to Vcc.

One FIFO in the cascade must be designated as the "first-load" device, by tying its first load input ( $\overline{FL}/RT$ ) to ground. All other devices must have their  $\overline{FL}/RT$  inputs tied HIGH. Under these circumstances, the retransmit function is not available for use.

In this mode, the control inputs which govern writing (WCLK and WEN) and the control inputs which govern reading (RCLK and REN) are shared by all devices, while logic within each QS72215/25 governs the steering of data. The common data inputs of all devices are tied together; but only one QS72215/25 is enabled during any given write cycle. Likewise, the common three-state data outputs of all devices are wire-ORed together; but only one QS72215/25 is enabled, including its three-state outputs, during any given read cycle. A data word is handled by only one device as it passes through the cascade of FIFOs, regardless of how many FIFOs are being cascaded together.

In the token-passing depth-cascaded mode, external logic should be used to generate a composite Full flag and a composite Empty flag, by ANDing the  $\overline{FF}$  outputs of all QS72215/25 devices together and by ANDing the  $\overline{EF}$  outputs of all devices together, using AND gates with assertive-LOW inputs and an assertive-LOW output. Here, the meaning of these composite flags is direct: the cascade of FIFOs is full, if and only if all k-FIFOs belonging to the cascade are individually full; and similarly for empty. In keeping with deMorgan's theorem, these k-input assertive-LOW AND gates are implemented physically as k-input assertive-HIGH OR gates. Figure 28 illustrates the case k = 3.

Similar external logic also may be used to generate a composite Programmable Almost-Full flag and a composite Programmable Almost-Empty flag, by ANDing the **PAF** outputs of all QS72215/25 devices together and by ANDing the **PAE** outputs of all devices together. Here, however, some careful analysis is required to determine exactly what the resulting composite flags mean. Their significance may vary widely, depending on the number of FIFOs in the cascade, and on the "offset" values which are present in the offset registers for these FIFOs. More complex logical combinations of **PAF** outputs with **FF** outputs, and of **PAE** outputs with **FF** outputs, may be found useful in particular applications.

In any case, the Half-Full flag and the retransmit function are not available for devices being used in tokenpassing depth-cascaded mode.







# FIGURE 28. SYNCHRONOUS-FIFO DEPTH-CASCADING USING STANDARD OPERATING MODE "TOKEN-PASSING" SCHEME

Notes :

Grounding FL designates the "first-load" FIFO ("master" FIFO). The remaining FIFOs are "slave" FIFOs. BOLD ITALIC = Enhanced Operating Mode.

#### **Depth Cascading Using Pipelining**

Using the pipelining approach, depth cascading is implemented by connecting the required number of QS72215/25s in series. Within the cascade, the data outputs of each device are connected to the data inputs of the next device (see Figure 29a). All devices in the cascade must be in *the enhanced operating mode*; thus, their *EMODE* inputs must be grounded.

Successive devices in the cascade are crosscoupled; they control each other, using a "handclasp" scheme for crossconnecting their control inputs and their status outputs (see again Figure 29a). The input side of the first device, and the output side of the last device are not crosscoupled to other devices. Their control/status and clock pins are connected to the external system.

For the FIFO devices within the cascade, transferring data from each device to the next device is governed by a clock. Preferably, the same clock should be used at every FIFO-to-FIFO data-transfer interface boundary within the cascade. This "transfer clock" may be either the external write clock or the external read clock. If both of these two clocks are periodic and free-running, the faster of the two is the obvious choice for the "transfer clock." Of course, in principle, the "transfer clock" may even be some other, totally different clock.

The Empty flag of each device is used to govern writing into the next device, and the Full flag of each device is used to govern reading from the preceding device. Since the standard Empty flag EF occurs one RCLK cycle too early to properly enable/disable the next device, the duplicate Empt flag (EF2) is used instead; EF2 is an exact copy of EF, except that it is delayed by one full RCLK cycle with respect to EF.

Also, since the usual enable signals  $\overline{\text{WEN}}$  and  $\overline{\text{REN}}$  have the wrong polarity to function properly in this "handclasp" mode, they are grounded for all devices within the cascade. *The duplicate but inverted signals WEN2 and REN2 are used instead.* 

# **EF2**, WEN2, and REN2 are available only in enhanced operating mode. They share the same pins which in standard operating mode are used respectively for **RXO**, **WXI**, and **RXI**. Hence, for pipelined operation, all devices in the cascade must be in the enhanced operating mode; their **EMODE** control inputs must be grounded.

When all of the foregoing conditions have been met in the interconnection of the pipelined array, then: At each device-to-device interface boundary within the array, a data word is transferred from the upstream device to the downstream device after *every* transfer-clock rising edge, as long as the upstream device is not empty and the downstream device is not full.

There is one possible anomalous behavior, which can occur if at any time the device upstream from a FIFOto-FIFO boundary ("device n - 1") becomes totally empty, at the same time as the downstream device ("device n") becomes totally full. Under these relatively infrequent conditions, one extra copy of the last word transferred out of device n - 1, which remains still available at the outputs of that device, gets introduced into the data stream. The simple circuit illustrated in Figure 29b avoids introducing this extra word and does not slow down the operation of the pipeline if it is implemented with logic which is sufficiently fast. Table 6 indicates the speed requirements for this circuit which correspond to the various speed grades of QS72215/25. If the infrequent introduction of such an extra word is not of concern for a given cascaded-QS72215/25 application, the circuit of Figure 29b may safely be omitted.

Two PLDs (programmable logic devices) suffice to implement the circuit of Figure 29b ten times, which allows for the cascading of QS72215/25s eleven deep. The choice of a GAL20RA10B-10 PLD to implement the flip-flop and the two AND gates at its inputs, and a GAL22V10C-5 PLD to implement the simple AND gate which follows the flip-flop, provides a sufficiently fast circuit to allow a cascade of QS72215/25-20 devices (the fastest speed grade presently offered by QSI) to operate with no speed degradation. Designers experienced in using PLDs may recognize other implementations.

The GAL20RA10B and GAL22V10C PLDs each provide ten macrocells. One macrocell may be configured to operate as a simple inverting or non-inverting buffer, a simple NAND or AND gate, an AND-OR gate, or a flip-flop with an AND-OR input structure. The GAL20RA10B macrocell architecture in particular supports the implementation of an asynchronous-set/reset clocked D flip-flop like the one shown in Figure 29b, except for some polarity differences at certain points within the logic diagram. If a slower implementation of the final AND gate can be tolerated in a given application, a single GAL20RA10B may be used to implement the circuit of

# TABLE 6.REQUIRED EXTERNAL-LOGIC SPEEDS FOR<br/>PIPELINED DEPTH-CASCADING OPERATION<br/>AT MAXIMUM RATE OF SPEED GRADE.

|                   | SPEED GRADE (Cycle Time) |         |         |
|-------------------|--------------------------|---------|---------|
|                   | 20 ns                    | 25 ns   | 35 ns   |
| TA <sup>(1)</sup> | ≤ 8 ns                   | ≤ 10 ns | ≤ 15 ns |
| TB <sup>(2)</sup> | ≤ 15 ns                  | ≤ 19 ns | ≤ 28 ns |

#### Notes:

- 1. TA is the setup time for the signal "FF (Device n)," including the delay of the assertive-LOW AND gate, with respect to the clock.
- 2. TB is the clock-to-output time for the signal "WEN2 (Device n)," including the delay of the assertive-HIGH AND gate.

Figure 29b five times, thus allowing for a cascade six FIFOs deep, with no second PLD being necessary. The GAL20RA10B and GAL22V10C PLDs are manufactured by Lattice Semiconductor Corporation, 5555 Northeast Moore Court, Hillsboro, OR 97124, USA.

#### Width Expansion Along with Depth Cascading

In principle, width expansion may be used with either of the two possible depth-cascading schemes.

However, when using the token-passing depth-cascading scheme, width expansion reduces simply to placing two or more cascades in parallel. In this mode of interconnection, no architectural support is available for interlocked-paralleled operation. Composite-flag logic may, of course, be designed to fit any complete array configuration, to determine meaningful full and empty indications for the entire array. This logic may, for instance, OR the FF and EF signals from the devices at the same relative position in each of the paralleled cascades, and then AND all of the rank-FF signals together; and likewise for all of the rank-EF signals. Then, the entire array is indicated to be full, if all ranks of devices (across the paralleled cascades) are individually full; and, similarly for empty.

When using the pipelined depth-cascading scheme, on the other hand, the first rank of devices (the one which receives input data words from the external system) and the last rank of devices (the one which provides output data words to the external system) may be operated in an interlocked-paralleled manner. Figure 30 shows a suggested interconnection scheme for two paralleled cascades, each three devices deep. The entire array of Figure 30 would comprise a 3072 x 36 "effective FIFO," if implemented with 1024 x 18 QS72225 devices. Whenever the number of paralleled cascades exceeds two, a small amount of external logic is necessary to implement the interlocking.



# FIGURE 29a. TI-STYLE PIPELINED DEPTH-CASCADING

BOLD ITALIC = ENHANCED OPERATING MODE Standard Operating Mode = IDT-Compatible

recommended that the faster of the write clock and the read clock 1. The transfer clock may be any free-running clock. However, it is be used, if both of these are free-running clocks. Block "A" contains the circuit shown in Figure 29b.

сi

# BOLD ITALIC = Enhanced Operating Mode.

# FIGURE 29b. EXTERNAL LOGIC NEEDED FOR TI-STYLE PIPELINED **DEPTH-CASCADING**



Notes:

- 1.  $\overline{AS}$  sets Q=1 regardless of CK or D. (Asynchronous Set)
- AR sets Q=0 regardless of CK or D. (Asynchronous Reset)
  Q=0 occurs if and only if device n–1 goes completely empty and device n goes completely full. Q=0 is
- maintained as long as these conditions persist.
- 3. This circuit is used as block "A" in Figure 29a and in Figure 30.

BOLD ITALIC = Enhanced Operating Mode.



# FIGURE 30. INTERLOCKED PARALLELING USED TOGETHER WITH PIPELINED DEPTH-CASCADING

#### **ORDERING INFORMATION**

# Example:

