## High-Performance FIFO Memories

Unidirectional and Bidirectional

## Data Book

| General Information |  |
| :---: | :---: |
| Unidirectional Clocked FIFOs |  |
|  |  |
| Unidirectional FIFOs |  |

## Bidirectional Clocked FIFOs

Bidirectional FIFOs
 S.

Product Previews
6

Articles and Application Notes
$7^{3}$
7utit

Mechanical Data

# High-Performance FIFO Memories Data Book 

## Unidirectional and Bidirectional 1992

## IMPORTANT NOTICE

Texas Instruments Incorporated (TI) reserves the right to make changes to its products or to discontinue any semiconductor product or service without notice, and advises its customers to obtain the latest version of relevant information to verify, before placing orders, that the information being relied on is current.

TI warrants performance of its semiconductor products and related software to current specifications in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by govemment requirements.

Please be aware that TI products are not intended for use in life-support appliances, devices, or systems. Use of TI product in such applications requires the written approval of the appropriate Tl officer. Certain applications using semiconductor devices may involve potential risks of personal injury, property damage, or loss of life. In order to minimize these risks, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards. Inclusion of TI products in such applications is understood to be fully at the risk of the customer using TI devices or systems.

TI assumes no liability for applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used.

## INTRODUCTION

First-In, First-Out (FIFO) memories from Texas Instruments are valuable data path elements for eliminating bottlenecks and regulating flow. Data transfers in and out of a FIFO memory are independent of one another and allow the device to be the communication medium between two asynchronous systems. Empty and full status flags that prevent underflow and overflow conditions are standard with all devices, and many have programmable almost full/almost empty flags to optimize the control of a particular system.
Each FIFO is constructed with a dual-port SRAM, read and write address incrementing logic, and flag circuitry. Rising-edge-triggered clocks are featured on all TI FIFOs, with self-timed reads and writes on memory that allow a large variance of usable pulse widths. The strobed style of FIFO produced by TI writes data to memory on each low-to-high transition of the load clock (LDCK) input and reads data on each rising edge of the unload clock (UNCK) input.
Tl's clocked style FIFO can also receive asynchronous clocks for writing and reading data, but the clock inputs are designed to be continuous, with the rising edge affecting data transfers when separate enable signals are asserted. This characteristic allows a seamless interface between the device and other high-speed buses or microprocessors with similar control. The availability of the free-running clock also provides the means to synchronize the full and empty status flags for use as reliable control signals and reduce the amount of external support logic. Each TI clocked FIFO has its empty flag synchronized to the read clock and its full flag synchronized to the write clock with at least two flip-flop stages. Clocked FIFOs produced in Advanced CMOS technology can support clock frequencies up to 67 MHz , and the SN74ABT7819, the first FIFO produced in Advanced BiCMOS technology, is capable of speeds up to 80 MHz . The SN74ABT7819 is also a bidirectional FIFO, with two independent FIFO memories combined on one chip to buffer data in opposite directions.

Memory organization of the FIFOs ranges in depth from 16 words to 2048 words and data bit widths of $4,5,8,9$, and 18 . To accommodate the need of reducing the packege area as data widths increase, many TI FIFO memories are offered in shrink surface-mount packages. The SSOP and SQFP packages, with $25-\mathrm{mil}$ and $0.5-\mathrm{mm}$ lead pitch, respectively, can reduce the FIFO-dedicated board area by $70 \%$ over PLCC packages.
Texas Instruments continues to offer leading-edge solutions to customers' needs in both packaging technology and device architecture. This is evidenced by the 120 -pin SQFP with $16 \mathrm{~mm} \times 16 \mathrm{~mm}$ area used to house the upcoming 32- and 36-bit products. With features such as synchronous retransmit, mailbox bypass registers, byte swapping, and bus-width matching, these devices provide a high level of integration in a compact area for applications such as interfacing a digital signal processor (DSP) to a host processor and matching systems with different memory organizations.

## PRODUCT STAGE STATEMENTS

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.
PRODUCT PREVIEW information concerns products in the formative or design phase of development. Characteristic data and other specifications are design goals. Texas Instruments reserves the right to change or discontinue these products without notice.

ADVANCE INFORMATION concerns new products in the sampling or preproduction phase of development. Characteristic data and other specifications are subject to change without notice.
The next statements must be used in combination:
UNLESS OTHERWISE NOTED this document contains PRODUCTION DATA information current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.
If any of the pages contain PRODUCT PREVIEW information, this statement must appear at the lower left on those pages:

PRODUCT PREVIEW information concerns products in the formative or design phase of development. Characteristic data and other specifications are design goals. Texas Instruments reserves the right to change or discontinue these products without notice.
If any of the pages contain ADVANCE INFORMATION, this statement must appear at the lower left on those pages:

ADVANCE INFORMATION concerns new products in the sampling or preproduction phase of development. Characteristic data and other specifications are subject to change without notice.

## Contents

Section 1 - General Information ..... 1-1
Glossary ..... 1-3
Explanation of Function Tables ..... 1-6
D Flip-Flop and Latch Signal Conventions ..... 1-8
Thermal Information ..... 1-9
Section 2 - Unidirectional Clocked FIFOs ..... 2-1
SN74ACT7801
$1024 \times 18$ Clocked First-In, First-Out Memory ..... 2-3
SN74ACT7803
$512 \times 18$ Clocked First-In, First-Out Memory ..... 2-19
SN74ACT7805
$256 \times 18$ Clocked First-In, First-Out Memory ..... 2-33
SN74ACT7807
$2048 \times 9$ Clocked First-In, First-Out Memory ..... 2-47
SN74ACT7811
$1024 \times 18$ Clocked First-In, First-Out Memory With 3-State Outputs ..... 2-63
SN74ACT7813
$64 \times 18$ Clocked First-In, First-Out Memory ..... 2-81
Section 3 - Unidirectional FIFOs ..... 3-1
SN74ACT7802
$1024 \times 18$ Asynchronous First-In, First-Out Memory ..... 3-3
SN74ACT7804
$512 \times 18$ First-In, First-Out Memory ..... 3-15
SN74ACT7806
$256 \times 18$ First-In, First-Out Memory ..... 3-27
SN74ACT7808
$2048 \times 9$ First-In, First-Out Memory ..... 3-39
SN74ACT7814
$64 \times 18$ First-In, First-Out Memory ..... 3-53
SN74ALS229B $16 \times 5$ Asynchronous First-In, First-Out Memory ..... 3-65
SN74ALS232B
$16 \times 4$ Asynchronous First-In, First-Out Memory ..... 3-71
SN74ALS233B
$16 \times 5$ Asynchronous First-In, First-Out Memory ..... 3-75
SN74ALS2232A
$64 \times 8$ Asynchronous First-In, First-Out Memory ..... 3-81
SN74ALS2233A
$64 \times 9$ Asynchronous First-In, First-Out Memory ..... 3-87
Section 4 - Bidirectional Clocked FIFOs ..... 4-1
SN74ABT7819
$512 \times 18 \times 2$ Clocked First-In, First-Out Memory ..... 4-3
Section 5 - Bidirectional FIFOs ..... 5-1
SN74ABT7820
$512 \times 18 \times 2$ First-In, First-Out Memory ..... 5-3
SN74ACT2235
$1024 \times 9 \times 2$ Asynchronous First-In, First-Out Memory ..... 5-17
SN74ACT2236
$1024 \times 9 \times 2$ Asynchronous First-In, First-Out Memory ..... 5-29
SN74ALS2238
$32 \times 9 \times 2$ Asynchronous Bidirectional First-In, First-Out Memory ..... 5-41
Section 6 - Product Previews ..... 6-1
SN74ABT7815
$64 \times 36 \times 2$ Clocked First-In, First-Out Memory With Bus Matching and Byte Swapping ..... 6-3
SN74ABT7816
$64 \times 36 \times 2$ Clocked First-In, First-Out Memory ..... 6-15
SN74ABT7817
$64 \times 36$ Clocked First-In, First-Out Memory With Bus Matching and Byte Swapping ..... 6-17
SN74ABT7818
$64 \times 36 \times 2$ Clocked First-In, First-Out Memory ..... 6-19
SN74ACT2226, SN74ACT2228
Dual $64 \times 1$ and Dual $256 \times 1$ Clocked First-In, First-Out Memories ..... 6-21
SN74ACT2227, SN74ACT2229
Dual $64 \times 1$ and Dual $256 \times 1$ First-In, First-Out Memories ..... 6-31
SN74ACT7821
$512 \times 32 \times 2$ Clocked First-In, First-Out Memory ..... 6-41
SN74ACT7822
$512 \times 36 \times 2$ Clocked First-In, First-Out Memory ..... 6-49
SN74ACT7823
$1024 \times 36$ Clocked First-In, First-Out Memory ..... 6-57
Section 7 - Articles and Application Notes ..... 7-1
64-Byte FIFOs, SN74ALS2232A and SN74ALS2233A ..... 7-3
$1 K \times 9 \times 2$ Asynchronous FIFOs, SN74ACT2235 and SN74ACT2236 ..... 7-9
FIFO Solutions for Increasing Clock Rates and Data Widths ..... 7-17
FIFO Surface-Mount Package Information ..... 7-25
Metastability Performance of Clocked FIFOs ..... 7-33
Section 8 - Mechanical Data ..... 8-1
Ordering Instructions ..... 8-3
DLO28, DL048, and DL056
Plastic Small-Outline Packages ..... 8-4
DW016, DW020, DW024, and DW028 Plastic Small-Outline Packages ..... 8-5
FNO20, FN028, FN044, FN052, FN068, and FN084
Plastic J-Leaded Chip Carriers ..... 8-6
N014, N016, and N02O
300-mil Plastic Dual-In-Line Packages ..... 8-8
N028, N040, NO48, and NO52
600-mil Plastic Dual-In-line Packages ..... 8-9
NT024 and NTO28
600-mil Plastic Dual-In-Line Packages ..... 8-10
PBM120
JEDEC Metric Plastic Quad Flatpack ..... 8-11
PCB120
JEDEC Metric Plastic Shrink Quad Flatpack ..... 8-12
PH080
JEDEC Metric Plastic Quad Flatpack ..... 8-14
PM64, PN80, and PZ100
JEDEC Metric Plastic Shrink Quad Flatpacks ..... 8-15
PQ100, PQ132, and PQ164
JEDEC Plastic Quad Flatpacks ..... 8-17

| General Information | 1 |
| :---: | :---: |
| Unidirectional Cloched FiFos |  |
| Unidiroctional Fifos |  |
| Bidirectional Clocked FIFOs | 14984 |
| Bidirectional Fifosk | 56\% |
| Product Previevis | Q ${ }^{\text {ama }}$ |
| Articles and Application Notes | P54 |
| Mechanical Data | 180, |

## introduction

These symbols, terms, and definitions are in accordance with those currently agreed upon by the JEDEC Council of the Electronic Industries Association (EIA) for use inthe USA and by the International Electrotechnical Commission (IEC) for international use.

## operating conditions and characteristics (in sequence by letter symbols)

$C_{l} \quad$ Input capecitance
The internal capacitance at an input of the device.
Co Output capacitance
The internal capacitance at an output of the device.
$\mathrm{C}_{\mathrm{pd}} \quad$ Power dissipation capacitance
Used to determine the no-load dynamic power dissipation per logic function (see individual circuit pages): $\mathrm{P}_{\mathrm{D}}=\mathrm{C}_{\mathrm{pd}} \mathrm{V}_{\mathrm{Cc}}{ }^{2} \mathrm{f}+\mathrm{I}_{\mathrm{Cc}} \mathrm{V}_{\mathrm{Cc}}$.
$\boldsymbol{f}_{\text {max }} \quad$ Maximum clock frequency
The highest rate at which the clock input of a bistable circuit can be driven through its required sequence while maintaining stable transitions of logic level at the output with input conditions established that should cause changes of output logic level in accordance with the specification.
Icc Supply current
The current into* the $V_{C C}$ supply terminal of an integrated circuit.
$\Delta \mathbf{I}_{\mathbf{c c}} \quad$ Supply current change (ACT devices only)
The increase in supply current for each input that is at one of the specified TTL voltage levels rather than 0 V or $\mathrm{V}_{\mathrm{cc}}$.
$\mathbf{I}_{\mathbf{I H}} \quad$ High-level Input current
The current into* an input when a high-level voltage is applied to that input.
IIL Low-level Input current
The current into* an input when a low-level voltage is applied to that input.
$\mathbf{I O H}_{\mathrm{OH}} \quad$ High-level output current
The current into* an output with input conditions applied that, according to the product specification, will establish a high level at the output.

IOL Low-level output current
The current into* an output with input conditions applied that, according to the product specification, will establish a low level at the output.
Ioz Off-state (high-Impedance-state) output current (of a 3-state output)
The current flowing into* an output having 3 -state capability with input conditions established that, according to the product specification, will establish the high-impedance state at the output.
$t_{a} \quad$ Access time
The time interval between the application of a specified input pulse and the availability of valid signals at an output.

[^0]

# GLOSSARY SYMBOLS, TERMS, AND DEFINITIONS 

## operating conditions and characteristics (continued)

## $t_{\text {su }} \quad$ Setup time

The time interval between the application of a signal at a specified inputterminal and a subsequent active transition at another specified input terminal.
NOTES: 1. The setup time is the actual time interval between two signal events and is determined by the system in which the digital circuit operates. A minimum value is specified that is the shortest interval for which correct operation of the digital circuit is guaranteed.
2. The setup time may have a negative value in which case the minimum limit defines the longest interval (between the active transition and the application of the other signal) for which correct operation of the digital circuit is guaranteed.

| $t_{\text {w }}$ | Pulse duration (wldth) |
| :---: | :---: |
|  | The time interval between specified reference points on the leading and trailing edges of the pulse waveform. |
| $\mathbf{V I H}_{\mathbf{H}}$ | High-level Input voltage |
|  | An input voltage within the more positive (less negative) of the two ranges of values used to represent the binary variables. |
|  | NOTE: A minimum is specified that is the least-positive value of high-level input voltage for which operation of the logic element within specification limits is guaranteed. |
| $\mathrm{V}_{\text {IL }}$ | Low-level Input voltage |
|  | An input voltage within the less positive (more negative) of the two ranges of values used to represent the binary variables. |
|  | NOTE: A maximum is specified that is the most-positive value of low-level input voltage for which operation of the logic element within specification limits is guaranteed. |
| $\mathrm{V}_{\mathrm{OH}}$ | Hlgh-level output voltage |
|  | The voltage at an output terminal with input conditions applied that, according to product specification, will establish a high level at the output. |
| $\mathrm{V}_{\mathbf{C L}}$ | Low-level output yoltace |
|  | The voltage at an output terminal with input conditions applied that, according to product specification, will establish a low level at the output. |
| $\mathbf{V}_{\mathbf{T}+}$ | Positive-going threshold level |
|  | The voltage level at a transition-operated input that causes operation of the logic element according to specification as the input voltage rises from a level below the negative-going threshold voltage, $\mathrm{V}_{\mathrm{T} \text { - }}$ |
| $\mathbf{V}_{\mathbf{T} \text { - }}$ | Negative-going threshold level |
|  | The voltage level at a transition-operated input that causes operation of the logic element according to specification as the input voltage falls from a level above the positive-going threshold voltage, $\mathrm{V}_{\mathrm{T}}$. |

## definitions

## clocked FIFO

A first-in, first-out memory that allows data to be written to its array and read from its array at independent rates. The low-to-high transition of a continous (free-running) write clock stores data in memory when write enable input signals are asserted. The low-to-high and high-to-low transitions of the input ready flag (or full flag) output are synchronous to the rising edge of the write clock. The low-to-high transition of a continous (free-running) read clock reads data from memory when read enable input signals are asserted. The low-to-high and high-to-low transitions of the output ready flag (or empty flag) output are synchronous to the rising edge of the read clock.

## function tables

The following symbols are used in function tables on TI data sheets.

| H | high level (steady state) |
| :---: | :---: |
| L | = low level (steady state) |
| $\uparrow$ | $=$ transition from low to high level |
| $\downarrow$ | $=$ transition from high to low level |
| $\longrightarrow$ | = value/level or resulting value/level is routed to indicated destination |
| $\sim$ | = value/level is re-entered |
| X | $=$ irrelevant (any input, including transitions) |
| Z | $=$ off (high-impedance) state of a 3-state output |
| a..h | $=$ the level of steady-state inputs A through H respectively |
| $\mathrm{Q}_{0}$ | $=$ level of $Q$ before the indicated steady-state input conditions were established |
| $\bar{\square}_{0}$ | $=$ complement of $Q_{0}$ or level of $\bar{Q}$ before the indicated steady-state input conditions were established |
| $\mathrm{Q}_{\mathrm{n}}$ | $=$ level of $\mathbf{Q}$ before the most recent active transition indicated by $\downarrow$ or $\uparrow$ |
| $\checkmark$ | = one high-level pulse |
| ᄃ- | = one low-level pulse |
| GGL | $=$ each output changes to the complement of its previous level on each active transition indicated by $\downarrow$ or $\uparrow$ |

If, in the input columns, a row contains only the symbols $\mathrm{H}, \mathrm{L}$, and/or X , this means the indicated output is valid whenever the input configuration is achieved and regardless of the sequence in which it is achieved. The output persists so long as the input configuration is maintained.
If, in the input columns, a row contains $\mathrm{H}, \mathrm{L}$, and/or X together with $\uparrow$ and/or $\downarrow$, this means the output is valid whenever the input configuration is achieved but the transition(s) must occur following the achievement of the steady-state levels. If the output is shown as a level $\left(H, L, Q_{0}\right.$, or $\bar{Q}_{0}$ ), it persists so long as the steady-state input levels and the levels that terminate indicated transitions are maintained. Unless otherwise indicated, input transitions in the opposite direction to those shown have no effect at the output. (If the output is shown as a pulse, $\Omega$ or $工$, the pulse follows the indicated input transition and persists for an interval dependent on the circuit.)

## function tables (continued)

Among the most complex function tables are those of the shift registers. These embody most of the symbols used in any of the function tables, plus more. Below is the function table of a 4-bit bidirectional universal shift register, e.g., type SN74194.

| FUNCTION TABLE |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUTS |  |  |  |  |  |  |  |  |  | OUTPUTS |  |  |  |
| CLEAR | MODE |  | CLOCK | SERIAL |  | PARALEL |  |  |  | $a_{A}$ | $a_{B}$ | $Q_{c}$ | $\mathbf{a}_{\text {D }}$ |
|  | S1 | so |  | LEFT | RIGHT | A | B | c | D |  |  |  |  |
| L | X | X | X | X | X | X | X | X | X | L | L | L | L |
| H | X | X | L | X | x | X | X | X | X | $Q_{A 0}$ | $\mathrm{Q}_{\mathrm{Bo}}$ | $Q_{\text {co }}$ | $Q_{D 0}$ |
| H | H | H | $\uparrow$ | X | X | a | b | c | d | a | $b$ | $c$ | d |
| H | L | H | 1 | X | H | H | H | H | H | H | $Q_{\text {An }}$ | $\mathrm{Q}_{\mathrm{Bn}}$ | $Q_{\text {cn }}$ |
| H | $L$ | H | $\dagger$ | X | L | L | L | L | L | L | $Q_{\text {An }}$ | $\mathrm{Q}_{\mathrm{Bn}}$ | $Q_{\text {cn }}$ |
| H | H | L | $\uparrow$ | H | X | X | X | X | X | $\mathrm{Q}_{\mathrm{Bn}}$ | $Q_{C n}$ | $Q_{D n}$ | H |
| H | H | L | $\dagger$ | L | X | X | X | X | X | $\mathrm{Q}_{\mathrm{Bn}}$ | $Q_{C n}$ | $Q_{\text {Dn }}$ | L |
| H | L | L | X | X | X | X | X | X | X | $Q_{A 0}$ | $\mathrm{Q}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $Q_{D 0}$ |

The first line of the table represents a synchronous clearing of the register and says that if clear is low, all four outputs will be reset low regardless of the other inputs. In the following lines, clear is inactive (high) and so has no effect.

The second line shows that so long as the clock input remains low (while clear is high), no other input has any effect and the outputs maintain the levels they assumed before the steady-state combination of clear high and clock low was established. Since on other lines of the table only the rising transition of the clock is shown to be active, the second line implicitly shows that no further change in the outputs will occur while the clock remains high or on the high-to-low transition of the clock.
The third line of the table represents synchronous parallel loading of the register and says that if S1 and S0 are both high then, without regard to the serial input, the data entered at $A$ will be at output $Q_{A}$, data entered at $B$ will be at $\mathrm{Q}_{\mathrm{B}}$, and so forth, fo!lowing a low-to-high cleck transiticn.
The fourth and fifth lines represent the loading of high- and low-level data, respectively, from the shift-right serial input and the shifting of previously entered data one bit; data previously at $Q_{A}$ is now at $Q_{B}$, the previous levels of $Q_{B}$ and $Q_{C}$ are now at $Q_{C}$ and $Q_{D}$, respectively, and the data previously at $Q_{D}$ is no longer in the register. This entry of serial data and shift takes place on the low-to-high transition of the clock when S1 is low and SO is high and the levels at inputs $A$ through $D$ have no effect.
The sixth and seventh lines represent the loading of high- and low-level data, respectively, from the shift-left serial input and the shifting of previously entered data one bit; data previously at $Q_{B}$ is not at $Q_{A}$, the previous levels of $Q_{C}$ and $Q_{D}$ are now at $Q_{B}$ and $Q_{C}$, respectively, and the data previously at $Q_{A}$ is no longer in the register. This entry of serial data and shift takes place on the low-to-high transition of the clock when S1 is high and SO is low and the levels at inputs $A$ through $D$ have no effect.
The last line shows that as long as both inputs are low, no other input has any effect and, as in the second line, the outputs maintain the levels they assumed before the steady-state combination of clear high and both mode inputs low was established.
The function table functional tests do not reflect all possible combinations or sequential modes.

## D flip-flop and latch signal conventions

It is normal Tl practice to name the outputs and other inputs of a D-type flip-flop or latch and to draw its logic symbol based on the assumption of true data (D) inputs. Outputs that produce data in phase with the data inputs are called $Q$ and those producting complementary data are called $\bar{Q}$. An input that causes a $Q$ output to go high or a $\bar{Q}$ output to go low is called preset (PRE). An input that causes a $\mathbb{Q}$ output to go high or a $Q$ output to go low is called clear (CLR). Bars are used over these pin names (PRE and CLR) if they are active-low.
The devices on several data sheets are second-source designs, and the pin name conventions used by the original manufacturers have been retained. That makes it necessary to designate the inputs and outputs of the inverting circuits $D$ and $Q$.

In some applications, it may be advantageous to redesignate the data input from $D$ to $D$ or vice versa. In that case, all the other inputs and outputs should be renamed as shown below. Also shown are corresponding changes in the graphical symbols. Arbitrary pin numbers are shown.


The figures show that when $Q$ and $Q$ exchange names, the preset and clear pins also exchange names. The polarity indicators ( $\triangle$ ) on PRE and CLR remain, as these inputs arestill active-low, but the presence or absence of the polarity indicator changes at $D$ (or $\bar{D}), Q$, and $\bar{Q}$. $\operatorname{Pin} 5(Q$ or $\bar{Q})$ is still in phase with the data input ( $D$ or D); their active levels change together.

## thermal information

In digital system design, consideration must be given to thermal management of components. The small size of the small-outline package makes this even more critical. Figure 1 shows the thermal resistance of these packages for various rates of air flow.

The thermal resistances in Figure 1 can be used to approximate typical and maximum virtual junction temperatures for the EPIC ${ }^{\text {m }}$ ACL family. In general, the junction temperature for any device can be calculated using Equation 1.
$T J=R_{\theta J A} \times P_{T}+T_{A}$
where:
$T_{J} \quad=$ virtual junction temperature
$\mathrm{R}_{\theta \mathrm{JA}}=$ thermal resistance, junction to free air
$\mathrm{P}_{\mathbf{T}} \quad=$ total power dissipation of the device
$T_{A}=$ free-air temperature

JUNCTION-TO-AMBIENT THERMAL RESISTANCE
Vs


Figure 1

The total power consumption can be determined from Equation 2 for an AC device and Equation 3 for an ACT device.
$P_{T}=V_{C C} \times l_{C C}+\left(C_{p d} \times V_{C C}{ }^{2} \times f_{i}\right)+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f_{0}\right)$
$P_{T}=V_{C C} \times\left[I_{C C}+\left(N \times \Delta I_{C C} \times d c\right)\right]+\left(C_{p d} \times V_{C C}{ }^{2} \times f_{i}\right)+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f_{0}\right)$
where:

| $V_{C C}$ | $=$ supply voltage ( 5 V for typical, 5.5 V for maximum) (see Note 1) |
| :--- | :--- |
| $\mathrm{I}_{\mathrm{Cc}}$ | $=$ quiescent supply current (specified on device data sheet) |
| $\mathrm{C}_{\text {pd }}$ | $=$ power dissipation capacitance (from the device data sheet) |
| $\mathrm{f}_{\mathrm{l}}$ | $=$ input frequency |
| $\mathrm{C}_{\mathrm{L}}$ | $=$ output load capacitance |
| $\mathrm{f}_{\mathrm{o}}$ | = output frequency |
| N | $=$ number of inputs driven by a TTL device |
| dc | $=$ duty cycle |
| $\Delta \mathrm{I}_{\mathrm{CC}}$ | $=$ increase in supply current (specified on device data sheet) |

NOTE 1: In system applications, $I_{C C}$ can be minimized by keeping input voltage levels less than 1 V for $V_{\mathbb{I L}}$ and greater than $V_{C C}-1 \mathrm{~V}$ for $V_{\mathbb{I H}}$ and input rise and fall times less than 15 ns .

EPIC is a trademark of Texas Instruments Incorporated.

| General Information | -1 |
| :---: | :---: |
| Unidirectional Clocked FIFOs | \%2, |
| Unidirectional Firas | 43-4 |
| Bidirectional Cliocked FiFos | 4 |
| Bidirectional Firos | 5 5 |
| Product Previews | W68䢕 |
| Articles and Application Notes | Fadem |
| Machanical Bata | 8 |

- Member of the Texas Instruments Widebus ${ }^{\text {™ }}$ Family
- Independent Asynchronous Inputs and Outputs
- 1024 Words $\times 18$ Bits
- Read and Write Operations Can Be Synchronized to Independent System Clocks
- Programmable Almost Full/Almost Empty Flag
- Input Ready, Output Ready, and Hali-Full Flags
- Cascadable In Word WIdth and/or Word Depth
- Fast Access Tlimes of 15 ns With a $50-\mathrm{pF}$ Load
- HIgh Output Drive for Direct Bus Interface
- 3-State Outputs
- Avallable In 68-PIn PLCC (FN) or Space-Saving 80-PIn Shrink Quad Flat Pack (PN)

| FN PACKAGE (TOP VIEW) |  |  |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |
| D14 | $]_{10}^{9} 887665433216867666564636261600$ | Vcc |
| D13 | 11 590 | Q14 |
| D12 | 12 58[ | Q13 |
| D11 | 13 - 570 | GND |
| D10 | 14 - 560 | Q12 |
| D9 | 15 - 55[] | Q11 |
| $\mathrm{V}_{\mathrm{cc}}$ | 16 - 54 | $\mathrm{V}_{\mathrm{cc}}$ |
| D8 | 17 -53] | Q10 |
| GND | 18 -520] | Q9 |
| D7 | 19 510 | GND |
| D6 | 20 - 500 | Q8 |
| D5 | 21 -490 | Q7 |
| D4 | 22 - 48 [ | $\mathrm{V}_{\mathrm{cc}}$ |
| D3 | 23 - 470 | Q6 |
| D2 | $24 \times 46$ | Q5 |
| D1 | 25 - ${ }^{45}$ | GND |
| DO | ${ }^{26}$ | Q4 |
|  | 2728293031323334353637383940414243 |  |
|  |  |  |



NC - No internal connection

## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7801 is a 1024-×18-bit FIFO for high speed and fast access times. It processes data at rates up to 40 MHz and access times of 15 ns in a bit-parallel format. Data outputs are noninverting with respect to the data inputs. Expansion is easily accomplished in both word width and word depth.
The SN74ACT7801 has normal input-bus-to-output-bus asynchronous operation. The special enable circuitry adds the ability to synchronize independent read and write (interrupts, requests) to their respective system clock.
logic symbol ${ }^{\dagger}$

$t$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12. Pin numbers shown are for the FN package.
functional block diagram


## functional description

## Inputs

## data $\ln$ (D0-D17)

Data inputs for 18 -bit-wide data to be stored in the memory. Data lines D0-D8 also carry the almost full/almost empty offset value ( $X$ ) on a high-to-low transition of the define almost full (DAF) input.

## reset (RESET)

A reset is accomplished by taking reset (RESET) low and generating a minimum of four read clock (RDCLK) and write clock (WRTCLK) cycles. This ensures that the internal read and write pointers are reset and that the output ready flag (OR), the half-full flag (HF), and the input ready flag (IR) are low; the almost full/almost empty flag (AF/AE) is high. The FIFO must be reset upon power up. With the define almost full (DAF) input at a low level, a low pulse on RESET defines the AF/AE status flag using the almost full/almost empty offset value ( X ), where $X$ is the value previously stored. With DAF at a high level, a low-level pulse on RESET defines the AF/AE flag using the default value of $X=256$.

## write enables (WRTEN1, WRTEN2)

The write enables (WRTEN1, WRTEN2) must be high before the rising edge of write clock (WRTCLK) for a word to be written into memory. The write enables do not affect the storage of the almost full/almost empty offset value ( X ).

## functional description (continued)

## write clock (WRTCLK)

Data is written into memory on a low-to-high transition of the write clock (WRTCLK) if the input ready flag output (IR) and the write enable control inputs (WRTEN1, WRTEN2) are high. WRTCLK is a free-running clock and functions as the synchronizing clock for all data transfers into the FIFO. The IR flag output is also driven synchronously with respect to the WRTCLK signal.

```
read onables (RDEN1, RDEN2)
```

Both read enables (RDEN1, RDEN2) must be high before the rising edge of read clock (RDCLK) to read a word out of memory. The read enables are not used to read the first word stored in memory.

## read clock (RDCLK)

Data is read out of memory on a low-to-high transition at the read clock (RDCLK) input if the output ready flag output (OR) and the output enable (OE) and read enable (RDEN1, RDEN2) control inputs are high. RDCLK is a free-running clock and functions as the synchronizing clock for all data transfers out of the FIFO. The OR flag is also driven synchronously with respect to the RDCLK signal.

## deflne almost full (DAF)

The high-to-low transition of the define almost full (DAF) input stores the binary value of data inputs D0-D8 as the almost full/almost empty offset value ( $X$ ). With DAF held low, a low pulse on the reset (RESET) input defines the almost fuil/almost empty flag (AF/AE) using $X$.
output enable (OE)
The data out (Q0-Q17) outputs and the output ready flag (OR) are in the high-impedance state when the output enable (OE) input is low. OE must be high before the rising edge of read clock (RDCLK) to read a word from memory.

## outputs

data out (Q0-Q17)
The first data word to be loaded into the FIFO is moved to the data out (Q0-Q17) register on the rising edge of the third read clock (RDCLK) pulse to occur after the first valid write. The read enable (RDEN1, RDEN2) inputs do not affect this operation. Following data is unloaded on the rising edge of RDCLK when RDEN1, RDEN2, and the output ready flag (OR) are high.

## input ready flag (IR)

The input ready flag (IR) is high when the FIFO is not full and low when the device is full. During reset, the IR flag is driven low on the rising edge of the second write clock (WRTCLK) pulse. The IR flag is driven high on the rising edge of the second WRTCLK pulse after RESET goes high. After the FIFO is filled and IR is driven low, IR is driven high on the second WRTCLK pulse after the first valid read.

## output ready flag (OR)

The output ready flag (OR) is high when the FIFO is not empty and low when it is empty. During reset, the OR flag is set low on the rising edge of the third read clock (RDCLK) pulse. The OR flag is set high on the rising edge of the third RDCLK pulse to occur after the first word is written into the FIFO. OR is set low on the rising edge of the first RDCLK pulse after the last word is read.

## half-full status flag (HF)

The half-full flag (HF) is high when the FIFO contains 513 or more words and is low when it contains 512 or less words.

## functional description (continued)

almost full/almost empty status flag (AF/AE)
The aimost full/almost empty flag (AF/AE) is defined by the almost full/almost empty offset value (X). The AF/AE flag is high when the FIFO contains $(X+1$ ) or less words or $(1025-X)$ or more words. The AF/AE flag is low when the FIFO contains between $(X+2)$ and ( $1024-X$ ) words.

## programming procedure for $A F / A E$

The almost full/almost empty flag (AF/AE) is programmed during each reset cycle. The almost full/almost empty offset value $(X)$ is either a user-defined value or the default value of $X=256$. Below are instructions to program AF/AE using both methods.

## user-defined X:

Step 1. Take DAF from high to low.
Step 2. If RESET is not already low, take RESET low.
Step 3. With DAF held low, take RESET high. This defines the AF/AE flag using $X$.
Step 4. To retain the current offset for the next reset, keep DAF low.
default $X$ :
To redefine the AF/AE flag using the default value of $X=256$, hold DAF high during the reset cycle.
timing diagrams

$t X$ is the binary value of DO-D8 only.
Figure 1. Reset Cycle: Define AF/AE Using the Value of $X$


Figure 2. Reset Cycle: Define AF/AE Using the Default Value


Figure 3. Write

## SN74ACT7801

1024 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS111-D3489, APRIL 1990-REVISED MAY 1991


Flgure 4. Read

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

Supply voltage range, $\mathrm{V}_{\mathrm{CC}}$
-0.5 V to 7 V
Input voltage, $\mathrm{V}_{\mathrm{I}}$ 7 V
Voltage applied to a disabled 3 -state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range.................................................... $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions

|  |  |  | 'ACT7801-15 |  | 'ACT7801-18 |  | 'ACT7801-20 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5.5 | 4.5 | 5.5 | 4.5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  | 2 |  | 2 |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  | 0.8 |  | 0.8 | V |
| $\mathrm{IOH}^{2}$ | High-level output current |  |  | -8 |  | -8 |  | -8 | mA |
| lOL | Low-level output current |  |  | 16 |  | 16 |  | 16 | mA |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency |  | 40 |  | 35 |  | 28.5 |  | MHz |
| $t_{\text {w }}$ | Pulso duration | Data in (D0-D17) high or low | 10 |  | 12 |  | 14 |  | ns |
|  |  | WRTCLK high | 7 |  | 8.5 |  | 10 |  |  |
|  |  | WRTCLK ${ }^{\text {dow }}$ | 15 |  | 15 |  | 15 |  |  |
|  |  | RDCLK high | 7 |  | 8.5 |  | 10 |  |  |
|  |  | RDCLK Iow | 15 |  | 15 |  | 15 |  |  |
|  |  | DAF high | 10 |  | 10 |  | 10 |  |  |
|  |  | WRTEN1, WRTEN2 high or low | 10 |  | 10 |  | 10 |  |  |
|  |  | OE, RDEN1, RDEN2 high or low | 10 |  | 10 |  | 10 |  |  |
| $\mathrm{tsu}^{\text {u }}$ | Setup time | Data in (D0-D17) before WRTCLK $\dagger$ | 5 |  | 5 |  | 5 |  | ns |
|  |  | WRTEN1, WRTEN2 before WRTCLK $\uparrow$ | 5 |  | 5 |  | 5 |  |  |
|  |  | OE, RDEN1, RDEN2 before RDCLK $\dagger$ | 5 |  | 5 |  | 5 |  |  |
|  |  | Reset: RESET low before first WRTCLK and RDCLK $\uparrow$ | 7 |  | 7 |  | 7 |  |  |
|  |  | Define AF/AE: D0-D8 before DAF $\downarrow$ | 5 |  | 5 |  | 5 |  |  |
|  |  | Define AF/AE: DAF $\downarrow$ before RESET $\dagger$ | 7 |  | 7 |  | 7 |  |  |
|  |  | Define AF/AE (default): DAF high before RESET $\uparrow$ | 5 |  | 5 |  | 5 |  |  |
| $t_{4}$ | Hold time | Data in (D0-D17) after WRTCLK $\dagger$ | 1 |  | 1 |  | 1 |  | ns |
|  |  | WRTEN1, WRTEN2 after WRTCLK $\uparrow$ | 1 |  | 1 |  | 1 |  |  |
|  |  | OE, RDEN1, RDEN2 after RDCLK $\dagger$ | 1 |  | 1 |  | 1 |  |  |
|  |  | Reset: RESET low after fouth WRTCLK and RDCLK $\uparrow$ | 0 |  | 0 |  | 0 |  |  |
|  |  | Define AF/AE: D0-D8 after DAF $\downarrow$ | 1 |  | 1 |  | 1 |  |  |
|  |  | Define AF/AE: DAF low after RESET $\uparrow$ | 0 |  | 0 |  | 0 |  |  |
|  |  | Define AF/AE (default): DAF high after RESET $\dagger$ | 1 |  | 1 |  | 1 |  |  |
| $T_{A}$ | Operating free-air temperature |  | 0 | 70 | 0 | 70 | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

## electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\text {OL }}=16 \mathrm{~mA}$ |  |  | 0.5 | V |
| I |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{ICCl}^{\ddagger}$ | Supply current | $\mathrm{f}_{\text {clock }}=25 \mathrm{MHz}^{\text {b }}$ |  |  | 200 | 230 | mA |
| $\mathrm{CCO}^{\ddagger}$ | Standby current | $\mathrm{V}_{\text {IH }}=$ WRTCLK, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{IL}}$ |  | 20 | 25 | mA |
| $\mathrm{lcCa}^{\ddagger}$ | Power-down current | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\mathrm{j}}$ |  | $V_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (see Figures 9 and 10)

| PARAMETER | FROM(INPUT) | TO (OUTPUT) | 'ACT7801-15 |  |  | 'ACT7801-18 |  | 'ACT7801-20 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYPt | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 40 |  |  | 35 |  | 28.5 |  | MHz |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | Any Q | 5 | 12 | 15 | 5 | 18 | 5 | 20 | ns |
| $t_{p d}{ }^{\text {d }}$ |  |  |  | 10.5 |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | WRTCLK $\uparrow$ | IR | 4 |  | 10 | 4 | 12 | 4 | 14 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | RDCLK $\uparrow$ | OR | 4 |  | 10 | 4 | 12 | 4 | 14 | ns |
| $t_{\text {pd }}$ | WRTCLK ${ }_{\text {¢ }}$ | AFIAE | 7 |  | 20 | 7 | 22 | 7 | 24 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | AF/AE | 7 |  | 20 | 7 | 22 | 7 | 24 | ns |
| tPu | WRTCLK $\uparrow$ | HF | 6 |  | 19 | 6 | 21 | 6 | 23 | ns |
| $\mathrm{t}_{\mathrm{pHL}}$ | RDCLK $\uparrow$ |  | 6 |  | 19 | 6 | 21 | 6 | 23 |  |
| $\mathrm{t}_{\mathrm{LH}}$ | RESET $\downarrow$ | AF/AE | 4 |  | 19 | 4 | 21 | 4 | 23 | ns |
| to $_{\text {HL }}$ |  | HF | 4 |  | 21 | 4 | 23 | 4 | 25 |  |
| $t_{\text {en }}$ | OE | Any Q, OR | 4 |  | 11 | 4 | 11 | 4 | 11 | ns |
| $t_{\text {dis }}$ |  |  | 2 |  | 14 | 2 | 14 | 2 | 14 |  |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\ddagger} \mathrm{lcC}$ tested with outputs open.
${ }^{5}$ For frequencies greater than $25 \mathrm{MHz}, \mathrm{I}_{\mathrm{CC}}=230 \mathrm{~mA}+(6 \mathrm{~mA} \times[f-25 \mathrm{MHz}])$.
${ }^{1}$ This parameter is measured with $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 5).

## TYPICAL CHARACTERISTICS

TYPICAL PROPAGATION DELAY TIME


Figure 5
TYPICAL POWER DISSIPATION CAPACITANCE
vs
SUPPLY VOLTAGE


Figure 6

## SCAS111-D3489, APRIL 1990-REVISED MAY 1991

## calculating power dissipation

With ICCF taken from Figure 6, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[I_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{C C}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{C C}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{C C}^{2} \times f 0\right)
$$

$I_{C C}=$ power-down Icc maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta l_{\text {CC }}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\text {pd }}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{j}=$ data input frequency
$f_{0}=$ data output frequency

## APPLICATION DATA

## expanding the SN74ACT7801

The SN74ACT7801 is expandable in width and depth. Expanding in word depth offers special timing considerations:

1. After the first data word is loaded into the FIFO, the word is unloaded, and the output ready flag output (OR) goes high after ( $\mathrm{N} \times 3$ ) read clock (RDCLK) cycles, where N is the number of devices used in depth expansion.
2. After the FIFO is filled, the input ready flag output (IR) goes low, the first word is unloaded, and the IR flag output is driven high after ( $\mathrm{N} \times 2$ ) write clock cycles, where N is the number of devices used in depth expansion.


Figure 7. Word-Depth Expansion: 2048 Words $\times 18$ Bits, $\mathrm{N}=2$


Figure 8. Word-Width Expansion: 1024 Words $\times 36$ Blts

## PARAMETER MEASUREMENT INFORMATION



Figure 9. Standard CMOS Outputs (OR, Half Full, AF/AE)


Figure 10. 3-State Outputs (Any Q, OR)

- Member of the Texas Instruments Widebus ${ }^{\text {TM }}$ Family
- Free-Running Read and Write Clocks May Be Asynchronous or CoIncldent
- Read and Write Operations Synchronized to Independent System Clocks
- Input-Ready Flag Synchronized to Write Clock
- Output-Ready Flag Synchronized to Read Clock
- Packaged In Shrink Small-Outline $300-\mathrm{mll}$ Package (DL) Using 25-mil Center-to-Center Spacing
- 512 Words by 18 Blts
- Low-Power Advanced CMOS Technology
- Half-Full Flag and Programmable Almost Full/Almost Empty Flag
- Bldirectional Configuration and Width Expanslon Without Additional Loglc
- Fast Access Times of 12 ns With a 50-pF Load and All Data Outputs Swltching SImultaneously
- Data Rates From 0 to 67 MHz
- Pin CompatIble WIth SN74ACT7805 and SN74ACT7813


## description

The SN74ACT7803 is a 512 -word $\times 18$-bit FIFO suited for buffering asynchronous data paths at $67-\mathrm{MHz}$ clock rates and $12-\mathrm{ns}$ access times. Its 56-pin shrink small-outline package (DL) offers greatly reduced board space over DIP, PLCC, and conventional SOIC packages. Two devices may be configured for bidirectional data buffering without additional logic. Multiple distributed $\mathrm{V}_{\mathrm{CC}}$ and GND pins along with Tl's patented Output Edge Control (OEC") circuit dampen simultaneous switching noise.
DLPACKAGE
(TOP VEW)

| FESET 1 |  | סE1 |
| :---: | :---: | :---: |
| D17 2 | 55 | Q17 |
| D16 3 | 54 | Q16 |
| D15 4 | 53 | Q15 |
| D14 5 | 52 | GND |
| D13 6 | 51 | Q14 |
| D12 7 | 50 | $\mathrm{V}_{\mathrm{cc}}$ |
| D11 8 | 49 | Q13 |
| D10 9 | 48 | Q12 |
| $\mathrm{V}_{\mathrm{cc}} 10$ | 47 | Q11 |
| D9 11 | 46 | Q10 |
| D8 12 | 45 | Q9 |
| GND 13 | 44 | GND |
| D7 14 | 43 | Q8 |
| D6 15 | 42 | Q7 |
| D5 16 | 41 | Q6 |
| D4 17 | 40 | $1{ }^{\text {Q }}$ |
| D3 18 | 39 | $\mathrm{V}_{\mathrm{cc}}$ |
| D2 19 | 38 | Q4 |
| D1 20 | 37 | [ Q3 |
| D 021 | 36 | Q2 |
| HF 22 | 35 | GND |
| PEN ${ }^{23}$ |  | Q1 |
| AF/AE 24 | 33 | Qo |
| WRTCLK 25 | 32 | RDCLK |
| WRTEN2 26 | 31 | IRDEN |
| WRTEN1 27 | 30 | ] DE2 |
| 1R[28 | 29 | OR |

The write clock (WRTCLK) and read clock (RDCLK) should be free-running and may be asynchronous or coincident. Data is written to memory on the rising edge of WRTCLK when WRTEN1 is high, WRTEN2 is low, and IR is high. Data is read from memory on the rising edge of RDCLK when RDEN, OE1, and OE2 are low and OR is high. The first word written to memory is clocked through to the output buffer regardless of the RDEN, OET, and OE2 levels. The OR flag indicates that valid data is present on the output buffer.
The FIFO may be reset asynchronously to WRTCLK and RDCLK. RESET must be asserted while at least four WRTCLK and four RDCLK rising edges occur to clear the synchronizing registers. Resetting the FIFO initializes the IR, OR, and HF flags low and the AF/AE flag high. The FIFO must be reset upon power up.

[^1]
## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/תEEE Std 91-1984 and IEC Publication 617-12

## functional block diagram



## Terminal Functions

| NAME | N $\quad$ N. | I/O | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 64 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y)$. AF/AE is high when memory contains $X$ or less words or ( 512 minus $Y$ ) or more words. AF/AE is high after reset. |
| D0-D17 | $\begin{gathered} 21-14,12-11 \\ 9-2 \end{gathered}$ | I | 18-bit data input port |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 256 or more words. HF is low after reset. |
| IR | 28 | 0 | Input ready flag. IR is synchronized to the low-to-high transition of WRTCLK. When IR is low, the FIFO is full and writes are disabled. IR is low during reset and goes high on the second low-to-high transition of WRTCLK after reset. |
| OE1, OE2 | 56,30 | 1 | Output enables. When $\overline{\mathrm{OET}}, \overline{\mathrm{OE}}$, and RDEN are low and OR is high, data is read from the FIFO on a low-to-high transition of RDCLK. When either OE 1 or OE 2 is high, reads are disabled, and the data outputs are in the high-impedance state. |
| OR | 29 | 0 | Output ready flag. OR is synchronized to the low-to-high transition of RDCLK. When OR is low, the FIFO is empty and reads are disabled. Ready data is present on Q0-Q17 when OR is high. OR is low during reset and goes high on the third low-to-high transition of RDCLK after the first word is loaded to empty memory. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on DO-D7 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49, \\ 51,53-55 \end{gathered}$ | 0 | 18-bit data output port. After the first valid write to empty memory, the first word is output on Q0-Q17 on the third rising edge of RDCLK. OR is also asserted high at this time to indicate ready data. When OR is low, the last word read from the FIFO is present on Q0-Q17. |
| RDCLK | 32 | 1 | Read clock. RDCLK is a continuous clock and may be asynchronous or coincident to WRTCLK. A low-to-high transition of RDCLK reads data from memory when OET, OE2, and RDEN are low and OR is high. OR is synchronous to the low-to-high transition of RDCLK. |
| RDEN | 31 | 1 | Read enable. When RDEN, OET, and $\overline{O E 2}$ are low and OR is high, data is read from the FIFO on the low-to-high transition of RDCLK. |
| RESET | 1 | 1 | Reset. To reset the FlFO, four low-to-high transitions of RDCLK and four low-to-high transitions of WRTCLK must occur while RESET is low. This sets HF, IR, and OR low and AF/AE high. |
| WRTCLK | 25 | I | Write clock. WRTCLK is a continuous clock and may be asynchronous or coincident to RDCLK. A low-to-high transition of WRTCLK writes data to memory when WRTEN2 is low, WRTEN1 is high, and IR is high. IR is synchronous to the low-to-high transition of WRTCLK. |
| WRTEN1, WRTEN2 | 27, 26 | I | Write enables. When WRTEN1 is high, WRTEN2 is low, and IR is high, data is written to the FIFO on a low-to-high transition of WRTCLK. |

# SN74ACT7803 <br> 512 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY 

SCAS191-D3993, MARCH 1991-REVISED MARCH 1992
timing diagram


Flgure 1. Reset Cycle

## timing diagram



Figure 2. Write


Flgure 3. Read

## offset values for AF/AE

The almostfull/almost empty flag has two programmable limits, the almost empty offset value $(X)$ and the almost full offset value $(M$. They may be programmed after the FIFO is reset and before the first word is written to memory. If the offsets are not programmed, the default values of $\mathrm{X}=\mathrm{Y}=64$ are used. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 512 minus $Y$ ) or more words.

Program enable (PEN) should be held high throughout the reset cycle. PEN may be brought low only when IR is high and WRTCLK is low. On the following low-to-high transition of WRTCLK, the binary value on D0-D7 is stored as the almost empty offset value $(\mathrm{X})$ and the almost full offset value $(\mathrm{Y}$. Holding PEN low for another low-to-high transition of WRTCLK will reprogram $Y$ to the binary value on DO-D7 at the time of the second WRTCLK low-to-high transition. When the offsets are being programmed, writes to the FIFO memory are disabled regardless of the state of the write enables (WRTEN1, WRTEN2). A maximum value of 255 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=64, P E N$ must be held high.

## timing diagram



Figure 4. Programming $X$ and $Y$ Separately
absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\boldsymbol{\dagger}}$


Voltage applied to a disabled 3-state output ............................................................. 5.5 V
Operating free-air temperature range ............................................................. $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ................................................................. $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may afiect device reliability.

## recommended operating conditions


${ }^{\dagger}$ To permit the clock pulse to be utilized for reset purposes.

SCAS191-D3993, MARCH 1991-REVISED MARCH 1992
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| V OL | Fags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{LL}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Qoutputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $V_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lac |  | $\mathrm{V}_{1}=\mathrm{V}_{C C}-0.2 \mathrm{~V}$ |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{CC}^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{\mathrm{i}}$ |  | $V_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 9 and 10)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (NPUT) } \end{aligned}$ | TO (OUTPUT) | 'AC77803-15 |  |  | 'ACT7803-20 |  | 'ACT7803-25 |  | 'ACT7803-40 |  | UNT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 67 |  |  | 50 |  | 40 |  | 25 |  | MHz |
| $t_{p d}$ | RDCLK $\uparrow$ | Any Q | 4 | 9.5 | 12 | 4 | 13 | 4 | 15 | 4 | 20 | ns |
| $t_{\text {pd }}{ }^{5}$ |  |  |  | 8.5 |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | WRTCLK $\dagger$ | IR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| $t_{\text {pd }}$ | RDCLK $\dagger$ | OR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| $t_{\text {pd }}$ | WRTCLK $\dagger$ | AF/AE | 7 |  | 16.5 | 7 | 19 | 7 | 21 | 7 | 23 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | RDCLK $\uparrow$ | AF/AE | 7 |  | 17 | 7 | 19 | 7 | 21 | 7 | 23 | ns |
| $t_{\text {tiH }}$ | WRTCLK $\dagger$ | HF | 7 |  | 15 | 7 | 17 | 7 | 19 | 7 | 21 | ns |
| ¢PHL | RDCLK $\dagger$ |  | 7 |  | 15.5 | 7 | 18 | 7 | 20 | 7 | 22 |  |
| tpli | RESET low | AF/AE | 2 |  | 9 | 2 | 11 | 2 | 13 | 2 | 15 | ns |
| $\mathrm{t}_{\mathrm{HL}}$ |  | HF | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 |  |
| ten | OE1, DE2 | Any Q | 2 |  | 8.5 | 2 | 11 | 2 | 11 | 2 | 11 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 2 |  | 9.5 | 2 | 11 | 2 | 14 | 2 | 14 |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.
${ }^{8}$ This parameter is measured with a 30 pF load (see Figure 7).
operating characteristics, $\mathrm{V}_{\mathbf{C C}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | TYP | UNIT |  |
| :---: | :---: | :---: | :---: | :---: |
| $C_{\text {pd }}$ | Power dissipation capacitance | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad f=5 \mathrm{MHz}$ | 53 |

APPLICATION INFORMATION


Figure 5. Bldirectlonal Configuration


Figure 6. Word-Width Expansion: $512 \times 36$ Blt

## TYPICAL CHARACTERISTICS



Figure 7


Flgure 8

## calculating power dissipation

With I $C C F$ taken from Figure 8, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
\mathrm{P}_{\mathrm{t}}=\mathrm{V}_{\mathrm{CC}} \times\left[\mathrm{l}_{\mathrm{CCF}}+\left(\mathrm{N} \times \Delta \mathrm{l}_{\mathrm{CC}} \times \mathrm{dc}\right)\right]+\Sigma\left(\mathrm{C}_{\mathrm{L}} \times \mathrm{V}_{\mathrm{CC}}^{2} \times \mathrm{fo}\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{C C} \times\left[I_{C c}+\left(N \times \Delta I_{C C} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{C C^{2}} \times f i\right)+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f o\right)
$$

$I_{C C}=$ power-down $I_{c c}$ maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta I_{C C}=$ increase in supply current
dc = duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$\mathrm{C}_{\mathrm{L}}=$ output capacitive load
$f_{i}=$ data input frequency
$f_{0}=$ data output frequency

PARAMETER MEASUREMENT INFORMATION


Figure 9. Standard CMOS Outputs (IR, OR, HF, AF/AE)


| PARAMETER |  | R1, R2 | $\mathrm{C}_{\text {L }}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | tozH | $500 \Omega$ | 50 pF | Open |
|  | 4PZL |  |  | Closed |
| $t_{\text {dis }}$ | $\dagger_{\text {PHZ }}$ | $500 \Omega$ | 50 pF | Open |
|  | tPL |  |  | Closed |
| $t_{0 d}$ |  | $500 \Omega$ | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 10. 3-State Outputs (Any Q)

- Member of the Texas Instruments Widebus ${ }^{\text {"4 }}$ Family
- Free-Running Read and Write Clocks May Be Asynchronous or CoIncIdent
- Read and Write Operations Synchronized to Independent System Clocks
- Input-Ready Flag Synchronized to Write Clock
- Output-Ready Flag Synchronized to Read Clock
- Packaged In Shrink Small-Outline 300-mll Package (DL) Using 25-mII Center-to-Center Spacing
- 256 Words by 18 Bits
- Low-Power Advanced CMOS Technology
- Half-Full Flag and Programmable Almost Full/Almost Empty Flag
- Bldirectional Conflguration and Width Expansion Without Addlitional Logic
- Fast Access Times of 12 ns With a 50-pF Load and All Data Outputs Swltching SImultaneously
- Data Rates From 0 to 67 MHz
- Pin Compatible WIth SN74ACT7803 and SN74ACT7813


## description

The SN74ACT7805 is a256-word $\times 18$-bit clocked FIFO suited for buffering asynchronous data paths at $67-\mathrm{MHz}$ clock rates and $12-\mathrm{ns}$ access times. Its 56 -pin shrink small-outline package (DL) offers greatly reduced board space over DIP, PLCC, and conventional SOIC packages. Two devices may be configured for bidirectional data buffering without additional logic. Multiple distributed $\mathrm{V}_{\mathrm{CC}}$ and GND pins along with TI's patented Output Edge Control (OEC") circuit dampen simultaneous switching noise.

## DL PACKAGE

(TOP VIEV)

| RESET 1 |  | סE1 |
| :---: | :---: | :---: |
| D17 2 | 55 | 1 Q17 |
| D16 3 | 54 | Q16 |
| D15 4 | 53 | Q15 |
| D14 5 | 52 | 1 GND |
| D13 [6 | 51 | 1 Q14 |
| D12 7 | 50 | $\mathrm{V}_{\mathrm{cc}}$ |
| D11 ${ }^{\text {a }}$ | 49 | Q13 |
| D10 9 | 48 | Q12 |
| $\mathrm{v}_{\text {cc }} 10$ | 47 | Q11 |
| D9 11 | 46 | Q10 |
| D8 12 | 45 | ¢9 |
| GND 13 | 44 | GND |
| D7 14 | 43 | [ Q |
| D6 15 |  | Q7 |
| D5 16 | 41 | $1{ }^{\text {Q6 }}$ |
| D4 17 | 40 | Q5 |
| D3 18 | 39 | V cc |
| D2 19 | 38 | $1 \mathrm{Q}^{4}$ |
| D1 20 | 37 | Q3 |
| Do 21 | 36 | Q2 |
| HF 22 | 35 | GND |
| PEN 23 | 34 | Q1 |
| AF/AE 24 | 33 | Q0 |
| WRTCLK 25 | 32 | RDCLK |
| WRTEN2 26 | 31 | RDEN |
| WRTEN1 27 | 30 | סE2 |
| 1R [ 28 | 29 | OR |

The write clock (WRTCLK) and read clock (RDCLK) should be free-running and may be asynchronous or coincident. Data is written to memory on the rising edge of WRTCLK when WRTEN1 is high, WRTEN2 is low, and IR is high. Data is read from memory on the rising edge of RDCLK when RDEN, OE1, and OE2 are low and OR is high. The first word written to memory is clocked through to the output buffer regardless of the RDEN, OET, and OE2 levels. The OR flag indicates that valid data is present on the output buffer.
The FIFO may be reset asynchronously to WRTCLK and RDCLK. RESET must be asserted while at least four WRTCLK and four RDCLK rising edges occur to clear the synchronizing registers. Resetting the FIFO initializes the IR, OR, and HF flags low and the AF/AE flag high. The FIFO must be reset upon power up.

[^2]logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI//EEE Std 91-1984 and IEC Publication 617-12

## functional block diagram



Terminal Functions

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. | /o |  |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 32 may be used for both the almost-empty offiset $(X)$ and the almost-full offset (Y). AF/AE is high when memory contains $X$ or less words or ( 256 minus $Y$ ) or more words. AF/AE is high after reset. |
| D0-D17 | 21-14, 12-11, 9-2 | 1 | 18-bit data input port |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 128 or more words. HF is low after reset. |
| IR | 28 | 0 | Input ready flag. IR is synchronized to the low-to-high transition of WRTCLK. When IR is low, the FIFO is full and writes are disabled. IR is low during reset and goes high on the second low-to-high transition of WRTCLK after reset. |
| OET, OE2 | 56,30 | 1 | Output enables. When $\overline{O E 1}, \overline{O E 2}$, and RDEN are low and OR is high, data is read from the FIFO on a low-to-high transition of RDCLK. When either $\overline{\mathrm{CET}}$ or $\overline{\mathrm{OE}} 2$ is high, reads are disabled, and the data outputs are in the high-impedance state. |
| OR | 29 | 0 | Outputready flag. OR is synchronized to the low-to-high transition of RDCLK. When OR is low, the FIFO is empty and reads are disabled. Ready data is presenton Q0-Q17 when OR is high. OR is low during reset and goes high on the third low-to-high transition of RDCLK after the first word is loaded to empty memory. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on DO-D6 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49,51, \\ 53-55 \end{gathered}$ | 0 | 18 -bit data output port. After the first valid write to empty memory, the first word is output on Q0-Q17 on the third rising edge of RDCLK. OR is also asserted high at this time to indicate ready data. When OR is low, the last word read from the FIFO is present on Q0-Q17. |
| RDCLK | 32 | 1 | Read clock. RDCLK is a continuous dock and may be asynchronous or coincident to WRTCLK. A low-to-high transition of RDCLK reads data from memory when OET, OE2, and FDEN are low and OR is high. OR is synchronous to the low-to-high transition or RDCLK. |
| RDEN | 31 | 1 | Read enable. When RDEN, OET, and $\bar{O}$ ² are low and OR is high, datais read from the FIFO on the low-to-high transition of RDCLK. |
| RESET | 1 | 1 | Reset. To reset the FIFO, four low-to-high transitions of RDCLK and four low-to-high transitions of WRTCLK must occur while RESET is low. This sets HF, IR, and OR low and AF/AE high. |
| WRTCLK | 25 | 1 | Write clock. WRTCLK is a continuous clock and may be asynchronous or coincident to RDCLK. A low-to-high transition of WRTCLK writes data to memory when WRTEN2 is low, WRTEN1 is high, and IR is high. IR is synchronous to the low-to-high transition of WRTCLK. |
| WRTEN1, WRTEN2 | 27, 26 | 1 | Write enables. When WRTEN1 is high, WRTEN2 is low, and IR is high, data is written to the FIFO on a low-to-high transition of WRTCLK. |

timing diagrams


Figure 1. Reset Cycle

## SN74ACT7805

256 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY

## SCAS201-D4007, MARCH 1991-REVISED APRIL 1992

timing diagrams (continued)


Figure 2. Write
timing diagrams (continued)


Figure 3. Read

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost empty offset value $(\mathrm{X})$ and the almost full offset value ( $)$. They may be programmed after the FIFO is reset and before the first word is written to memory. If the offsets are not programmed, the default values of $X=Y=32$ are used. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 256 minus $Y$ ) or more words.

Program enable (PEN) should be held high throughout the reset cycle. PEN may be brought low only when IR is high and WRTCLK is low. On the following low-to-high transition of WRTCLK, the binary value on D0-D6 is stored as the almost empty offset value $(X)$ and the almost full offset value $(\mathrm{Y})$. Holding PEN low for another low-to-high transition of WRTCLK will reprogram $Y$ to the binary value on D0-D6 at the time of the second WRTCLK low-to-high transition. When the offsets are being programmed, writes to the FIFO memory are disabled regardless of the state of the write enables (WRTEN1, WRTEN2). A maximum value of 127 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=32$, PEN must be held high.

## timing diagram



FIgure 4. Programming $X$ and $Y$ Separately

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$



Voltage applied to a disabled 3-state output ............................................................ 5.5 V

Storage temperature range .................................................................. $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not Implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
recommended operating conditions

${ }^{\dagger}$ To permit the cock pulse to be utilized for reset purposes.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | DITIONS | MIN | TYp ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOH}^{\text {a }}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Fags | $V_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Qoutputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{C C}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{Oz}}$ |  | $V_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lcc |  | $V_{1}=V_{C C}-0.2$ |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{cc}^{\ddagger}$ |  | $V_{C C}=5.5 \mathrm{~V}$, | Other inputs at $\mathrm{V}_{\text {CC }}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 9 and 10)

| PARAMETER | FROM(INPUT) | TO (OUTPUT) | 'ACT7805-15 |  |  | 'ACT7805-20 |  | 'ACT7805-25 |  | 'ACT7805-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 67 |  |  | 50 |  | 40 |  | 25 |  | MHz |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | Any Q | 4 | 9.5 | 12 | 4 | 13 | 4 | 15 | 4 | 20 | ns |
| $t_{\text {da }}{ }^{5}$ |  |  |  | 8.5 |  |  |  |  |  |  |  |  |
| $t_{\text {pd }}$ | WRTCLK $\dagger$ | IR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| tod | RDCLK $\dagger$ | OR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| $t_{\text {pd }}$ | WRTCLK $\dagger$ | AF/AE | 7 |  | 16.5 | 7 | 19 | 7 | 21 | 7 | 23 | ns |
| $\mathrm{t}_{\text {pd }}$ | RDCLK $\dagger$ |  | 7 |  | 17 | 7 | 19 | 7 | 21 | 7 | 23 |  |
| tPLH | WRTCLK $\dagger$ | HF | 7 |  | 15 | 7 | 17 | 7 | 19 |  | 21 | ns |
| ${ }_{\text {tPHL }}$ | RDCLK $\dagger$ |  | 7 |  | 15.5 | 7 | 18 | 7 | 20 | 7 | 22 |  |
| +pLH | RESET low | AF/AE | 2 |  | 9 | 2 | 11 | 2 | 13 | 2 | 15 | ns |
| 4 PHL |  | HF | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 |  |
| ten | OE1, OE2 | Any Q | 2 |  | 8.5 | 2 | 11 | 2 | 11 | 2 | 11 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 2 |  | 9.5 | 2 | 11 | 2 | 14 | 2 | 14 |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current for each input that is at one of the specified $T \mathrm{TL}$ voltage levels rather 0 V or $\mathrm{V}_{\mathrm{Cc}}$.
${ }^{5}$ This parameter is measured at $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ load (see Figure 7).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDTIONS | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $C_{p d} \quad$ Power dissipation capacitance per FIFO channel | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad \mathrm{f}=5 \mathrm{MHz}$ | 53 | pF |



Figure 5. Bldirectlonal Configuration


Figure 6. Word-Width Expansion: $256 \times 36$ Blts

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
Vs
LOAD CAPACITANCE


Flgure 7


Flgure 8

## calculating power dissipation

With $I_{\text {CCF }}$ taken from Figure 8, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c^{2} \times f o}\right)
$$

Icc = power-down Icc maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta \mathrm{l}_{\mathrm{CC}}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$\mathrm{f}_{\mathrm{i}}=$ data input frequency
$\mathrm{f}_{\mathrm{o}}=$ data output frequency

PARAMETER MEASUREMENT INFORMATION


Figure 9. Standard CMOS Outputs (IR, OR, HF, AF/AE)


| PARAMETER |  | R1, R2 | $\mathrm{C}_{\mathrm{L}}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| $t_{\text {en }}$ | 4PZH | 500 Q | 50 pF | Open |
|  | tozl |  |  | Closed |
| $t_{\text {dis }}$ | ${ }_{\text {¢ }}^{\text {PHZ }}$ | $500 \Omega$ | 50 pF | Open |
|  | tPLZ |  |  | Closed |
| $\mathrm{t}_{\mathrm{pd}}$ |  | 500 Q | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 10. 3-State Outputs (Any Q)

- Free-Running Read and Write Clocks May Be Asynchronous or Coincldent
- Read and Write Operatlons SynchronIzed to Independent System Clocks
- Input-Ready Flag Synchronized to Write Clock
- Output-Ready Flag Synchronized to Read Cleck
- 2048 Words by 9 Blts
- Low-Power Advanced CMOS Technology
- Programmable Almost Full/Almost Empty Flag
- Input-Ready, Output-Ready, and Half-Full Flags
- Cascadable In Word Width and/or Word Depth
- Fast Access Tlmes of 12 ns With a 50-pF Load
- Data Rates From 0 to 67 MHz
- 3-State Outputs
- Avallable in 44-PIn PLCC (FN) or Space-Saving 64-Pin Shrink Quad Flat Pack (PM)


## description

The SN74ACT7807 is a 2048 -word by 9-bit FIFO with high speed and fast access times. It processes data at rates up to 67 MHz and access times of 12 ns in a bit-parallel format. Data outputs are noninverting with respect to the data inputs. Expansion is easily accomplished in both word width and word depth.
The write clock (WRTCLK) and read clock (RDCLK) inputs should be free-running and may be asynchronous or coincident. Data is written to memory on the rising edge of WRTCLK when the write-enable (WRTEN1/DP9, WRTEN2) inputs are high and the input-ready (IR) flag output is high. Data is read from memory on the rising edge of RDCLK when the read-enable (RDEN1, RDEN2) and output-enable (OE) inputs are high and the output-ready (OR) flag output is high. The first word written to memory is clocked through to the output buffer regardless of the levels on RDEN1, RDEN2, and OE. The OR flag indicates that valid data is present on the output buffer.
The FIFO may be reset asynchronous to WRTCLK and RDCLK. RESET must be asserted while at least four WRTCLK and four RDCLK cycles occur to clear the synchronizing registers. Resetting the FIFO initializes the IR, OR, and HF flags low and the AF/AE flag high. The FIFO must be reset upon power up.


NC - No internal connection

## logic symbol ${ }^{\dagger}$


${ }^{\dagger}$ This symbol is in accordance with ANSINEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for the FN package.

## Terminal Functions

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: |
| AF/AE | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 256 may be used for both the almost-empty offset $(X)$ and the almost-full offset ( $Y$ ). AF/AE is high whon memory contains $X$ or less words or ( 2048 minus $Y$ ) or more words. AF/AE is high after reset. |
| D0-D8 | 1 | Nine-bit data input port. |
| HF | 0 | Half-full flag. HF is high when the FIFO memory contains 1024 or more words. HF is low after reset. |
| IR | 0 | Input ready flag. IR is synchronized to the low-to-high transition of WRTCLK. When IR is low, the FIFO is full and writes are disabled. IR is low during reset and goes high on the second low-to-high transition of WFTCLKafter reset. |
| OE | 1 | Output enable. When OE, RDEN1, RDEN2 and OR are high, datais read from the FIFO on a low-to-high transition of RDCLK. When OE is low, reads are disabled and the data outputs are in the high-impedance state. |
| OR | 0 | Output ready flag. OR is synchronized to the low-to-high transition of RDCLK. When OR is low, the FIFO is empty and reads are disabled. Ready data is present on Q0-Q17 when OR is high. OR is low during reset and goes high on the third low-to-high transition of RDCLK after the first word is loaded to empty memory. |
| PEN | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on D0-D8 and DP9 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q8 | 0 | Nine-bit data output port. After the first valid write to empty memory, the first word is output on Q0-08 on the third rising edge of RDCLK. OR is also asserted high at this time to indicate ready data. When OR is low, the last word read from the FIFO is present on Q0-Q8. |
| RDCLK | 1 | Read clock. RDCLK is a continuous clock and may be asynchronous or coincident to WRTCLK. A low-to-high transition of RDCLK reads data from memory when RDEN1, RDEN2, OE, and OR are high. OR is synchronous to the low-to-high transition or RDCLK. |
| RDEN1, RDEN2 | 1 | Read enables. When RDEN1, RDEN2, OE, and OR are high, data is read from the FIFO on the low-to-high transition of RDCLK. |
| RESET | 1 | Reset. To reset the FIFO, four low-to-high transitions of RDCLK and four low-to-high transitions of WRTCLK must occur while RESET is low. This sets HF, IR, and OR low and AF/AE high. |
| WRTCLK | I | Write clock. WRTCLK is a continuous clock and may be asynchronous or coincident to RDCLK. A low-to-high transition of WRTCLK writes data to memory when WRTEN1/DP9, WRTEN2, and IR are high. IR is synchronous to the low-to-high transition of WRTCLK. |
| WRTEN1/DP9 | 1 | Write enable/data pin 9. When WRTEN1/DP9, WRTEN2, and IR are high, data is written to the FIFO on a low-to-high transition of WRTCLK. When programming an AF/AE offset value, WRTEN1/DP9 is used as the most significant data bit. |
| WRTEN2 | I | Write enable. When WRTEN1/DP9, WRTEN2, and IRare high, datais written to the FIFO on alow-to-hightransition of WRTCLK. |

functional block diagram


## SCAS200-D4005, JANUARY 1991-REVISED APRIL 1992

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost-empty offset value $(X)$ and the almost-full offset value ( Y ). They may be programmed after the FIFO is reset and before the first word is written to memory. If the offsets are not programmed, the default values of $X=Y=256$ are used. The AF/AE flag is high when the FIFO contains X or less words or ( 2048 minus $Y$ ) or more words.

Program enable (PEN) should be held high throughout the reset cycle. PEN may be brought low only when IR is high and WRTCLK is low. On the following low-to-high transition of WRTCLK, the binary value on D0-D8 and WRTEN1/DP9 is stored as the almost empty offset value $(X)$ and the almost full offset value ( Y ). Holding PEN low for another low-to-high transition of WRTCLK reprograms $Y$ to the binary value on D0-D8 and WRTEN1/DP9 at the time of the second WRTCLK low-to-high transition. While the offsets are programmed, data is not written to the FIFO memory regardless of the state of the write enables (WRTEN1/DP9, WRTEN2).

A maximum value of 1023 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=256$, PEN must be held high.

## timing diagrams



Figure 1. Programming $X$ and $Y$ Separately
timing diagrams (continued)


Flgure 2. Reset Cycle: Define AF/AE Using the Default

## 2048 X 9 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS200-D4005, JANUARY 1991-REVISED APRIL 1992

## timing diagrams (continued)



Figure 3. Write


Figure 4. Read

## SN74ACT7807 <br> 2048 X 9 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS200-D4005, JANUARY 1991-REVISED APRIL 1992

## 



Voltage applied to a disabled 3-state output .............................................................. 5.5 V
Operating free-air temperature range ............................................................ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . .................................................................... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
t Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions



[^3]
## SN74ACT7807 <br> 2048 X 9 CLOCKED FIRST-IN, FIRST-OUT MEMOKY

SCAS200-D4005, JANUARY 1991-REVISED APRIL 1992
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {t }}$ MAX | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  | V |
| $V_{\text {OL }}$ | Flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{C C}$ or 0 |  | $\pm 5$ | $\mu \mathrm{A}$ |
| 102 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{cc}}$ cr 0 |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{Cc}}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ or 0 |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcc}^{\ddagger}$ | WRTEN1/DP9 | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, One input at 3.4 V, Other inputs at $\mathrm{V}_{C C}$ or GND |  |  | 2 | mA |
|  | Other inputs |  |  |  | 1 |  |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 4 | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 8 | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 9 and 10)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (NPUT) } \end{aligned}$ | TO (OUTPUT) | 'ACT7807-15 |  |  | 'ACT7807-20 |  | 'ACT7807-25 |  | 'ACT7807-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 67 |  |  | 50 |  | 40 |  | 25 |  | MHz |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | Any Q | 3 | 9 | 12 | 3 | 13 | 3 | 18 | 3 | 25 | ns |
| $\mathrm{t}_{\text {dd }}{ }^{\text {g }}$ |  |  |  | 8 |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {pd }}$ | WRTCLK $\dagger$ | IR | 1 |  | 9 | 1 | 12 | 1 | 14 | 1 | 16 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | RDCLK $\uparrow$ | OR | 1 |  | 9 | 2 | 12 | 2 | 14 | 2 | 16 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | WRTCLK $\uparrow$ | AF/AE | 2 |  | 16 | 2 | 20 | 2 | 25 | 2 | 30 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | AF/AE | 2 |  | 17 | 2 | 20 | 2 | 25 | 2 | 30 | ns |
| $\mathrm{t}_{\text {PLH }}$ | WRTCLK $\dagger$ | HF | 2 |  | 19 | 2 | 21 | 2 | 23 | 2 | 25 | ns |
| ${ }_{\text {¢ }}$ | RDCLK $\uparrow$ |  | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 |  |
| tplu | RESET low | AF/AE | 1 |  | 12 | 1 | 18 | 1 | 22 | 1 | 24 | ns |
| $\mathrm{tPHL}^{\text {che }}$ |  | HF | 2 |  | 12 | 2 | 18 | 2 | 22 | 2 | 24 |  |
| ten | OE | Any Q | 2 |  | 10 | 2 | 13 | 2 | 15 | 2 | 18 | ns |
| $t_{\text {dis }}$ |  |  | 1 |  | 11 | 1 | 13 | 1 | 15 | 1 | 18 |  |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.
${ }^{\$}$ This parameter is measured with $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 7).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDMONS | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $C_{p d}$ Power dissipation capacitance per FFFO channel | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad f=5 \mathrm{MHz}$ | 91 | pF |

APPLICATION INFORMATION


Flgure 5. Word-Depth Expansion: 4096 Words by 9 Blts


Figure 6. Word-Width Expansion: 2048 Words by 18 Blts

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
vs
LOAD CAPACITANCE


Figure 7
SUPPLY CURRENT
v3
CLOCK FREQUENCY


Flgure 8

## calculating power dissipation

With ICCF taken from Figure 8, the maximum power dissipation may be calculated using:

$$
P_{t}=V_{c c} \times\left[l_{c C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C^{2}} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c}{ }^{2} \times f 0\right)
$$

$I_{\text {cc }}=$ power-down Icc maximum
$N=$ number of inputs driven by a TTL device
$\Delta I_{\text {CC }}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{i}=$ data input frequency
$f_{0}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



Figure 9. Standard CMOS Outputs (IR, OR, HF, AF/AE)


Figure 10. 3-State Outputs (Any Q)

- Member of the Texas Instruments Widebus ${ }^{\text {TM }}$ Family
- Independent Asynchronous Inputs and Outputs
- 1024 Words $\times 18$ Bits
- Read and Write Operatlons Can Be Synchronized to Independent System Clocks
- Programmable Almost Full/Almost Empty Flag
- Input Ready, Output Ready, and Half-Full Flags
- Cascadable In Word WIdth and/or Word Depth
- Fast Access Times of 15 ns With a 50-pF Load
- High Output Drive for Direct Bus Interface
- Avallable In 68-PIn PLCC (FN) or Space-Saving 80-Pin Shrink Quad Flat Pack (PN)



NC - No internal connection

## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7811 is a $1024-\times 18$-bit FIFO for high speed and fast access times. It processes data at rates up to 40 MHz and access times of 15 ns in a bit-parallel format. Data outputs are noninverting with respect to the data inputs. Expansion is easily accomplished in both word width and word depth.

The SN74ACT7811 has normal input-bus-to-output-bus asynchronous operation. The special enable circuitry adds the ability to synchronize independent read and write (interrupts, requests) to their respective system clock.

## logic symbol ${ }^{\dagger}$


${ }^{\dagger}$ This symbol is in accordance with ANSI/REEE Std 91-1984 and IEC Publication 617-12 Pin numbers shown are for the FN package.
functional block diagram


## terminal functions

## Inputs

data In (D0-D17)
Data inputs for 18 -bit-wide data to be stored in the memory. Data lines D0-D8 also carry the almost full/almost empty offset value ( X ) on a high-to-low transition of the define almost full (DAF) input.
reset (RESET)
A reset is accomplished by taking reset (RESET) low and generating a minimum of four read clock (RDCLK) and write clock (WRTCLK) cycles. This ensures that the internal read and write pointers are reset and that the output ready flag (OR), the half-full flag (HF), and the input ready flag (IR) are low; the almost full/almost empty flag (AF/AE) is high. The FIFO must be reset upon power up. With the define almost full (DAF) input at a low level, a low pulse on RESET defines the AF/AE status flag using the almost full/almost empty offset value ( X ), where $X$ is the value previously stored. With DAF at a high level, a low-level pulse on RESET defines the AF/AE flag using the default value of $X=256$.
write enables (WRTEN1, WRTEN2)
The write enables (WRTEN1, WRTEN2) must be high before the rising edge of write clock (WRTCLK) for a word to be written into memory. The write enables do not affect the storage of the almost full/almost empty offset value ( $X$ ).

## terminal functions (continued)

## write clock (WRTCLK)

Data is written into memory on a low-to-high transition of the write clock (WRTCLK) if the input ready flag output (IR) and the write enable control inputs (WRTEN1, WRTEN2) are high. WRTCLK is a free-running clock and functions as the synchronizing clock for all data transfers into the FIFO. The IR flag output is also driven synchronously with respect to the WRTCLK signal.

## read enables (RDEN1, RDEN2)

Both read enables (RDEN1, RDEN2) must high before the rising edge of read clock (RDCLK) to read a word out of memory. The read enables are not used to read the first word stored in memory.

## read clock (RDCLK)

Data is read out of memory on a low-to-high transition at the read clock (RDCLK) input if the output ready flag output (OR) and the output enable (OE) and read enable (RDEN1, RDEN2) control inputs are high. RDCLK is a free-running clock and functions as the synchronizing clock for all data transfers out of the FIFO. The OR flag is also driven synchronously with respect to the RDCLK signal.

## define almost full (DAF)

The high-to-low transition of the define almost full (DAF) input stores the binary value of data inputs D0-D8 as the almost full/almost empty offset value ( $X$ ). With DAF held low, a low pulse on the reset (RESET) input defines the almost full/almost empty flag (AF/AE) using $X$.

## output enable (OE)

The data out (Q0-Q17) outputs are in the high-impedance state when the output enable (OE) input is low. OE must be high before the rising edge of read clock (RDCLK) to read a word from memory.

## outputs

## data out (QO-Q17)

The first data word to be loaded into the FIFO is moved to the data out (Q0-Q17) register on the rising edge of the third read clock (RDCLK) pulse to occur after the first valid write. The read enable (RDEN1, RDEN2) inputs do not affect this operation. Following data is unloaded on the rising edge of RDCLK when RDEN1, RDEN2, and the output ready flag (OR) are high.

## Input ready flag (IR)

The input ready flag (IR) is high when the FIFO is not full and low when the device is full. During reset, the IR flag is driven low on the rising edge of the second write clock (WRTCLK) pulse. The IR flag is driven high on the rising edge of the second WRTCLK pulse after RESET goes high. After the FIFO is filled and IR is driven low, IR is driven high on the second WRTCLK pulse after the first valid read.

## output ready flag (OR)

The output ready flag (OR) is high when the FIFO is not empty and low when it is empty. During reset, the OR flag is set low on the rising edge of the third read clock (RDCLK) pulse. The OR flag is set high on the rising edge of the third RDCLK pulse to occur after the first word is written into the FIFO. OR is set low on the rising edge of the first RDCLK pulse after the last word is read.

## half-full status flag (HF)

The half-full flag (HF) is high when the FIFO contains 513 or more words and is low when it contains 512 or less words.

## almost full/almost empty status flag (AF/AE)

The almost full/almost empty flag (AF/AE) is defined by the almost full/almost empty offset value ( $X$ ). The AF/AE flag is high when the FIFO contains $(X+1)$ or less words or $(1025-X)$ or more words. The AF/AE flag is low when the FIFO contains between $(X+2)$ and $(1024-X)$ words.

## terminal functions (continued)

## programming procedure for AF/AE

The almost full/almost empty fiag (AF/AE) is programmed during each reset cycle. The almost full/almost empty offset value $(X)$ is either a user-defined value or the default value of $X=256$. Below are instructions to program AF/AE using both methods.

## user-defined $X$ :

Step 1. Take DAF from high to low.
Step 2. If RESET is not already low, take RESET low.
Step 3. With DAF held low, take RESET high. This defines the AF/AE flag using $X$.
Step 4. To retain the current offset for the next reset, keep DAF low.
default $X$ :
To redefine the AF/AE flag using the default value of $X=256$, hold DAF high during the reset cycle.
timing diagrams


Flgure 1. Reset Cycle: Define AF/AE Using the Value of $X$


Figure 2. Reset Cycle: Define AF/AE Using the Default Value


Flgure 3. Write


Figure 4. Read

## absolute maximum ratings over operating free-air temperature range (unless otherwicc noted) ${ }^{\dagger}$

$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings onty, and
functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not
implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
recommended operating conditions

|  |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | Supply voltage | 4.5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  | V |
| $\mathrm{V}_{\mathrm{lL}}$ | Low-level input voltage |  | 0.8 | V |
| IOH | High-level output current |  | -8 | mA |
| loL | Low-lavel output current |  | 16 | mA |
| TA | Operating free-air temperature | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MiN | TYP ${ }^{\text { }}$ | MAX | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage | $\mathrm{V}_{C C}=4.5 \mathrm{~V}_{1}$ | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 | V |
| II | Input current | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 V |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz | High-impedance-state output current | $V_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\text {cc }}$ or OV |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{lcc}^{5}$ |  | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ or 0 V |  |  |  | 400 | $\mu \mathrm{A}$ |
|  |  | One input at 3.4 V , | Other inputs at $\mathrm{V}_{C C}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| $C_{0}$ |  | $\mathrm{V}_{0}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ |  |  | 8 |  | pF |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{5} \mathrm{I}_{\mathrm{CC}}$ tested with outputs open.

## SN74ACT7811

1024 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY
WITH 3-STATE OUTPUTS
SCAS151A-D3729, JANUARY 1991-REVISED FEBRUARY 1992
timing requirements


[^4]switching characteristics over recommended operating free-air temperature range (see Figures 9 and 10)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & V_{C c}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & R_{L}=500 \Omega \\ & T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}{ }^{\dagger} \end{aligned}$ |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 'ACT7811-15 |  |  | 'ACT7811-18 |  | 'ACT7811-20 |  | 'ACT7811-25 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 40 |  |  | 35 |  | 28.5 |  | 16.7 |  | MHz |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | Any Q | 4 | 12 | 15 | 4 | 18 | 4 | 20 | 4 | 25 | ns |
| $\mathrm{tpd}^{\ddagger}$ |  |  |  | 10.5 |  |  |  |  |  |  |  |  |
| $t_{\text {pd }}$ | WRTCLK $\dagger$ | IR | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | OR | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 | ns |
| $t_{\text {pd }}$ | WRTCLK $\uparrow$ | AF/AE | 6 |  | 20 | 6 | 22 | 6 | 24 | 6 | 26 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | AF/AE | 6 |  | 20 | 6 | 22 | 6 | 24 | 6 | 26 | ns |
| tplH | WRTCLK $\dagger$ | HF | 6 |  | 19 | 6 | 21 | 6 | 23 | 6 | 25 | ns |
| tphL | RDCLK $\uparrow$ |  | 6 |  | 19 | 6 | 21 | 6 | 23 | 6 | 25 |  |
| tpli | RESET $\downarrow$ | AF/AE | 3 |  | 19 | 3 | 21 | 3 | 23 | 3 | 25 | ns |
| tpHL |  | HF | 4 |  | 21 | 4 | 23 | 4 | 25 | 4 | 27 |  |
| ten | OE | Any Q | 2 |  | 11 | 2 | 11 | 2 | 11 | 2 | 11 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 2 |  | 14 | 2 | 14 | 2 | 14 | 2 | 14 |  |

$\dagger$ For conditions shown as MIN or MAX, use the appropriate value under recommended operating conditions.
$\ddagger$ This parameter is measured with $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 5).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDTIONS | TYP | UNIT |
| :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{pd}} \quad$ Power dissipation capacitance per 1 K bits | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \quad \mathrm{f}=5 \mathrm{MHz}$ | 65 | pF |

TYPICAL CHARACTERISTICS
TYPICAL PROPAGATION DELAY TIME
v8
LOAD CAPACITANCE


Flgure 5

## TYPICAL CHARACTERISTICS

## TYPICAL POWER DISSIPATION CAPACITANCE

vs
SUPPLY VOLTAGE


$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c^{2}} \times f o\right)
$$

Icc = power-down Icc maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta \mathrm{I}_{\mathrm{CC}}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$\mathrm{f}_{\mathrm{i}}=$ data input frequency
$\mathrm{f}_{\mathrm{o}}=$ data output frequency
Flgure 6

## SN74ACT7811

## 1024 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY

## WITH 3-STATE OUTPUTS

## APPLICATION DATA

## expanding the SN74ACT7811

The SN74ACT7811 is expandable in width and depth. Expanding in word depth offers special timing considerations:

1. After the first data word is loaded into the FIFO, the word is unloaded, and the output ready flag output (OR) goes high after $(\mathbf{N} \times 3)$ read clock (RDCLK) cycles, where $N$ is the number of devices used in depth expansion.
2. After the FIFO is filled, the input ready flag output (IR) goes low, the first word is unloaded, and the IR flag output is driven high after ( $\mathrm{N} \times 2$ ) write clock cycles, where N is the number of devices used in depth expansion.


Figure 7. Word-Depth Expansion: 2048 Words $\times 18$ Blts, $\mathrm{N}=2$


Figure 8. Word-Width Expansion: 1024 Words $\times 36$ Blts

PARAMETER MEASUREMENT INFORMATION


Flgure 9. Standard CMOS Outputs


| PARAMETER |  | R1, R2 | $\mathrm{C}^{\dagger}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | ¢ P ZH | $500 \Omega$ | 50 pF | Open |
|  | ¢ ${ }_{\text {ZL }}$ |  |  | Closed |
| $\mathrm{t}_{\text {dis }}$ | $\dagger_{\text {PHz }}$ | 500 Q | 50 pF | Open |
|  | $\mathrm{t}_{\text {PLZ }}$ |  |  | Closed |
| $t_{\text {pd }}$ |  | $500 \Omega$ | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 10. 3-State Outputs (Any Q)

- Member of the Texas Instruments Widebus ${ }^{\text {rM }}$ Family
- Free-Running Read and Write Clocks May Be Asynchronous or Colncident
- Read and Write Operations Synchronized to Independent System Clocks
- Input-Ready Flag Synchronized to Write Clock
- Output-Ready Flag Synchronlzed to Read Clock
- Packaged In Shrink Small-Outline 300-mll Package (DL) UsIng 25-mII Center-to-Center Spaclng
- 64 Words by 18 Blts
- Low-Power Advanced CMOS Technology
- Half-Full Flag and Programmable Almost Full/Almost Empty Flag
- Bidirectional Conflguration and Width Expansion Without Additional Loglc
- Fast Access Times of 12 ns With a 50-pF Load and All Data Outputs Switching Simultaneously
- Data Rates From 0 to 67 MHz
- Pin Compatlble With SN74ACT7803 and SN74ACT7805


## description

The SN74ACT7813 is a 64 -word $\times 18$-bit FIFO suited for buffering asynchronous data paths at $67-\mathrm{MHz}$ clock rates and $12-n s$ access times. Its 56-pin shrink small-outline package (DL) offers greatly reduced board space over DIP, PLCC, and conventional SOIC packages. Two devices may be configured for bidirectional data buffering without additional logic. Multiple distributed $V_{C C}$ and GND pins along with Tl's patented Output Edge Control (OEC ${ }^{\text {t" }}$ ) circuit dampen simultaneous switching noise.


The write clock (WRTCLK) and read clock (RDCLK) should be free-running and may be asynchronous or coincident. Data is written to memory on the rising edge of WRTCLK when WRTEN1 is high, WRTEN2 is low, and IR is high. Data is read from memory on the rising edge of RDCLK when RDEN, OE1, and OE2 are low and OR is high. The first word written to memory is clocked through to the output buffer regardless of the RDEN, OET, and OE2 levels. The OR flag indicates that valid data is present on the output buffer.

The FIFO may be reset asynchronously to WRTCLK and RDCLK. RESET must be asserted while at least four WRTCLK and four RDCLK rising edges occur to clear the synchronizing registers. Resetting the FIFO initializes the IR, OR, and HF flags low and the AF/AE flag high. The FIFO must be reset upon power up.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12

## functional block diagram



## Terminal Functions

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | No. | 1/0 |  |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 8 may be used for both the almost-empty offset $(X)$ and the almost-full offset ( $)$. AF/AE is high when memory contains $X$ or less words or ( 64 minus $Y$ ) or more words. AF/AE is high after reset. |
| D0-D17 | 21-14, 12-11, 9-2 | 1 | 18-bit data input port |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 32 or more words. HF Is low after reset. |
| IR | 28 | 0 | Input ready flag. IR is synchronized to the low-to-high transition of WRTCLK. When IR Is low, the FIFO is full and writes are disabled. IR is low during reset and goes high on the second low-to-high transition of WRTCL.K after reset. |
| ОE1, రE2 | - 56,30 | 1 | Output enables. When ठE1, రE2, and RDEN are low and OR is high, data is read from the FIFO on a low-to-high transition of RDCLK. When either $\overline{\mathrm{OET}}$ or OE 2 is high, reads are disabled, and the data outputs are in the high-impedance state. |
| OR | 29 | 0 | Output ready flag. OR is synchronized to the low-to-high transition of RDCLK. When OR is low, the FIFO is empty and reads are disabled. Ready data is present on Q0-Q17 when OR is high. OR is low during reset and goes high on the third low-to-high transition of RDCL.K after the first word is loaded to empty memory. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on DO-D4 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49,51, \\ 53-55 \end{gathered}$ | 0 | 18 -bit data output port. After the first valid write to empty memory, the first word is output on Q0-Q17 on the third rising edge of RDCLK. OR is also asserted high at this time to indicate ready data. When OR is low, the last word read from the FIFO is present on Q0-Q17. |
| RDCLK | 32 | 1 | Read clock. RDCLK is a continuous clock and may be asynchronous or coincident to WRTCLK. A low-to-high transition of RDCLK reads data from memory when OET, OE2, and RDEN are low and $O R$ is high. OR is synchronous to the low-to-high transition or RDCLK. |
| RDEN | 31 | 1 | Read enable. When RDEN, $\overline{\mathrm{OE}}$, and $\overline{\mathrm{OE} 2}$ are low and OR is high, data is read from the FIFO on the low-to-high transition of RDCLK. |
| RESET | 1 | 1 | Reset. To reset the FIFO, four low-to-high transitions of RDCLK and four low-to-high transitions of WRTCLK must occur while RESET is low. This sets HF, IR, and OR low and AF/AE high. |
| WRTCLK | 25 | 1 | Write clock. WRTCLK is a continuous clock and may be asynchronous or coincident to RDCLK. A low-to-high transition of WRTCLK writes data to memory when WRTEN2 is low, WRTEN1 is high, and IR is high. IR is synchronous to the low-to-high transition of WRTCLK. |
| WFTEN1, WRTEN2 | 27, 26 | 1 | Write enables. When WRTEN1 is high, WRTEN2 is low, and IR is high, data is written to the FIFO on a low-to-high transition of WRTCLK. |

## SN74ACT7813 <br> 64 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCAS199-D4002, JANUARY 1991-REVISED APRIL 1992
timing diagram


Flgure 1. Reset Cycle

## SCAS199-D4002, JANUARY 1991-REVISED APRIL. 1992

## timing diagram



Figure 2. Write

## timing diagram



Flgure 3. Read

## SN74ACT7813

64 X 18 CLOCKED FIRST-IN, FIRST-OUT MEMORY

## SCAS199-D4002, JANUARY 1991-REVISED APRIL 1992

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost empty offset value $(X)$ and the almost full offset value ( $M$ ). They may be programmed after the FIFO is reset and before the first word is written to memory. If the offsets are not programmed, the default values of $X=Y=8$ are used. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 64 minus $Y$ ) or more words.
Program enable (PEN) should be held high throughout the reset cycle. PEN may be brought low only when IR is high and WRTCLK is low. On the following low-to-high transition of WRTCLK, the binary value on D0-D4 is stored as the almost empty offset value $(X)$ and the almost full offset value ( $Y$ ). Holding PEN low for another low-to-high transition of WRTCLK will reprogram Y to the binary value on D0-D4 at the time of the second WRTCLK low-to-high transition. When the offsets are being programmed, writes to the FIFO memory are disabled regardless of the state of the write enables (WRTEN1, WRTEN2). A maximum value of 31 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=8$, PEN must be held high.

## timing diagram



Figure 4. Programming $X$ and $Y$ Separately

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

$\qquad$
$\qquad$
Voltage applied to a disabled 3-state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

[^5]recommended operating conditions

$\dagger$ To permit the clock pulse to be utilized for reset purposes.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {¢ }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | Flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | $\mathrm{V}_{1}=\mathrm{V}_{C C}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| l |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{cc}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| Icc |  | $V_{1}=V_{C C}-0.2$ |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{l}_{\mathrm{CC}}{ }^{\ddagger}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $V_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 8 |  | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 9 and 10)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | 'ACT7813-15 |  |  | 'ACT7813-20 |  | 'ACT7813-25 |  | 'ACT7813-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYPt | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | WRTCLK or RDCLK |  | 67 |  |  | 50 |  | 40 |  | 25 |  | MHz |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | Any Q | 4 | 9.5 | 12 | 4 | 13 | 4 | 15 | 4 | 20 | ns |
| $t_{\text {d }}{ }^{5}$ |  |  |  | 8.5 |  |  |  |  |  |  |  |  |
| $t_{\text {pd }}$ | WRTCLK ${ }_{\text {¢ }}$ | IR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | OR | 3 |  | 8.5 | 3 | 11 | 3 | 13 | 3 | 15 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | WRTCLK $\dagger$ | AF/AE | 7 |  | 16.5 | 7 | 19 | 7 | 21 | 7 | 23 | ns |
| $t_{\text {pd }}$ | RDCLK $\uparrow$ | AF/AE | 7 |  | 17 | 7 | 19 | 7 | 21 | 7 | 23 | ns |
| ${ }_{\text {tPLH }}$ | WRTCLK ${ }^{\text {¢ }}$ | HF | 7 |  | 15 | 7 | 17 | 7 | 19 | 7 | 21 | ns |
| tpHL | RDCLK $\uparrow$ |  | 7 |  | 15.5 | 7 | 18 | 7 | 20 | 7 | 22 |  |
| +pLH | RESET low | AF/AE | 2 |  | 9 | 2 | 11 | 2 | 13 | 2 | 15 | ns |
| ${ }_{4}{ }_{\text {HL }}$ |  | HF | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 |  |
| ten | OE1, OE2 | Any Q | 2 |  | 8.5 | 2 | 11 | 2 | 11 | 2 | 11 | ns |
| $t_{\text {dis }}$ |  |  | 2 |  | 9.5 | 2 | 11 | 2 | 14 | 2 | 14 |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.
${ }^{5}$ This parameter is measured with a 30 pF load (see Figure 7).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $C_{p d} \quad$ Power dissipation capacitance | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad f=5 \mathrm{MHz}$ | 53 | pF |

## APPLICATION DATA



Figure 5. Bidirectlonal Configuration


Flgure 6. Word-Width Expansion: $64 \times 36$ Blts

## TYPICAL CHARACTERISTICS



Figure 7


Figure 8

## calculating power dissipation

With I CCF taken from Figure 8, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f o\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c^{2}}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{C C^{2}}^{2} \times f o\right)
$$

$\mathrm{I}_{\mathrm{CC}}=$ power-down $\mathrm{I}_{\mathrm{cc}}$ maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta I_{C C}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{i}=$ data input frequency
$f_{0}=$ data output frequency

PARAMETER MEASUREMENT INFORMATION


Figure 9. Standard CMOS Outputs (IR, OR, HF, AF/AE)


| PARAMETER |  | R1, R2 | $\mathrm{CL}^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | ${ }_{\text {PZH }}$ | 500 \& | 50 pF | Open |
|  | t ${ }_{\text {¢ }}$ |  |  | Closed |
| $\mathrm{t}_{\text {dis }}$ | tPHz | 5008 | 50 pF | Open |
|  | tplz |  |  | Closed |
| $t_{\text {dod }}$ |  | 500 \& | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 10. 3-State Outputs (Any Q)

| General information | 1 - |
| :---: | :---: |
| Unidirectional Clocked firosm |  |
| Unidirectional FIFOs | 531-3 |
| Bidirectional Chacked FiFos | 4. 杼 |
| Bidirectional firdos | 55 |
| Product Provious |  |
| Artiches and Application Notes |  |
| Rhechanical Datia | 58********* |

- Member of the Texas Instruments Widebus ${ }^{\text {m" }}$ Famlly
- Independent Asynchronous Inputs and Outputs
- Low-Power Advanced CMOS Technology
- 1024 Words $\times 18$ Blts
- Programmable Almost Full/Almost Empty Fling
- Empty, Full, and Half-Full Flags
- Fast Access Times of 15 ns With a 50-pF Load
- Fall-Through Time . . . 20 ns Typlcal
- Data Rates From 0 to 50 MHz
- High-Output Drive for Dlrect Bus Interface
- 3-State Outputs
- Available In 68-PIn PLCC (FN) Package

FN PACKAGE
(TOP VEW)


NC-No internal connection

## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7802 is a 1024-by 18-bit FIFO for high-speed applications. It processes data in a bit-parallel format at rates up to 50 MHz and access times of 25 ns .

Data is written into the FIFO memory on a low-to-high transition on the load clock input (LDCK) and is read out on a low-to-high transition on the unload clock input (UNCK). The memory is full when the number of words clocked in exceeds by 1024 the number of words clocked out. When the memory is full, LDCK has no effect on the data in the memory; when the memory is empty, UNCK has no effect.

## SCAS187-D3599,AUGUST 1990-REVISED DECEMBER 1991

## description (continued)

The FIFO memory status is monitored by the full (FULL), empty (EMPTY), half-full (HF), and almost full/almost empty (AF/AE) flags. The FULL output is low when the memory is full; the EMPTY output is low when the memory is empty. The HF output is high when the memory contains 512 or more words and low when it contains less than 512 words. The level of the AF/AE flag is determined by both the number of words in the FIFO and a user-definable offset X. AF/AE is high when the FIFO is almost full or almost empty, i.e., when it contains $X$ or less words or ( $1024-X$ ) or more words. The almost fullalmost empty offset value is either user-defined or the default value of 256 ; it is programmed during each reset cycle as follows:

## user-defined $X$ :

Step 1. Take DAF from high to low.
Step 2. If RESET is not already low, take RESET low.
Step 3. With DAF held low, take RESET high. This defines the AF/AE flag using $X$.

## default $X$ :

To redefine the AF/AE flag using the default value of $X=256$, hold DAF high during the reset cycle.
A low level on the reset (RESET) input resets the FIFO internal clock stack pointers and sets FULL high, AF/AE high, HF low, and EMPTY low. The Q outputs are not reset to any specific logic level. The FIFO múst be reset upon power up.
The $Q$ outputs are noninverting and are in the high-impedance state when the output-enable (OE) input is low.
When writing to the FIFO after a reset pulse or when the FIFO is empty, the first active transition on LDCK drives EMPTY high and causes the first word written to the FIFO to appear on the Q outputs. Therefore, an active transition on UNCK is not required to read the first word written to the FIFO. Each subsequent read from the FIFO requires an active transition on UNCK.
The SN74ACT7802 can be cascaded in the word-width direction but not in the word-depth direction.

## logic symbol ${ }^{\dagger}$


† This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
functional block diagram

timing diagram


Define the AF/AE offset value (X)
usling the data on DO-D8

## SN74ACT7802 <br> 1024 X 18 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

## SCAS187-D3599, AUGUST 1990-REVISED DECEMBER 1991

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

| Supply voltage range, $\mathrm{V}_{\mathrm{Cc}}$ | -0.5 V to 7 V |
| :---: | :---: |
| Input voltage, $\mathrm{V}_{1}$ | 7 V |
| Voltage applied to a disabled 3-state output | 5.5 V |
| Operating free-air temperature range | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $5^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions

|  |  |  | 'ACT7802-20 |  | 'ACT7802-30 |  | 'ACT7802-40 |  | 'ACT7802-60 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5.5 | 4.5 | 5.5 | 4.5 | 5.5 | 4.5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  | 2 |  | 2 |  | 2 |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  | 0.8 |  | 0.8 |  | 0.8 | V |
| IOH | High-level output current |  |  | -8 |  | -8 |  | -8 |  | -8 | mA |
| loL | Low-lovel output current |  |  | 16 |  | 16 |  | 16 |  | 16 | mA |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency |  | 50 |  | 33 |  | 25 |  | 16.7 |  | MHz |
| tw | Pulse duration | LDCK high | 8 |  | 10 |  | 14 |  | 20 |  | ns |
|  |  | LDCK low | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | UNCK high | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | UNCK low | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | DAF high | 10 |  | 10 |  | 10 |  | 10 |  |  |
|  |  | RESET low | 20 |  | 20 |  | 25 |  | 25 |  |  |
| $t_{s u}$ | Setup time | Data in (D0-D7) before LDCK $\dagger$ | 4 |  | 4 |  | 5 |  | 5 |  | ns |
|  |  | RESET inactive (high) before LDCK $\uparrow$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
|  |  | Define AF/AE: DO-D8 before DAF $\downarrow$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
|  |  | Define AF/AE: DAF $\downarrow$ before RESET $\uparrow$ | 7 |  | 7 |  | 7 |  | 7 |  |  |
|  |  | Define AF/AE (default): DAF high before RESET $\dagger$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
| ¢ | Hold time | Data in (D0-D7) after LDCK $\uparrow$ | 1 |  | 1 |  | 2 |  | 2 |  | ns |
|  |  | Define AF/AE: D0-D8 after DAF $\downarrow$ | 0 |  | 0 |  | 0 |  | 0 |  |  |
|  |  | Define AF/AE: DAF low after RESET $\dagger$ | 0 |  | 0 |  | 0 |  | 0 |  |  |
|  |  | Define AF/AE (default): DAF high atter RESET $\uparrow$ | 0 |  | 0 |  | 0 |  | 0 |  |  |
| TA | Operating free-air temperature |  | 0 | 70 | 0 | 70 | 0 | 70 | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITONS |  |  | MIN | TYPt | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ |  | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| 1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{OZ}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{cc}}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $1 \mathrm{lc}^{\ddagger}$ | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}-0.2 \mathrm{~V}$ or 0 |  |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcC}^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | One input at 3.4 V, | Other inputs at $\mathrm{V}_{\text {cC }}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ | $V_{1}=0$, | $f=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| $\mathrm{C}_{0}$ | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  |  | 8 |  | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (see Figures 4 and 5)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (NPUT) } \end{aligned}$ | TO (OUTPUT) | 'ACT7802-20 |  |  | 'ACT7802-30 |  | 'ACT7802-40 |  | 'ACT7802-60 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYPt | MAX | MiN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK or UNCK |  | 50 |  |  | 33 |  | 25 |  | 16.7 |  | MHz |
| $t_{\text {pd }}$ | LDCK $\uparrow$ | Any Q | 8 |  | 25 | 8 | 30 | 8 | 35 | 8 | 45 | ns |
| $\mathrm{t}_{\mathrm{pd}}{ }^{5}$ | UNCK $\uparrow$ | Any Q | 12 | 21 | 25 | 12 | 30 | 12 | 35 | 12 | 45 | ns |
| $t_{\text {PLH }}$ | LDCK $\dagger$ | EMPTY | 4 |  | 16 | 4 | 18 | 4 | 20 | 4 | 22 | ns |
| $t_{\text {PHL }}$ | UNCK $\uparrow$ |  | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 |  |
| $\mathrm{t}_{\text {PHL }}$ | RESET $\downarrow$ | EMPTY | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| $\mathrm{t}_{\text {PHL }}$ | LDCK $\dagger$ | FULL | 4 |  | 16 | 4 | 18 | 4 | 20 | 4 | 22 | ns |
| $t_{\text {PLH }}$ | UNCK $\dagger$ | FULL | 4 |  | 15 | 4 | 17 | 4 | 19 | 4 | 21 | ns |
|  | RESET $\downarrow$ |  | 2 |  | 15 | 2 | 17 | 2 | 19 | 2 | 21 |  |
| $t_{\text {pd }}$ | LDCK $\dagger$ | AF/AE | 2 |  | 18 | 2 | 20 | 2 | 22 | 2 | 24 | ns |
|  | UNCK ${ }^{\text {¢ }}$ |  | 2 |  | 18 | 2 | 20 | 2 | 22 | 2 | 24 |  |
| $\mathrm{t}_{\text {PLH }}$ | RESET $\downarrow$ | AF/AE | 2 |  | 15 | 2 | 17 | 2 | 19 | 2 | 21 | ns |
| $\mathrm{t}_{\text {PLH }}$ | LDCK $\dagger$ | HALF FULL | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| ${ }^{\text {t }}$ PHL | UNCK $\uparrow$ | HALF FULL | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
|  | RESET $\downarrow$ |  | 2 |  | 15 | 2 | 17 | 2 | 19 | 2 | 21 |  |
| $t_{\text {en }}$ | OE | Any Q | 2 |  | 10 | 2 | 12 | 2 | 14 | 2 | 16 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE | Any Q | 2 |  | 12 | 2 | 14 | 2 | 16 | 2 | 18 | ns |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ lcc tosted with outputs open.
§ This parameter is measured with $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 1).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDTIONS | TYP | UNIT |
| :--- | ---: | ---: | ---: |
| Cpd | Power dissipation capacitancer per channel | CL $=50 \mathrm{pF}$ | $\mathrm{f}=5 \mathrm{MHz}$ |

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
vs
LOAD CAPACITANCE


Figure 1

TYPICAL POWER DISSIPATION CAPACITANCE vs SUPPLY VOLTAGE


Flgure 2

## calculating power dissipation

With I CCF taken from Figure 2, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C c F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c^{2}} \times f i\right)+\Sigma\left(C_{L} \times V_{c c^{2}} \times f o\right)
$$

$\mathrm{I}_{\mathrm{cc}}=$ power-down $\mathrm{I}_{\mathrm{cc}}$ maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta I_{C C}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{1}=$ data input frequency
$f_{0}=$ data output frequency

## SCAS187-D3599, AUGUST 1990-REVISED DECEMBER 1991

APPLICATION DATA


Figure 3. Word-Width Expansion: 1024-Word by 36-Blt

PARAMETER MEASUREMENT INFORMATION


Flgure 4. Standard CMOS Outputs (FULL, HF, AF/AE, EMPTY)


[^6]Flgure 5. 3-State Outputs (Any Q)

- Member of the Texas Instruments Widebus ${ }^{\text {TM }}$ Family
- Load Clock and Unload Clock May Be Asynchronous or Coincldent
- Packaged In Shrink Small-Outline 300-mil Package (DL) Using 25-mil Center-to-Center Spacing
- 512 Words by 18 Blts
- Low-Power Advanced CMOS Technology
- Full, Empty, and Half-Full Flags
- Programmable Almost Full/Almost Empty Flag
- Fast Access Times of 15 ns With a $50-\mathrm{pF}$ Load and All Data Outputs Swltching Simultaneously
- Data Rates From 0 to 50 MHz
- 3-State Outputs
- Pin Compatlble With SN74ACT7806 and SN74ACT7814


## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7804 is a 512-word by 18 -bit FIFO for high speed and fast access times. It processes data at rates up to 50 MHz and access times of 15 ns in a bit-parallel format.

Data is written into memory on a low-to-high transition at the load clock (LDCK) input and is read out on a low-to-high transition at the unload clock (UNCK) input. The memory is full when the number of words clocked in exceeds the number of words clocked out by 512. When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the full (FULL), empty (EMPTY), half-full (HF), and almost full/almost empty (AF/AE) flags. The FULL output is low when the memory is full and high when the memory is not full. The EMPTY output is low when the memory is empty and high when it is not empty. The HF output is high when the FIFO contains 256 or more words and is low when it contains 255 or less words. The AF/AE status flag is a programmable flag. The first one or two low-to-high transitions of LDCK after reset are used to program the almost-empty offset value ( $X$ ) and the almost-full offset value ( $Y$ ) if program enable ( PEN ) is low. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 512 minus $Y$ ) or more words. The AF/AE flag is low when the FIFO contains between ( X plus 1) and ( 511 minus Y ) words.

Widebus is a trademark of Texas Instruments Incorporated.

## description (continued)

A low level on the reset (RESET) input resets the internal stack pointers and sets FULL high, AF/AE high, HF low, and EMPTY low. The Q outputs are not reset to any specific logic level. The FiFO must be reset upon power up.

The first word loaded into empty memory causes EMPTY to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. The data outputs are noninverting with respect to the data inputs and are in the high-impedance state when the output-enable ( OE ) input is high.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.

## functional block diagram



Terminal Functions

| PIN |  | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. |  |  |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offiset values may be programmed for this flag, or the default value of 64 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y$ ). AF/AE is high when memory contains $X$ or less words or ( 512 minus $Y$ ) or more words. AF/AE is high after reset. |
| D0-D17 | $\begin{gathered} 21-14,12-11 \\ 9-2 \end{gathered}$ | 1 | 18-bit data input port |
| EMPTY | 29 | 0 | Empty flag. EMPTY is low when the FIFO is empty. A FIFO reset also causes EMPTY to go low. |
| FULL | 28 | 0 | Full flag. FULL. is low when the FIFO is full. A FIFO reset causes FULL to go high. .' |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 256 or more words. HF is low after reset. |
| LDCK | 25 | 1 | Load clock. Data is written to the FIFO on the rising edge of LDCK when FULL. is high. |
| OE | 56 | 1 | Output enable. When $\overline{O E}$ is high, the data outputs are in the high-impedance state. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on D0-D7 is latched as an AF/AE offset value when PEN is low and LDCK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49, \\ 51,53-55 \end{gathered}$ | 0 | 18-bit data output port |
| RESET | 1 | I | Reset. A low level on this input resets the FIFO and drives AF/AE and FULL high and HF and EMPTP low. |
| UNCK | 32 | I | Unload clock. Data is read from the FIFO on the rising edge of UNCK when EMPTY is high. |

## offset values for AF/AE

The almostfull/almost empty flag has two programmable limits, the almost empty offset value $(X)$ and the almost full offset value ( Y . They may be programmed after the FIFO is reset and before the first word is written to memory. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 512 minus $Y$ ) or more words.
To program the offset values, PEN may be brought low after reset only when LDCK is low. On the following low-to-high transition of LDCK, the binary value on D0-D7 is stored as the almost-empty offset value $(X)$ and the almost-full offset value (Y). Holding PEN low for another low-to-high transition of LDCK will reprogram Y to the binary value on D0-D7 at the time of the second LDCK low-to-high transition. Writes to the FIFO memory are disabled while the offsets are programmed.
A maximum value of 255 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=64$, PEN must be held high.


Figure 1. Programming $X$ and $Y$ Separately


## SN74ACT7804 512 K 18 FIRST-IN, FIRST-OUT MEMORY

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$
$\qquad$
Suply volage range, $V_{C C}$
-0.5 V to 7 V

Voltage applied to a disabled 3-state output ........................................................... 5.5 V
Operating free-air temperature range....................................................... $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range .................................................................... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
recommended operating conditions


## electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITONS |  | MIN | TYP ${ }^{\ddagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| VOL | Flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=V_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| Icc |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}-0.2 \mathrm{~V}$ or 0 |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta l_{\text {c }}{ }^{6}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\text {CC }}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{\mathrm{i}}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 8 |  | pF |

[^7]switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 5 and 6)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | TO (OUTPUT) | 'ACT7804-20 |  |  | 'ACT7804-25 |  | 'ACT7804-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{f}_{\text {max }}$ | LDCK or UNCK |  | 50 |  |  | 40 |  | 25 |  | MHz |
| $t_{\text {pd }}$ | LDCK $\dagger$ | Any Q | 9 |  | 20 | 9 | 22 | 9 | 24 | ns |
| $t_{\text {pd }}$ | UNCK $\uparrow$ |  | 6 | 11.5 | 15 | 6 | 18 | 6 | 20 |  |
| $\mathrm{t}_{\mathrm{pd}}{ }^{\ddagger}$ | UNCK $\uparrow$ |  |  | 10.5 |  |  |  |  |  |  |
| tplu | L.DCK $\uparrow$ | EMPTY | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| $\mathrm{t}_{\text {PHL }}$ | UNCK $\dagger$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| $\mathrm{t}_{\text {PHL }}$ | RESET low |  | 4 |  | 16 | 4 | 18 | 4 | 20 |  |
| $\mathrm{t}_{\mathrm{PHL}}$ | LDCK $\uparrow$ | FULL | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| ${ }_{\text {PPLH }}$ | UNCK $\dagger$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| tely | RESET low |  | 4 |  | 18 | 4 | 20 | 4 | 22 |  |
| ${ }_{\text {tod }}$ | LDCK $\dagger$ | AF/AE | 7 |  | 18 | 7 | 20 | 7 | 22 | ns |
| $t_{\text {pd }}$ | UNCK $\uparrow$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| tple | RESET low |  | 2 |  | 10 | 2 | 12 | 2 | 14 |  |
| $\mathrm{tp}_{\text {LH }}$ | LDCK $\uparrow$ | HF | 5 |  | 18 | 5 | 20 | 5 | 22 | ns |
| ${ }_{\text {¢ }}$ | UNCK $\uparrow$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| $\mathrm{t}_{\text {PHL }}$ | RESET low |  | 3 |  | 12 | 3 | 14 | 3 | 16 |  |
| $t_{\text {en }}$ | OE | Any Q | 2 |  | 9 | 2 | 10 | 2 | 11 | ns |
| $\mathbf{t}_{\text {dis }}$ |  |  | 2 |  | 10 | 2 | 11 | 2 | 12 |  |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This parameter is measured at $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 3).
operating characteristics, $\mathrm{V}_{\mathrm{Cc}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | TYP | UNIT |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $C_{\text {pd }} \quad$ Power dissipation capacitance per FIFO channel | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad \mathrm{f}=5 \mathrm{MHz}$ | 53 | pF |

## APPLICATION INFORMATION



Figure 2. Word-Width Expansion: 512 Words by 36 Blts

TYPICAL CHARACTERISTICS


Flgure 3


Figure 4

## calculating power dissipation

With ICCF taken from Figure 4, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f o\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{C C} \times\left[l_{c c}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{C C}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f o\right)
$$

$\mathrm{I}_{\mathrm{CC}}=$ power-down $\mathrm{I}_{\mathrm{Cc}}$ maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta l_{\text {CC }}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$\mathrm{f}_{\mathrm{i}}=$ data input frequency
$\mathrm{f}_{\mathrm{o}}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



Figure 5. Standard CMOS Outputs (FOLL, EMPTY, HF, AF/AE)


FIgure 6. 3-State Outputs (Any Q)

- Member of the Texas Instruments Whdebus ${ }^{\text {T }}$ Family
- Load Clock and Unload Clock May Be Asynchronous or Coincident
- Packaged in Shrink Small-Outilno 300-mil Package (DL) Using 25-mil Center-to-Center Spacing
- 256 Words by 18 Blts
- Low-Power Advanced CMOS Technology
- Full, Empty, and Half-Full Flags
- Programmable Almost Full/Almost Empty Flag
- Fast Access Times of 15 ns With a 50-pF Load and All Data Outputs Switching SImultaneously
- Data Rates From 0 to 50 MHz
- 3-State Outputs
- Pin Compatlble WIth SN74ACT7804 and SN74ACT7814


## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7806 is a 256 -word by 18 -bit FIFO for high speed and fast access times. It processes data at rates up to 50 MHz and access times of 15 ns in a bit-parallel format.

Data is written into memory on a low-to-high transition at the load clock (LDCK) input and is read out on a low-to-high transition at the unload clock (UNCK) input. The memory is full when the number of words clocked in exceeds the number of words clocked out by 256. When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the full (FULL), empty (EMPTY), half-full (HF), and almost full/almost empty (AF/AE) flags. The FULL output is low when the memory is full and high when the memory is not full. The EMPTY output is low when the memory is empty and high when it is not empty. The HF output is high when the FIFO contains 128 or more words and is low when it contains 127 or less words. The AF/AE status flag is a programmable flag. The first one or two low-to-high transitions of LDCK after reset are used to program the almost-empty offset value ( $X$ ) and the almost-full offset value $(Y$ ) if program enable (PEN) is low. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 256 minus $Y$ ) or more words. The AF/AE flag is low when the FIFO contains between ( $X$ plus 1) and ( 255 minus $Y$ ) words.
A low level on the reset (RESET) input resets the internal stack pointers and sets FULL high, HF low, and EMPTY low. The Q outputs are not reset to any specific logic level. The FIFO must be reset upon power up.
Widebus is a trademark of Toxas Instruments Incorporated.

## description (continued)

The first word loaded into empty memory causes EMPTY to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. The data outputs are noninverting with respect to the data inputs and are in the high-impedance state when the output-enable ( OE ) input is high.
logic symbol ${ }^{\dagger}$.


[^8]functional block diagram


Terminal Functions

| PIN |  | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. |  |  |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 32 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y)$. AF/AE is high when memory contains X or less words or ( 256 minus Y ) or more words. AF/AE is high after reset. |
| D0-D17 | $\begin{gathered} \text { 21-14, 12-11, } \\ 9-2 \end{gathered}$ | 1 | 18-bit data input port |
| EMPTY | 29 | 0 | Empty flag. EMPTY is high when the FIFO memory is not empty; EMPTY is low when the FIFO memory is ompty or upon assertion of RESET. |
| FULIL | 28 | 0 | Full flag. FULL. is high when the FIFO memory is not full or upon assertion of RESET; FULL is low when the FIFO memory is full. |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 128 or more words. HF is low after reset. |
| LDCK | 25 | 1 | Load cock. Data is written to the FIFO on the rising edge of LDCK when FULL is high. |
| $\overline{O E}$ | 56 | 1 | Output enable. When రE is high, the data outputs are in the high-impedance state. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on D0-D6 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49, \\ 51,53-55 \end{gathered}$ | 0 | 18-bit data output port |
| RESET | 1 | 1 | Reset. A low level on this input resets the FIFO and drives FULL. high and HF and EMPTY low. |
| UNCK | 32 | 1 | Unload clock. Data is read from the FIFO on the rising edge of UNCK when EMPTY is high. |

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost empty offset value $(X)$ and the almost full offset value ( $)$. They may be programmed after the FIFO is reset and before the first word is written to memory. The AF/AE flag will be high when the FIFO contains $X$ or less words or ( 256 minus $Y$ ) or more words.
To program the offset values, PEN may be brought low after reset only when LDCK is low. On the following low-to-high transition of LDCK, the binary value on DO-D6 is stored as the almost-empty offset value $(X)$ and the almost-full offset value ( Y . Holding PEN low for another low-to-high transition of LDCK will reprogram $Y$ to the binary value on DO-D6 at the time of the second LDCK low-to-high transition. Writes to the FIFO memory are disabled while the offsets are programmed.

A maximum value of 127 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=32$, PEN must be held high.


Flgure 1. Programming $X$ and $Y$ Separately


## SN74ACT7806 256 X 18 FIRST-IN, FIRST-OUT MEMORY

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions


electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\text { }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {a }}$ - mA |  |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 4 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {CC }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| ${ }^{\text {cce }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}-0.2 \mathrm{~V}$ or 0 |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{CCC}^{5}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $V_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

[^9]
## SN74ACT7806 <br> 256 X 18 FIRST-IN, FIRST-OUT MEMORY

SCAS208-D4024, JUNE 1991-REVISED APRIL 1992
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 5 and 6)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | 'ACT7806-20 |  |  | 'ACT7806-25 |  | 'ACT7806-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {+ }}$ | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK or UNCK |  | 50 |  |  | 40 |  | 25 |  | MHz |
| $t_{\text {pd }}$ | LDCK $\dagger$ | Any Q | 9 |  | 20 | 9 | 22 | 9 | 24 | ns |
| ${ }_{\text {cod }}$ | UNCK $\dagger$ |  | 6 | 11.5 | 15 | 6 | 18 | 6 | 20 |  |
| $\mathrm{t}_{\mathrm{pd}}{ }^{\ddagger}$ | UNCK $\uparrow$ |  |  | 10.5 |  |  |  |  |  |  |
| tpli | LDCK $\dagger$ | EMPTY | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| $\mathrm{t}_{\text {PHL }}$ | UNCK $\uparrow$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| tPHL | RESET low |  | 4 |  | 16 | 4 | 18 | 4 | 20 |  |
| $t_{\text {PHL }}$ | LDCK $\uparrow$ | FUIL | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| ${ }_{\text {tPLH }}$ | UNCK $\uparrow$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| tplu | RESET low |  | 4 |  | 18 | 4 | 20 | 4 | 22 |  |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\uparrow$ | AF/AE | 7 |  | 18 | 7 | 20 | 7 | 22 | ns |
| $t_{\text {pd }}$ | UNCK $\uparrow$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| trin $^{\text {che }}$ | RESET low |  | 2 |  | 10 | 2 | 12 | 2 | 14 |  |
| tpiH | LDCK $\dagger$ | HF | 5 |  | 18 | 5 | 20 | 5 | 22 | ns |
| ¢PHL | UNCK $\dagger$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| $\mathrm{t}_{\mathrm{PHL}}$ | RESET low |  | 3 |  | 12 | 3 | 14 | 3 | 16 |  |
| ten | OE | Any Q | 2 |  | 9 | 2 | 10 | 2 | 11 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 2 |  | 10 | 2 | 11 | 2 | 12 |  |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This parameter is measured at $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 3).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $C_{p d} \quad$ Power dissipation capacitance per FIFO channel | Outputs enabled | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \mathrm{F}_{\mathrm{l}} \quad \mathrm{f}=5 \mathrm{MHz}$ | 53 | pF |



Flgure 2. Word-Width Expansion: 256 Words by 36 Bits

## TYPICAL CHARACTERISTICS



Figure 3


Figure 4

## calculating power dissipation

With ICCF taken from Figure 4, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d C\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c^{2}} \times f i\right)+\Sigma\left(C_{L} \times V_{c c}{ }^{2} \times f o\right)
$$

$\mathrm{I}_{\mathrm{CC}}=$ power-down $\mathrm{I}_{\mathrm{cc}}$ maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta \mathrm{l}_{\mathrm{CC}}=$ increase in supply current
dc = duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$\mathrm{C}_{\mathrm{L}}=$ output capacitive load
$\mathrm{f}_{\mathrm{i}}=$ data input frequency
$\mathrm{f}_{0}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



Flgure 5. Standard CMOS Outputs (FULL, EMPTY, HF, AF/AE)


| PARAMETER |  | R1, R2 | $\mathrm{C}_{\mathrm{L}}{ }^{\text {t }}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | tpZH | $500 \Omega$ | 50 pF | Open |
|  | tPZL |  |  | Closed |
| $t_{\text {dis }}$ | $t_{\mathrm{PHZ}}$ | 500 ¢ | 50 pF | Open |
|  | $t_{\text {PLZ }}$ |  |  | Closed |
| $t_{\text {pd }}$ |  | $500 \Omega$ | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 6. 3-State Outputs (Any Q)

- Load Clocks and Unload Clocks May Be Asynchronous or CoIncident
- 2048 Words by 9 Bits
- Low-Power Advanced CMOS Technology
- Fast Access Times of 15 ns With a 50-pF Load
- Programmable Almost Full/Almost Empty Flag
- Expansion Logic for Depth Cascading
- Empty, Full, and Half-Full Flags
- Fall-Through Time of 20 ns Typ
- Data Rates From 0 to 50 MHz
- 3-State Outputs
- Avallable in 44-Pin PLCC (FN) or Space-Saving 64-Pin Shrink Quad Flat Pack (PM)


## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7808 is a 2048-word by 9-bit FIFO designed for high speed and fast access times. It processes data at rates up to 50 MHz and access times of 15 ns in a bit-parallel format.
Data is written into memory on a low-to-high transition at the load clock (LDCK) input and is read out on a low-to-high transition at the unload clock (UNCK) input. The memory is full when the number of words clocked in exceeds the number of words clocked out by 2048. When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the full (FULL), empty (EMPTY), half-full (HF), and almost full/almost empty (AF/AE) flags. The FOLL output is low when the memory is full and high when the memory is not full. The EMPTY output is low when the memory is empty and high when it is not empty. The HF output is high whenever the FIFO contains 1024 or more words and is low when it contains 1023 or less words. The AF/AE status flag is a programmable flag. The first one or two low-to-high transitions of LDCK after reset may be used to program the almost empty offset value $(X)$ and the almost full offset value $(Y)$ if program enable (PEN) is low. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 2048 minus $Y$ ) or more words. The AF/AE flag is low when the FIFO contains between $(X+1)$ and ( 2047 minus $Y$ ) words.

A low level on the reset (RESET) input resets the internal stack pointers and sets FULL high, AF/AE high, HF low, and EMPTP low. The Q outputs are not reset to any specific logic level. The FIFO must be reset upon power up.
The first word loaded into empty memory causes EMPTP to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are in the high-impedance state when the output-enable (OE) input is low. OE does not affect the output flags.

Cascading is easily accomplished in the word-width and word-depth directions. When not using the FIFO in depth expansion, cascade enable (CASEN) must be tied high.

| FN PACKAGE (TOP VEW) |  |  |
| :---: | :---: | :---: |
| O |  |  |
| 6, 6 |  |  |
| Do | $77^{6} 554431214443424140{ }_{39}$ | Q1 |
| D1 | 18 | $\mathrm{V}_{\mathrm{cc}}$ |
| D2 | 19 37 | Q2 |
| GND | 710 36 | Q3 |
| D3 | 11 35 | GND |
| D4 | 12 34 | Q4 |
| D5 | 13 -33 | $\mathrm{V}_{\mathrm{cc}}$ |
| vcc | 14 32[] | Q5 |
| D6 | 15 310 | Q6 |
| D7 | 16 30П | GND |
| D8 | $1782{ }^{17}$ | Q7 |
|  |  |  |
|  |  |  |

PM PACKAGE
(TOP VEW)

NC - No internal connection

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/תEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for the FN package.
functional block diagram


## Terminal Functions

| PIN NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| AF/AE | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 256 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y)$. AF/AE is high when memory contains $X$ or less words or ( 2048 minus $Y$ ) or more words. AF/AE is high after reset. |
| CASEN ${ }^{\dagger}$ | I | Cascade enable. When multiple 'ACT7808 devices are depth cascaded, every device must have its CASEN input tied low. CASEN must be tied high when a device is not used in depth expansion. |
| D0-D8 | 1 | 9-bit data input port |
| DP9 | 1 | DP9 is used as the most significant bit when programming the AF/AE offset values. |
| EMPTY | 0 | Empty flag. EMPTY is low when the FIFO memory is empty. A FIFO reset also causes EMPTY to go low. |
| FL $\dagger$ | 1 | When multiple 'ACT7808 devices are depth cascaded, the first device in the chain must have its FL input tied low, and all other devices must have their FL inputs tied high. |
| FULL | 0 | Full flag. FULL is low when the FIFO is full. A FIFO reset causes FULL to go high. |
| HF | 0 | Half-full flag. HF is high when the FIFO memory contains 1024 or more words. HF is low after reset. |
| LDCK | 1 | Load clock. Data is written to the FIFO on the rising edge of LDCK when FULL is high. |
| OE | I | Output enable. When OE is low, the data outputs are in the high-impedance state. |
| PEN | I | Program enable. After reset and before the first word is written to the FIFO, the binary value on D0-D8 and DP9 is latched as an AF/AE offset value when PEN is low and LDCK is high. |
| Q0-Q8 | 0 | 9-bit data output port |
| RESET | I | Reset. A low level on this input resets the FIFO and drives FULL and AF/AE high and HF and EMPTY low. |
| UNCK | 1 | Unload clock. Data is read from the FIFO on the rising edge of UNCK when EMPTP is high. |
| XI' | 1 | Expansion input (XI) and expansion output (XO). When multiple 'ACT7808 devices are depth cascaded, the XO of one device must be connected to the XI of the next device in the chain. The XO of the last device in the chain is connected |
| XO' | 0 | to the XI of the first device in the chain. |

$\dagger$ See Figures 2 and 3 for application information on FIFO word-width and depth expansions, respectively.

## SN74ACT7808 <br> 2048 X 9 FRSTT-IN, FIRST-OUT MEMORY

SCAS205-D4026, FEBRUARY 1991-PEVISED APRIL 1992

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost-empty offset value $(\mathrm{X})$ and the almost-full offset value ( $)$. They may be programmed after the FIFO is reset and before the first word is written to memory. If the offsets are not programmed, the default values of $X=Y=256$ are used. The AF/AE flag is high when the FIFO contains X or less words or ( 2048 minus Y ) or more words.

To program the offset values, PEN may be brought low after reset only when LDCK is low. On the following low-to-high transition of LDCK, the binary value on DO-D8 and DP9 is stored as the almost-empty offset value $(X)$ and the almost-full offset value ( Y . Holding PEN low for another low-to-high transition of LDCK reprograms Y to the binary value on D0-D8 and DP9 at the time of the second LDCK low-to-high transition. Writes to the FIFO memory are disabled while the offsets are programmed.

A maximum value of 1023 may be programmed for either X or Y . To use the default values of $\mathrm{X}=\mathrm{Y}=256$, PEN must be held high.

## timing dlagram



Flgure 1. Timing Dlagram to Program $X$ and $Y$ Separately
timing diagram


Texas
INSTRUMENTS

## SN74ACT7808 <br> 2048 X 9 FIRST-IN, FIRST-OUT MEMORY

SCAS205-D4026, FEBRUARY 1991-REVISED APRIL 1992

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$


Input voltage, $\mathrm{V}_{1}$ $7 V$


Storage temperature range $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions



SCAS205-D4026, FEBRUARY 1991-REVISED APRIL 1992
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN TYP ${ }^{\text {P }}$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-8 \mathrm{~mA}$ | 2.4 | V |
| VOL | Flags | $V_{C C}=4.5 \mathrm{~V}$, | $\mathrm{lOL}^{2}=8 \mathrm{~mA}$ | 0.5 | $V$ |
|  | Q outputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | $\mathrm{IOL}=16 \mathrm{~mA}$ | 0.5 |  |
| 4 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $V_{1}=V_{\text {cc }}$ or 0 | $\pm 5$ | $\mu \mathrm{A}$ |
| l OZ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or 0 | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{cc}}$ |  | $\mathrm{V}_{\text {cc }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{Cc}}-0.2 \mathrm{~V}$ or 0 | 400 | $\mu \mathrm{A}$ |
| $\Delta l_{\text {cc }}{ }^{\ddagger}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND | 1 | mA |
| $\mathrm{C}_{\mathrm{i}}$ |  | $V_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ | 4 | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ | 8 | pF |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 6 and 7)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | TO (OUTPUT) | 'ACT7808-20 |  |  | 'ACT7809-25 |  | 'ACT7808-30 |  | 'ACT7808-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK or UNCK |  | 50 |  |  | 40 |  | 33.3 |  | 25 |  | MHz |
| ${ }_{\text {tod }}$ | LDCK $\dagger$ | Any Q | 5 |  | 20 | 5 | 22 | 5 | 25 | 5 | 28 |  |
| $t_{\text {pd }}$ | UNCK $\dagger$ |  | 4.5 | 11 | 15 | 4.5 | 18 | 4.5 | 20 | 4.5 | 22 | ns |
| $\mathrm{t}_{\mathrm{pd}}{ }^{\text {g }}$ |  |  |  | 10 |  |  |  |  |  |  |  |  |
| ¢PLH | LDCK $\dagger$ | EMPTY | 4 |  | 15 | 4 | 17 | 4 | 19 | 4 | 21 | ns |
| ¢ ${ }_{\text {HL }}$ | UNCK $\dagger$ |  | 2 |  | 15 | 2 | 17 | 2 | 19 | 2 | 21 |  |
| tphL | RESET low |  | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 |  |
| tpHL | LDCK $\uparrow$ | FULI | 4 |  | 15 | 4 | 17 | 4 | 19 | 4 | 21 | ns |
| ${ }_{\text {¢ }}^{\text {LH }}$ | UNCK $\uparrow$ |  | 4 |  | 14 | 4 | 16 | 4 | 18 | 4 | 20 |  |
| toth | RESET low |  | 2 |  | 18 | 2 | 20 | 2 | 22 | 2 | 24 |  |
| ${ }_{\text {ted }}$ | LDCK $\dagger$ | AF/AE | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| $t_{\text {pd }}$ | UNCK $\dagger$ |  | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 |  |
| +pıH | RESET low |  | 0 |  | 10 | 0 | 12 | 0 | 14 | 0 | 16 |  |
| tplH | LDCK $\dagger$ | HF | 2 |  | 19 | 2 | 21 | 2 | 23 | 2 | 25 | ns |
| ¢pHL | UNCK $\uparrow$ |  | 2 |  | 16 | 2 | 18 | 2 | 20 | 2 | 22 |  |
| $\mathrm{t}_{\text {¢ }}$ | RESET low |  | 2 |  | 12 | 2 | 14 | 2 | 16 | 2 | 18 |  |
| +pLH | UNCK $\uparrow$ | XO | 2 |  | 11 | 2 | 13 | 2 | 15 | 2 | 17 | ns |
| $\mathrm{t}_{\text {PHL }}$ | LDCK $\dagger$ |  | 2 |  | 11 | 2 | 13 | 2 | 15 | 2 | 17 |  |
| ten | OE | Any Q | 1 |  | 10 | 1 | 12 | 1 | 14 | 1 | 16 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 1 |  | 9 | 1 | 11 | 1 | 13 | 1 | 15 |  |
| ten | XI high | Any Q | 3 |  | 13 | 3 | 15 | 3 | 17 | 3 | 19 | ns |
| $\mathrm{t}_{\text {dis }}$ | XO high |  |  |  | 4 |  | 4 |  | 4 |  | 4 |  |

[^10]operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | TYP | UNIT |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $C_{p d} \quad$ Power dissipation capacitance per FIFO channel | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad f=5 \mathrm{MHz}$ | 91 | pF |

## 2048 X 9 FIRST-IN, FIRST-OUT MEMORY



Figure 2. Word-Width Expansion: 2048 Words by 18 Blts

## depth cascading

The SN74ACT7808 provides expansion logic necessary for cascading an unlimited number of the FIFOs in depth. CASEN must be low on all FIFOs used in depth expansion. FL must be tied low on the first FIFO in the chain; all others must have FL tied high. The expansion out (XO) output of a FIFO must be tied to the expansion in (XI) input of the next FIFO in the chain. The XO output of the last FIFO is tied to the XI input of the first FIFO to complete the loop. Data buses are common to each FIFO in the chain. A composite EMPTP and FULL signal must be generated to indicate boundary conditions.


Figure 3. Depth Cascading to Form a $\mathbf{6 K} \times 9$ FIFO

TYPICAL CHARACTERISTICS
PROPAGATION DELAY TIME
LOAD CAPACITANCE


Figure 4


Flgure 5

## calculating power dissipation

With I CCF taken from Figure 5, the maximum power dissipation may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta I_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C}^{2} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c}{ }^{2} \times f o\right)
$$

Icc = power-down Icc maximum
$N=$ number of inputs driven by a TTL device
$\Delta I_{c \mathrm{C}}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{i}=$ data input frequency
$\mathrm{f}_{0}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



Flgure 6. Standard CMOS Outputs (XO, EMPTY, FULL, AF/AE, HF)


| PARAMETER |  | R1, R2 | $\mathrm{CL}^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| $t_{\text {en }}$ | tpzH | 5009 | 50 pF | Open |
|  | $t_{\text {PZL }}$ |  |  | Closed |
| $t_{\text {dis }}$ | ${ }_{4}{ }_{\text {Hz }}$ | 500 ¢ | 50 pF | Open |
|  | t+LZ |  |  | Closed |
| $\mathrm{t}_{\mathrm{pd}}$ |  | $500 \Omega$ | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Flgure 7. 3-State Outputs (Any Q)

- Member of the Texas Instruments Widebus ${ }^{\text {T4 }}$ Family
- Load Clock and Unload Clock May Be Asynchronous or Colncident
- Packaged In Shrink Small-Outline 300-mil Package (DL) Using 25-mll Center-to-Center Spacing
- 64 Words by 18 Blts
- Low-Power Advanced CMOS Technology
- Full, Empty, and Half-Full Flags
- Programmable Almost Full/Almost Empty Flag
- Fast Access TImes of 15 ns With a 50-pF Load and All Data Outputs Swltching Simultaneously
- Data Rates From 0 to 50 MHz
- 3-State Outputs
- Pin Compatlble WIth SN74ACT7804 and SN74ACT7806
description
A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT7814 is a 64 -word by 18 -bit FIFO for high speed and fast access times. It processes data at rates up to 50 MHz and access times of 15 ns in a bit-parallel format.

Data is written into memory on a low-to-high transition at the load clock (LDCK) input and is read out on a low-to-high transition at the unload clock (UNCK) input. The memory is full when the number of words clocked in exceeds the number of words clocked out by 64 . When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the full (FULL), empty (EMPTY), half-full (HF), and almost full/almost empty (AF/AE) flags. The FULL output is low when the memory is full and high when the memory is not full. The EMPTY output is low when the memory is empty and high when it is not empty. The HF output is high when the FIFO contains 32 or more words and is low when it contains 31 or less words. The AF/AE status flag is a programmable flag. The first one or two low-to-high transitions of LDCK after reset are used to program the almost-empty offset value $(X)$ and the almost-full offset value $(Y$ ) if program enable (PEN) is low. The AF/AE flag is high when the FIFO contains $X$ or less words or ( 64 minus $Y$ ) or more words. The AF/AE flag is low when the FIFO contains between ( X plus 1 ) and ( 63 minus $Y$ ) words.
A low level on the reset (RESET) input resets the internal stack pointers and sets FULL high, HF low, and EMPTY low. The Q outputs are not reset to any specific logic level. The FIFO must be reset upon power up.

[^11]
## description (continued)

The first word loaded into empty memory causes EMPTY to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. The data outputs are noninverting with respect to the data inputs and are in the high-impedance state when the output-enable (OE) input is high.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/REEE Std 91-1984 and IEC Publication 617-12.
functional block diagram


Terminal Functions

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | No. | 1/0 |  |
| AF/AE | 24 | 0 | Almost full/almost empty flag. Depth offset values may be programmed for this flag, or the dofault value of 8 may be used for both the almost empty offiset ( $X$ ) and the almost full offset ( $($ ). AF/AE is high when memory contains X or less words or ( 64 minus Y ) or more words. AF/AE is high after reset. |
| D0-D17 | $\begin{gathered} 21-14,12-11 \\ 9-2 \end{gathered}$ | 1 | 18-bit data input port |
| EMPTP | 29 | 0 | Empty flag. EMPTY is high when the FiFO memory is not empty; EMPTY is low when the FIFO memory is empty or upon assertion of RESET. |
| FULL | 28 | 0 | Full flag. FULL is high when the FIFO memory is not full or upon assertion of RESET; FULL is low when the FIFO memory is full. |
| HF | 22 | 0 | Half-full flag. HF is high when the FIFO memory contains 32 or more words. HF is low after reset. |
| LDCK | 25 | 1 | Load clock. Data is written to the FIFO on the rising edge of LDCK when FULL is high. |
| రE | 56 | 1 | Output enable. When $\overline{O E}$ is high, the data outputs are in the high-impedance state. |
| PEN | 23 | 1 | Program enable. After reset and before the first word is written to the FIFO, the binary value on D0-D4 is latched as an AF/AE offset value when PEN is low and WRTCLK is high. |
| Q0-Q17 | $\begin{gathered} 33-34,36-38, \\ 40-43,45-49 \\ 51,53-55 \end{gathered}$ | 0 | 18-bit data output port |
| FESET | 1 | 1 | Reset. A low level on this input resets the FIFO and drives FULL high and HF and EMPTY low. |
| UNCK | 32 | 1 | Unload clock. Data is read from the FIFO on the rising edge of UNCK when EMPTY is high. |

## offset values for AF/AE

The almost full/almost empty flag has two programmable limits, the almost empty offset value $(X)$ and the almost full offset value ( $Y$ ). They may be programmed after the FIFO is reset and before the first word is written to memory. The AF/AE flag will be high when the FIFO contains $X$ or less words or ( 64 minus $Y$ ) or more words.
To program the offset values, PEN may be brought low after reset only when LDCK is low. On the following low-to-high transition of LDCK, the binary value on D0-D4 is stored as the almost-empty offset value $(X)$ and the almost-full offset value (Y). Holding PEN low for another low-to-high transition of LDCK will reprogram Y to the binary value on DO-D4 at the time of the second LDCK low-to-high transition. Writes to the FIFO memory are disabled while the offsets are programmed.

A maximum value of 31 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=8, P E N$ must be held high.


Figure 1. Programming $X$ and $Y$ Separately
timing diagram

# SN74ACT7814 64 X 18 FIRST-IN, FIRST-OUT MEMORY 

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$


$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
recommended operating conditions

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\text { }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| VOL | Flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \cdot \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\mathrm{Cc}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {cc }}$ |  | $V_{1}=V_{C C}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lCC}^{\text {¢ }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
${ }^{5}$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.

## SN74ACT7814 <br> 64 X 18 FIRST-IN, FIRST-OUT MEMORY

SCAS209-D4023, SEPTEMBER 1991-REVISED APRIL 1992
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 5 and 6)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | 'ACT7814-20 |  |  | 'ACT7814-25 |  | 'ACT7814-40 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{+}$ | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK or UNCK |  | 50 |  |  | 40 |  | 25 |  | MHz |
| tpd | LDCK $\dagger$ | Any Q | 9 |  | 20 | 9 | 22 | 9 | 24 | ns |
| tpd | UNCK $\dagger$ |  | 6 | 11.5 | 15 | 6 | 18 | 6 | 20 |  |
| $\mathrm{t}_{\mathrm{pd}}{ }^{ \pm}$ | UNCK $\dagger$ |  |  | 10.5 |  |  |  |  |  |  |
| tpLH | LDCK $\dagger$ | EMPTY | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| tpHL. | UNCK $\uparrow$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| $\mathrm{t}_{\mathrm{H} \mathrm{H}}$ | RESET low |  | 4 |  | 16 | 4 | 18 | 4 | 20 |  |
| ${ }_{\text {PHL }}$ | LDCK $\uparrow$ | FULL | 6 |  | 15 | 6 | 17 | 6 | 19 | ns |
| tplH | UNCK $\uparrow$ |  | 6 |  | 15 | 6 | 17 | 6 | 19 |  |
| $\mathrm{tpLH}^{\text {L }}$ | RESET low |  | 4 |  | 18 | 4 | 20 | 4 | 22 |  |
| $t_{\text {pd }}$ | LDCK $\dagger$ | AF/AE | 7 |  | 18 | 7 | 20 | 7 | 22 | ns |
| $t_{\text {pd }}$ | UNCK $\dagger$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| tplH | RESET low |  | 2 |  | 10 | 2 | 12 | 2 | 14 |  |
| tpli | LDCK $\uparrow$ | HF | 5 |  | 18 | 5 | 20 | 5 | 22 | ns |
| $\mathrm{t}_{\text {PHL }}$ | UNCK $\dagger$ |  | 7 |  | 18 | 7 | 20 | 7 | 22 |  |
| $\mathrm{tPHL}^{\text {che }}$ | RESET low |  | 3 |  | 12 | 3 | 14 | 3 | 16 |  |
| ten | OE | Any Q | 2 |  | 9 | 2 | 10 | 2 | 11 | ns |
| $t_{\text {dis }}$ |  |  | 2 |  | 10 | 2 | 11 | 2 | 12 |  |

${ }^{\dagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
$\ddagger$ This parameter is measured at $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (see Figure 3).
operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | TYP | UNIT |  |
| :--- | :--- | :--- | :--- | :---: | :---: |
| $C_{p d} \quad$ Power dissipation capacitance per FIFO channel | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad \mathrm{f}=5 \mathrm{MHz}$ | 53 | pF |



Figure 2. Word-Wldth Expansion: 64 Words by 36 Blts

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
vs
LOAD CAPACITANCE


Figure 3


Figure 4

## calculating power dissipation

With ICCF taken from Figure 4, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f o\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times \text { fo }\right)
$$

$\mathrm{I}_{\mathrm{cc}}=$ power-down $\mathrm{I}_{\mathrm{cc}}$ maximum
$N=$ number of inputs driven by a TTL device
$\Delta I_{C C}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{i}=$ data input frequency
$f_{0}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



Figure 5. Standard CMOS Outputs (FULL, EMPTY, HF, AF/AE)


| PARAMETER |  | R1, R2 | $\mathrm{C}^{\dagger}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| $t$ en | tozH | 500 @ | 50 pF | Open |
|  | tPZL |  |  | Closed |
| $t_{\text {dis }}$ | ¢ Hz | 5009 | 50 pF | Open |
|  | $4_{\text {PLZ }}$ |  |  | Closed |
| $t_{0 d}$ |  | $500 \Omega$ | 50 pF | Opon |

$\dagger$ Includes probe and test fixture capacitance.
Flgure 6. 3-State Outputs (Any Q)

- Independent Asychronous Inputs and Outputs
- 16 Words by 5 Blts Each
- Data Rates From 0 to $\mathbf{4 0} \mathbf{~ M H z}$
- Fall-Through Time .. . 14 ns Typ
- 3-State Outputs
- Package Options Include Plastic Small-Outline Packages, Plastic Chip Carriers, and Standard Plastic 300-mil DIPs


## description

This 80-bit memory uses Advanced Low-Power Schottky technology and features high speed and fast fall-through times. It is organized as 16 words by 5 bits.

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. This FIFO is designed to process data at rates from 0 to 40 MHz in a bit-parallel format, word by word.
Data is written into memory on a low-to-high transition at the load clock input (LDCK) and is read out on a low-to-high transition at the unload clock (UNCK). The memory is full when the number of words clocked in exceeds by 16 the number of words clocked out. When the memory is full, LDCK signals have no effect. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the FULL, EMPTY, FULL-2, and FULL+2 output flags. The FULI output is low when the memory is full and high when it is not full. The FULL-2 output is low when the memory contains 14 data words. The EMPTY output is low when the memory is empty and high when it is not empty. The EMPTY +2 output is low when two words remain in memory.
A low level on the reset input (RST) resets the internal stack control pointers and also sets EMPTY low and sets FULL, FULL-2, and EMPTY+2 high. The Q outputs are not reset to any specific logic level. The first low-to-high transition on LDCK after either a RST pulse or from an empty condition causes EMPTY to go high and the data to appear on the $Q$ outputs. It is important to note that the first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are at high impedance when the output-enable input (OE) is low. OE does not affect the output flags. Cascading is easily accomplished in the word-width direction but is not possible in the word-depth direction.
The SN74ALS229B is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSI/AEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but does not show the details of implementation; for these, see the logic diagram. The symbol represents the memory as if it were controlled by a single counter whose content is the number of words stored at the time. Output data is invalid when the counter content (CT) is 0 .
Pin numbers shown are for DW and N packages.
logic diagram (positive logic)


Pin numbers shown are for DW and $N$ packages.
timing diagram

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$
$\qquad$
Supply voltage, $\mathrm{V}_{\mathrm{CC}}$
7 V

Voltage applied to a disabled 3 -state output ............................................................ 5.5 V
Operating free-air temperature range ........................................................... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ....................................................................... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absoluto-maximum-rated conditions for extended periods may affect device reliability.

## SN74ALS229B 16 X 5 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

recommended operating conditions (see Note 1)

|  |  |  | MIN | NOM | MAX | UNT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage |  |  |  | 0.8 | V |
|  | High-level output current | Q outputs |  |  | -1.6 | mA |
|  |  | Status flags |  |  | -0.4 |  |
| lol | Low-lovel output curront | Q outputs |  |  | 24 | mA |
|  |  | Status flags |  |  | 8 |  |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency | LDCK | 0 |  | 40 | MHz |
|  |  | UNCK | 0 |  | 40 |  |
| $\mathrm{t}_{\text {w }}$ | Pulse duration | RST low | 18 |  |  | ns |
|  |  | LDCK low | 15 |  |  |  |
|  |  | LDCK high | 10 |  |  |  |
|  |  | UNCK low | 15 |  |  |  |
|  |  | UNCK high | 10 |  |  |  |
| $\mathrm{t}_{\text {su }}$ | Setup time | Data before LDCK $\dagger$ | 8 |  |  | ns |
|  |  | RST (inactive) before LDCK $\dagger$ | 5 |  |  |  |
|  |  | LDCK (inactive) before RST ${ }_{\text {a }}$ | 5 |  |  |  |
| $t_{n}$ | Hold time | Data after LDCK $\uparrow$ | 5 |  |  | ns |
| $\mathrm{T}_{\mathrm{A}}$ | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 1: To ensure proper operation of this high-speed FIFO device, it is necessary to provide a clean signal to the LDCK and UNCK clock inputs. Any excessive noise or glitching on the clock inputs that violates the $\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IH}}$, or minimum pulse duration limits can cause a false clock or improper operation of the internal read and write pointers.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYPt | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IK}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Q outputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |
|  | Status flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ to 5.5 V | $\mathrm{IOL}^{\mathrm{OL}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{cc}}-2$ |  |  |  |
| V OL | Qoutputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 | V |
|  | ouputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}_{\text {O }}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | Status flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  | Status flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| lozi |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| lozL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| I |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| IIH |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| ILL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | mA |
| Icc |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |  |  | 85 | 140 | mA |

[^12]switching characteristics

| PARAMETER | FROM (INPUT) | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \mathrm{Q}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX |  |
| $f_{\text {max }}$ | LDCK, UNCK |  | 40 | MHz |
| $t_{\text {pd }}$ | LDCK $\dagger$ | Any Q | 6 30 | ns |
|  | UNCK $\dagger$ |  | 630 |  |
| tPLH | LDCK $\uparrow$ | EMPTY | $5 \quad 25$ | ns |
| ${ }_{\text {tPHL }}$ | UNCK ${ }^{\text {¢ }}$ |  | $6 \quad 27$ |  |
| $\mathrm{t}_{\mathrm{HL}}$ | RST $\downarrow$ | EMPTY | $5 \quad 26$ | ns |
| $t_{\text {pd }}$ | LDCK $\dagger$ | EMPTY+2 | $7 \times 33$ | ns |
|  | UNCK $\dagger$ |  | $9 \quad 35$ |  |
| ${ }_{\text {tPLH }}$ | RST $\downarrow$ | EMPTY+2 | $9 \quad 33$ | ns |
| $t_{\text {pd }}$ | LDCK $\dagger$ | FULL-2 | $7 \quad 33$ | ns |
|  | UNCK $\uparrow$ |  | 935 |  |
| ${ }_{\text {tPLH }}$ | RST $\downarrow$ | FULL-2 | 93 | ns |
| ${ }_{\text {tr }}$ | LDCK ${ }_{\text {¢ }}$ | FULI | $6 \quad 27$ | ns |
| tric | UNCK $\dagger$ | FULI | $5 \quad 25$ | ns |
|  | RST $\downarrow$ |  | $8 \quad 31$ |  |
| ten | OEf | Q | $2 \quad 15$ | ns |
| $\mathrm{t}_{\text {dis }}$ | OE! | Q | 15 | ns |

# SN74ALS232B <br> $16 \times 4$ ASYCNHRONOUS FIRST-IN, FIRST-OUT MEMORY 

- Independent Asynchronous Inputs and Outputs
- Package Options Include Plastlc Small-Outline Packages, Plastic Chlp Carrlers, and Standard Plastic 300-mII DIPs
- 16 Words by 4 Blts Each
- Data Rates From 0 to $\mathbf{4 0} \mathbf{~ M H z}$
- Fall-Through Time ... 14 ns Type
- 3-State Outputs


## DW OR N PACKAGE

(TOP VIEW)


FN PACKAGE (TOP VIEW)


NC-No internal connection
This 64-bit memory uses Advanced Low-Power Schottky technology and features high speed and fast fall-through times. It is organized as 16 words by 4 bits each.

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. This FIFO is designed to process data at rates from 0 to 40 MHz in a bit-parallel format, word by word.

Data is written into memory on a low-to-high transition at the load clock input (LDCK) and is read out on a low-to-high transition at the unload clock input (UNCK). The memory is full when the number of words clocked in exceeds by 16 the number of words clocked out. When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.

Status of the FIFO memory is monitored by the FULL and EMPTY output flags. The FULL output will be low when the memory is full, and high when the memory is not full. The EMPTY output will be low when the memory is empty, and high when it is not empty.
A low level on the reset input ( $\overline{\mathrm{RST}}$ ) resets the internal stack control pointers and also sets $\overline{\mathrm{EMPTY}}$ low and sets FULL high. The outputs are not reset to any specific logic levels. The first low-to-high transition on LDCK, either after a RST pulse or from an empty condition, will cause EMPTY to go high and the data to appear on the $\mathbf{Q}$ outputs. It is important to note that the first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are at high impedance when the output-enable input (OE) is low. OE does not affect either the FULL or EMPTY output flags. Cascading is easily accomplished in the word-width direction, but is not possible in the word-depth direction.

## SN74ALS232B

## $16 \times 4$ ASYCNHRONOUS FIRST-IN, FIRST-OUT MEMORY

logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but does not show the details of implementation; for these, see the logic diagram. The symbol represents the memory as if it were controlled by a single counter whose content is the number of words stored at the time. Output data is invalid when the counter content (CT) is 0 .
logic diagram (positive logic)


Pin numbers shown are for DW and N packages.

## SN74ALS232B $16 \times 4$ ASYCNHRONOUS FIRST-IN, FIRST-OUT MEMORY

timing diagram

absolute maximum ratings over operating free-air temperature (unless otherwise noted)
Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V 7 V
Input voltage ................................................................................. 7 V
Voltage applied to a disabled 3-state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions (see Note 1)

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage |  | 4.5 | 5 | 5.5 | V |
| High-level input voltage |  | 2 |  |  | V |
| Low-level input voltage |  |  |  | 0.8 | V |
| IOH High-level output current | Q outputs |  |  | -2.6 | mA |
|  | FULL, EMPTY |  |  | -0.4 |  |
| IOL Low-level output current | Q outputs |  |  | 24 | mA |
|  | FULL, EMPTY |  |  | 8 |  |
| ${ }^{\text {clock }}{ }^{\dagger}$ Clock frequency | LDCK | 0 |  | 40 | MHz |
|  | UNCK | 0 |  | 40 |  |
| $\mathrm{t}_{\mathrm{w}} \quad$ Pulse duration | RST' low | 18 |  |  | ns |
|  | LDCK low | 15 |  |  |  |
|  | LDCK high | 10 |  |  |  |
|  | UNCK low | 15 |  |  |  |
|  | UNCK high | 10 |  |  |  |
| ${ }^{\text {tsu }}$ su Setup time | Data before LDCK $\uparrow$ | 8 |  |  | ns |
|  | LDCK inactive before $\overline{\mathrm{RST}} \uparrow$ | 5 |  |  |  |
| th Hold time | Data after LDCK $\uparrow$ | 5 |  |  | ns |
|  | LDCK inactive after $\overline{\text { RST }} \uparrow$ | 5 |  |  |  |
| Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

[^13]
## SN74ALS232B <br> $16 \times 4$ ASYCNHRONOUS FIRST-IN, FIRST-OUT MEMORY

SDIS010A - D3247, FEBRUARY 1989
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.
switching characteristics

| PARAMETER | FROM (INPUT) | ro (OUTPUT) | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & R 1=500 \Omega, \\ & R 2=500 \Omega, \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \hline V_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & R 1=500 \mathrm{\Omega}, \\ & R 2=500 \Omega, \\ & T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  |  | 50 |  | 40 |  | MHz |
|  | UNCK |  |  | 50 |  | 40 |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\uparrow$ | Any Q |  | 14 | 23 | 6 | 30 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | Any Q |  | 15 | 23 | 6 | 30 | ns |
| tPLH | LDCK $\dagger$ | EMPTY |  | 13 | 20 | 5 | 25 | ns |
| tPHL | UNCK $\uparrow$ | EMPTY |  | 15 | 22 | 6 | 27 | ns |
| tpHL | RST $\downarrow$ | EMPTY |  | 15 | 21 | 5 | 26 | ns |
| tPHL | LDCK $\dagger$ | FULL |  | 15 | 22 | 6 | 27 | ns |
| tPLH | UNCK $\uparrow$ | FULL |  | 13 | 20 | 5 | 25 | ns |
| ${ }_{\text {t }}$ LH | RST $\downarrow$ | FULIL |  | 16 | 23 | 7 | 28 | ns |
| ten | OE¢ | 0 |  | 5 | 12 | 1 | 14 | ns |
| ${ }_{\text {dis }}$ | OE」 | 0 |  | 5 | 12 | 1 | 16 | ns |

- Independent Asychronous Inputs and Outputs
- 16 Words by 5 Blts Each
- Data Rates From 0 to $\mathbf{4 0} \mathrm{MHz}$
- Fall-Through Time . . . 14 ns Typ
- 3-State Outputs
- Package Optlons Include Plastic Small-Outline Packages, Plastlc Chip Carrlers, and Standard Plastlc 300-mil DIPs


## description

This 80-bit memory uses Advanced Low-Power Schottky technology and features high speed and a fast fall-through time. It is organized as 16 words by 5 bits.
A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. This FIFO is designed to process data at rates from 0 to 40 MHz in a bit-parallel format, word by word.
Data is written into memory on a low-to-high transition at the load clock input (LDCK) and is read out on a low-to-high transition at the unload clock input (UNCK). The memory is full when the number of words clocked in exceeds by 16 the number of words clocked out. When the memory is full, LDCK signals have no effect. When the memory is empty, UNCK signals have no effect.
Status of the FIFO memory is monitored by the FULL, EMPTY, FULL-1, and FULL+1 output flags. The FULL output is low when the memory is full and high when it is not full. The FULL-1 output is low when the memory contains 15 data words. The EMPTY output is low when the memory is empty and high when it is not empty. The EMPTY+1 output is low when two words remain in memory.
A low level on the reset input (RST) resets the internal stack control pointers and also sets EMPTY low and sets FULI, FULL-1, and EMPTY+1 high. The Q outputs are not reset to any specific logic level. The first low-to-high transition on LDCK, after either a RST pulse or from an empty condition, causes EMPTY to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are at high impedance when the output-enable input (OE) is low. OE does not affect the output flags. Cascading is easily accomplished in the word-width direction but is not possible in the word-depth direction.
The SN74ALS233B is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSIIEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but does not show the details of implementation; for these, see the logic diagram. The symbol represents the memory as if it were controlled by a single counter whose content is the number of words stored at the time. Output data is invalid when the counter content (CT) is 0.
Pin numbers shown are for DW and N packages.


Pin numbers shown are for DW and N packages.
timing diagram

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) $\dagger$
$\qquad$
Input voltage, $\mathrm{V}_{1}$.............................................................................................. . . . 7 . 7 V
Voltage applied to a disabled 3-state output ............................................................. 5.5 V
Operating free-air temperature range $\ldots . . \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range .................................................................... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent demage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "rocommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## SN74ALS233B 16 X 5 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

| D3487, MARCH 1990-REVISED JUNE 1992 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| recommended operating conditions (see Note 1) |  |  |  |  |  |
|  |  |  | MIN | NOM MAX | UNIT |
| $V_{C C}$ | Supply voltage |  | 4.5 | $5 \quad 5.5$ | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage |  |  | 0.8 | V |
| lOH | High-level output current | Q outputs |  | -1.6 | mA |
|  |  | Status flags |  | -0.4 |  |
| lol | Low-level output current | Q outputs |  | 24 | mA |
|  |  | Status flags |  | 8 |  |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency | LDCK | 0 | 40 | MHz |
|  |  | UNCK | 0 | 40 |  |
| $t_{\text {w }}$ | Pulse duration | RST Jow | 18 |  | ns |
|  |  | LDCK low | 15 |  |  |
|  |  | LDCK high | 10 |  |  |
|  |  | UNCK low | 15 |  |  |
|  |  | UNCK high | 10 |  |  |
| $t_{s u}$ | Setup time | Data before LDCK $\uparrow$ | 8 |  | ns |
|  |  | RST (inactive) before LDCK $\dagger$ | 5 |  |  |
|  |  | LDCK (inactive) before RST $\uparrow$ | 5 |  |  |
| $t_{n}$ | Hold time | Data after LDCK $\dagger$ | 5 |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 1: To ensure proper operation of this high-speed FIFO device, it is necessary to provide a clean signal to the LDCK and UNCK clock inputs. Any excessive noise or glitching on the clock inputs that violates the $\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IH}}$, or minimum puise duration limits can cause a false clock or improper operation of the internal read and write pointers.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IK }}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| V OH | Q outputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |
|  | Status flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{l}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}-2}$ |  |  |  |
| $\mathrm{V}_{\text {OL }}$ | Q outbuts | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}_{\text {O }}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | Status flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  | Staks flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l} \mathrm{LL}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| lozh |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| lozL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}_{1}$ | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| ${ }_{1}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| $\mathrm{I}_{1}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| Ifi |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | mA |
| Icc |  | $V_{C C}=5.5 \mathrm{~V}$ |  |  | 88 | 133 | mA |

[^14]
## switching characteristics

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & V_{c c}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & R 1=500 \Omega, \\ & R 2=500 \Omega, \\ & T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX |  |
| $f_{\text {max }}$ | LDCK, UNCK |  | 40 | MHz |
| $t_{\text {pd }}$ | LDCK $\uparrow$ | Any Q | 6 | ns |
|  | UNCK $\dagger$ |  | 630 |  |
| tplH | LDCK ${ }^{\text {¢ }}$ | EMPTP | $5 \quad 25$ | ns |
| $t_{\text {PHL }}$ | UNCK $\dagger$ |  | $6 \quad 27$ |  |
| ${ }_{4}{ }_{\text {HLL }}$ | RST $\downarrow$ | EMPTY | $5 \quad 25$ | ns |
| $t_{p d}$ | LDCK $\uparrow$ | EMPTY+1 | $7 \times 34$ | ns |
|  | UNCK $\dagger$ |  | $7 \quad 34$ |  |
| tple | RST ${ }_{\text {L }}$ | EMPTY+1 | $8 \quad 31$ | ns |
| $t_{\text {pd }}$ | LDCK $\dagger$ | FULL- 1 | 93 | ns |
|  | UNCK $\uparrow$ |  | 8 32 |  |
| $\mathrm{t}_{\text {PLH }}$ | RST ${ }^{\text {d }}$ | FULL- | $11 \quad 32$ | ns |
| $\mathrm{t}_{\mathrm{pHL}}$ | LDCK $\uparrow$ | FUII | $6 \quad 27$ | ns |
| ${ }_{\text {tplu }}$ | UNCK $\dagger$ | FULI | $5 \quad 25$ | ns |
|  | RST $\downarrow$ |  | $9-30$ |  |
| $t_{\text {en }}$ | OEf | Q | $2 \quad 15$ | ns |
| $\mathrm{t}_{\text {dis }}$ | OE! | 0 | $1-15$ | ns |

## - Independent Asynchronous Inputs and Outputs <br> - 64 Words by 8 Blts Each <br> - Data Rates From 0 to $\mathbf{4 0 ~ M H z}$ <br> - Fall-Through Time . . . 20 ns Typical <br> - 3-State Outputs

## description

This 512-bit memory uses Advanced Low-Power Schottky IMPACT-X ${ }^{\text {mw }}$ technology and features high speed and fast fall-through times. It is organized as 64 words by 8 bits.
A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The function is used as a buffer to couple two buses operating at different clock rates. This FIFO is designed to process data at rates from 0 to 40 MHz in a bit-parallel format, word by word.

Data is written into memory on a low-to-high transition of the load clock (LDCK) input and is read out on a low-to-high transition of the unload clock (UNCK) input. The memory is full when the number of words clocked in exceed by 64 the number of words clocked out. When the memory is full, LDCK signals have no effect on the data residing in memory. When the the memory is empty, UNCK signals have no effect.

Status of the FIFO memory is monitored by the FUILL and EMPTP output flags. The FOLI output will be low when the memory is full, and high when the memory is not full. The EMPTY output will be low when the memory is empty, and high when it is not empty.
A low level on the reset (RST) input resets the internal stack control pointers and also sets EMPTY low and FULI high. The outputs are not reset to any specific logic levels. The first low-to-high transition on LDCK, either after a RST pulse or from an empty condition, causes EMPTY to go high and the data to appear on the Q outputs. The first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are at a high-impedance state when the output-enable (OE) input is low. The OE input does not effect either the FULI or EMPTY output flags. Cascading is easily accomplished in the word-width direction, but is not possible in the word-depth direction.

The SN74ALS2232A is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## logic symbol ${ }^{\dagger}$


$\dagger$ This symbol is in accordance with ANSIIEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but does not show the details of implementation; for these, see the logic diagram. The symbol represents the memory as if itwere controlled by a single counter whose content is the number of words stored at the time. Output data is invalid when the counter content (CT) is 0 .
Pin numbers shown are for the NT package.
logic diagram (positive logic)


Pin numbers shown are for the NT package.

## timing diagram



## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$


Input voltage ............................................................................................. 7 . V
Voltage applied to a disabled 3-state output ............................................................. 5.5 V


$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions beyond those indicated in the "recommended operating conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
NOTE 1: All voltage values are with respect to GND.

## SN74ALS2232A 64 X 8 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

## recommended operating conditions

|  |  |  | MIN | NOM | MAX | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | Supply voltage |  | 4.75 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage |  |  |  | 0.8 | V |
| ${ }^{\text {IOH }}$ | High-level output current | Q outputs |  |  | -2.6 | mA |
|  |  | FULL, EMPTY |  |  | -0.4 |  |
| lol | Low-loval output current | Q outputs |  |  | 24 | mA |
|  |  | FULL, EMPPTY |  |  | 8 |  |
| ${ }_{\text {clock }}$ | Clock frequency | LDCK, UNCK | 0 |  | 40 | MHz |
| tw | Pulse duration | RST low | 25 |  |  | ns |
|  |  | LDCK low | 13 |  |  |  |
|  |  | LDCK high | 12 |  |  |  |
|  |  | UNCK low | 13 |  |  |  |
|  |  | UNCK high | 12 |  |  |  |
| $\mathrm{t}_{\text {Su1 }}$ | Setup time, data before LDCK $\uparrow$ |  | 5 |  |  | ns |
| $t_{\text {Slu }}$ | Setup time, RST high (inactive) before LDCK $\uparrow$ |  | 5 |  |  | ns |
| $t_{n}$ | Hold time, data after LDCK $\uparrow$ |  | 5 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## electrical characteristics over recommended operating free-air temperature range (unless

 otherwise noted)| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IK}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  | V |
|  | FULL, EMPTP | $\mathrm{V}_{C C}=$ MIN to MAX, | $\mathrm{I}_{\mathrm{OH}}=0.4 \mathrm{~mA}$ | $\mathrm{V}_{C C-2}$ |  |  |  |
| VOL | Q outputs | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 | v |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{2}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | FULL, EMPTY | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {a }}$ 4 mA |  | 0.25 | - 0.4 |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| ${ }_{\text {lozH }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| lozl |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| I |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| $\mathrm{l}_{1}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{1 / 2}$ | CLKS | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 | mA |
|  | Others |  |  |  |  | -0.1 |  |
| $10^{\ddagger}$ | Q outputs | $V_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -20 |  | -130 | mA |
|  | FULI, EMPTY |  |  | -20 |  | -112 |  |
| Icc |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |  |  | 175 | 270 | mA |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
\# The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los-
switching characteristics over recommended ranges of supply voltage and operating free-air temperature

| PARAMETER | FROM (INPUT) | TO(OUTPUT) | $\begin{aligned} V_{C C} & =5 \mathrm{~V}, \\ C_{L} & =50 \mathrm{pF}, \\ R 1 & =500 \mathrm{Q}, \\ R 2 & =500 \mathrm{Q}, \\ \mathrm{~T}_{\mathrm{A}} & ={25^{\circ} \mathrm{C}} \end{aligned}$ |  |  | $\begin{gathered} \mathrm{V}_{\mathrm{Cc}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ \mathrm{R} 1=500 \Omega, \\ \mathrm{R} 2=500 \Omega, \\ \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{gathered}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN MAX |  |
| $f_{\text {max }}$ | LDCK, UNCK |  | 40 |  |  | 40 | MHz |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\dagger$ | Any Q |  | 18 | 26 | 30 | ns |
|  | UNCK $\uparrow$ |  |  | 18 | 24 | 27 |  |
| tPLH | LDCK $\dagger$ | EMPTY |  | 12 | 16 | 18 | ns |
| $\mathrm{t}_{\text {PHL }}$ | UNCK ${ }^{\text {¢ }}$ |  |  | 12 | 17 | 20 |  |
| $\mathrm{t}_{\mathrm{PHL}}$ | RST 1 | EMPTY |  | 12 | 17 | 20 | ns |
| ${ }_{\text {¢ }}^{\text {HL }}$ | LDCK $\dagger$ | FULI |  | 16 | 21 | 22 | ns |
| trin | UNCK $\dagger$ | FULL |  | 10 | 15 | 18 | ns |
|  | RST $\downarrow$ |  |  | 13 | 19 | 23 |  |
| ten | OEf | Q |  | 11 | 15 | 17 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE! | Q |  | 11 | 17 | 19 | ns |

- Independent Asynchronous Inputs and Outputs
- 64 Words By 9 Bits
- Data Rates From 0 to $40 \mathbf{M H z}$
- Fall-Through Time . . 20 ns Typical
- 3-State Outputs


## description

This 576-bit memory uses Advanced Low-Power Schottky IMPACT - X"' technology and features high speed and fast fall-through times. It is organized as 64 words by 9 bits.
A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The function is used as a buffer to couple two buses operating at different clock rates. This FIFO is designed to process data at rates from 0 to 40 MHz in a bitparallel format, word by word.
Data is written into memory on a low-to-high transition of the load clock input (LDCK) and is read out on a low-to-high transition of the unload clock input (UNCK). The memory is full when the number of words clocked in exceeds by 64 the number of words clocked out. When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.

Status of the FIFO memory is monitored by the FULL, EMPTY, ALMOST FULL/EMPTY, and HALF FULL output flags. The FULL output will be low when the memory is full and high when the memory is not full. The EMPTY output will be low when the memory is empty and high when it is not empty. The ALMOST FULL/EMPTY flag is high when the FIFO contains eight or less words or fifty-six or more words. The ALMOST FULL/EMPTY flag is low when the FIFO contains between nine and fifty-five words. The HALF FULL flag is high when the FIFO contains thirty-two or more words, and is low when the FIFO contains thirty-óne words or less.


## SN74ALS2233A <br> $64 \times 9$ ASYNCHRONOUS FIRST-IN, FIRST.OUT MEMORY

## description (continued)

A low level on the reset input ( $\overline{\mathrm{RST}}$ ) resets the internal stack control pointers and also sets EMPTY low and FULL high. The outputs are not reset to any specific logic levels. The first low-to-high transition on LDCK, either after a $\overline{\text { RST }}$ pulse or from an empty condition, causes EMPTY to go high and the data to appear on the $\mathbf{Q}$ outputs. The first word does not have to be unloaded. Data outputs are noninverting with respect to the data inputs and are at a high-impedance state when the output-enable input (OE) is low. The OE input does not affect either the FULL or EMPTY output flags. Cascading is easily accomplished in the word-width direction, but is not possible in the word-depth direction.

The SN74ALS2233A is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## logic symbol $\dagger$



[^15]Pin numbers shown are for the N package.
logic diagram (positive logic)


# SN174ALS2233A <br> $64 \times 9$ ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMMORY 

## absolute maximum ratings over operating free-air temperature range

Supply voltage, VCC ..... 7 V
Input voltage ..... 7 V
Voltage applied to a disabled 3-state output ..... 5.5 V
Operating free-air temperature range ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## recommended operating conditions

|  |  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 | V |
| ${ }^{\mathrm{I} O H}$ | High-level output current | Q outputs |  |  | -2.6 | mA |
|  |  | Flag outputs |  |  | -0.4 |  |
| ${ }^{\text {IOL }}$ | Low-level output current | Q outputs |  |  | 24 | mA |
|  |  | Flag outputs |  |  | 8 |  |
| $\mathrm{f}_{\text {clock }}$ | Clock frequency | LDCK, UNCK | 0 |  | 40 | MHz |
| ${ }^{\text {w }}$ w | Pusle duration | R̄ST low | 25 |  |  | ns |
|  |  | LDCK low | 13 |  |  |  |
|  |  | LDCK high | 12 |  |  |  |
|  |  | UNCK low | 13 |  |  |  |
|  |  | UNCK high | 12 |  |  |  |
| $\mathrm{t}_{\text {su }} 1$ | Setup time, data before LDCK $\uparrow$ |  | 5 |  |  | ns |
| $\mathrm{t}_{\text {su }} 2$ | Setup time, $\overline{\mathrm{RST}}$ high (inactive) before LDCK $\uparrow$ |  | 5 |  |  | ns |
| $\mathrm{t}_{\mathrm{h}}$ | Hold time, data after LDCK $\uparrow$ |  | 5 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IK }}$ |  | $V_{C C}=4.5 \mathrm{~V}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | 1.2 | V |
| $\mathrm{VOH}^{\text {O }}$ | Flag outputs | $\mathrm{V}_{\text {CC }}=$ MIN TO MAX, $\mathrm{I}_{\text {OH }}=0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}-2}$ |  |  | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| $\mathrm{VOL}_{\text {OL }}$ | Q Outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | $\mathrm{IOL}^{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 | v |
|  | Outputs |  | $\mathrm{IOL}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | Flag outputs |  | $\mathrm{IOL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  |  |  | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| IOZH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -20 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| IIH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| ILL | CLKs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 | mA |
|  | Others |  |  |  |  | -0.1 |  |
| $10^{ \pm}$ | Q outputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -20 |  | -130 | mA |
|  | Flag outputs |  |  | -20 |  | -112 |  |
| ICC |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  | 175 | 290 | mA |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.

## $64 \times 9$ ASYNCHRONOUS FIRST-IN, FIRST.OUT MEMORY

D3092, FEBRUARY 1988-REVISED MARCH 1990
switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & R 1=500 \mathrm{\Omega}, \\ & R_{1}=500 \Omega, \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ \mathrm{R} 1=500 \mathrm{\Omega}, \\ R 2=500 \Omega, \\ \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \hline \end{gathered}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  |  |  |  | 40 |  | MHz |
|  | UNCK |  |  |  |  | 40 |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\uparrow$ | Any 0 |  | 18 | 26 |  | 30 | ns |
| tpd | UNCK $\uparrow$ | Any 0 |  | 18 | 24 |  | 27 | ns |
| tPLH | L.DCK $\uparrow$ | EMPTY |  | 12 | 16 |  | 18 | ns |
| tPHL | UNCK $\uparrow$ | EMPTY |  | 12 | 17 |  | 20 | ns |
| tPHL | RST $\downarrow$ | EMPTY |  | 12 | 17 |  | 20 | ns |
| tPHL | LDCKt | FULI |  | 16 | 21 |  | 22 | ns |
| tPLH | UNCK $\uparrow$ | FULL |  | 10 | 15 |  | 18 | ns |
| tPLH | RST $\downarrow$ | FULL |  | 13 | 19 |  | 23 | ns |
| tPLH | LDCK $\uparrow$ | ALMOST |  | 22 | 27 |  | 30 | ns |
| tPHL |  | FULL/EMPTY |  | 19 | 25 |  | 28 |  |
| tPLH | UNCK $\uparrow$ | ALMOST FULL/EMPTY |  | 22 | 27 |  | 30 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 17 | 23 |  | 26 |  |
| ${ }^{\text {tPLH }}$ | RST $\downarrow$ | ALMOST FULL/EMPTY |  | 12 | 16 |  | 18 |  |
| ${ }_{\text {tPLH }}$ | LDCK $\dagger$ | HALF FULL |  | 22 | 27 |  | 30 | ns |
| tPHL | $\overline{\text { RST }} \downarrow$ | HALF FULL |  | 28 | 32 |  | 35 | ns |
| tPHL | UNCK $\uparrow$ | HALF FULL |  | 16 | 22 |  | 25 | ns |
| ten | OET | Q |  | 11 | 15 |  | 17 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE】 | 0 |  | 11 | 17 |  | 19 | ns |


| General Intormation | 1 |
| :---: | :---: |
| Unidirectional Clocked FiFOs | 2 |
| Unidirectional Fifos | 3 |
| Bidirectional Clocked FIFOs | 4 |
| Bidirectional FiFOs | 5 |
| Product Previous | 6 |
| Articles and Application Notes | 7. |
| Mechanical Bata | 8 |

- Member of the Texas Instruments Widebus ${ }^{\text {n4 }}$ Famlly
- Free-Running CLKA and CLKB May be Asynchronous or Colncldent
- Read and Write Operations Synchronized to Independent System Clocks
- Two Separate $512 \times 18$ Clocked FIFOs Bufiering Data In Opposite Directions
- IRA and ORA Synchronized to CLKA
- IRB and ORB Synchronized to CLKB
- Programmable Almost Full/Almost Empty Flags
- Fast Access Times of 9 ns With a $50-\mathrm{pF}$ Load and SImultaneous Switching Data Outputs
- Data Rates up to 80 MHz
- Advanced BICMOS Technology
- Avallable in 80-pin Quad Flatpack (PH) and Space-Saving 80-pin Shrink Quad Flatpack (PN)
- Microprocessor Interface Control Loglc




## description

A FIFO memory is a storage device that allows data to be read from its array in the same order it is written. The SN74ABT7819 is a high-speed, low-power BiCMOS bidirectional clocked FIFO memory. Two independent $512 \times 18$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. Each FIFO has flags to indicate empty and full conditions, a half-full flag, and a programmable almost full/almost empty flag.

The SN74ABT7819 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.

The state of the A0-A17 outputs is controlled by CSA andW/RA. When both CSA and W/RA are low, the outputs are active. The A0-A17 outputs are in the high-impedance state when either CSA or W/RA is high. Data is written to FIFOA-B from port A on the low-to-high transition of CLKA when CSA is low, W/RA is high, WENA is high, and the IRA flag is high. Data is read from FIFOB-A to the AO-A17 outputs on the low-to-high transition of CLKA when CSA is low, W/RA is low, RENA is high, and the ORA flag is high.

## description (continued)

The state of the B0-B17 outputs is controlled by CSB and W/RB. When both CSB andW/RB are low, the outputs are active. The B0-B17 outputs are in the high-impedance state when either CSB or W/RB is high. Data is written to FIFOB-A from port B on the low-to-high transition of CLKB when CSB is low, W/RB is high, WENB is high, and the IRB flag is high. Data is read from FIFOB-A to the B0-B17 outputs on the low-to-high transition of CLKB when CSB is low, W/RB is low, RENB is high, and the ORB flag is high.
The setup and hold time constraints for the chip selects (CSA, CSB) and write/read selects (W/RA, W/RB) are for enabling write and read operations on memory and are not related to the high-impedance control of the data outputs. If a port's read enable (RENA or RENB) and write enable (WENA or WENB) are set low during a clock cycle, the chip select and write/read select may switch at any time during the cycle to change the state of the data outputs.

The input ready and output ready flags of aFIFO are two-stage synchronized to the port clocks for use as reliable control signals. CLKA synchronizes the status of the input ready flag of FIFOA-B (IRA) and the output ready flag of FIFOB-A (ORA). CLKB synchronized the status of the input ready flag of FIFOB-A (IRB) and the output ready flag of FIFOA-B (ORB). When the input ready flag of a port is low, the FIFO receiving input from the port is full, and writes are disabled to its array. When the output ready flag of a port is low, the FIFO that outputs data to the port is empty, and reads from its memory are disabled. The first word loaded to an empty memory is sent to the FIFO's output register at the same time its output ready flag is asserted (high). When the memory is read empty and the output ready flag is forced low, the last valid data remains on the FIFO outputs until the output ready flag is asserted (high) again. In this way, a high on the output ready flag indicates new data is present on the FIFO outputs.
functional block diagram

logic symbol ${ }^{\dagger}$

$\dagger$ This symbol is in accordance with ANSI／IEEE Std 91－1984 and IEC Publication 617－12．
Pin numbers shown are for the PH package．

## SN74ABT7819

## enable logic diagram (positive logic)



FUNCTION TABLES

| SELECT INPUTS |  |  |  |  | A0-A17 | A Port Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLKA | CSA | W/RA | WENA | RENA |  |  |
| $X$ | $H$ | $X$ | $X$ | $X$ | High Z | None |
| $\uparrow$ | L | H | H | X | High Z | Write A0-A17 to FIFOA-B |
| $\uparrow$ | L | L | X | H | Active | Read FIFOB-A to A0-A17 |


| SELECT INPUTS |  |  |  |  | Bo-B17 | B Port Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLKB | CSB | W/RB | WENB | RENB |  |  |
| X | H | X | X | X | High Z | N |
| $\uparrow$ | L | H | H | X | High Z | Write B0-B17 to FIFOB-A |
| $i$ | L | L | X | H | Active | Read FIFOA-B to B0-B17 |

# SN74ABT7819 512 X 18 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY 

SCBS125A-D4502, JULY 1992-REVISED AUGUST 1992

## Terminal Functions

| PIN NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A17 | 1/0 | Port A data. 18-bit bidirectional data port for side A |
| AF/AEA | 0 | FIFOA-B almost full/almost empty flag. Depth offsets may be programmed for this flag, or the default value of 128 may be used for both the almost empty offset $(X)$ and the almost full offset ( $M$ ). AF/AEA is high when $X$ or less words or (512 minus $Y$ ) or more words are stored in FIFOA-B. AF/AEA is forced high when FIFOA-B is reset. |
| AF/AEB | 0 | FIFOB-A almost full/almost empty flag. Depth offsets may be programmed for this flag, or the default value of 128 may bs uesd for both the almost empty offsot $(X)$ and the almost full offest $(Y)$. AF/AEB is high when $X$ or less words or (512 minus $Y$ ) or more words are stored in FIFOB-A. AF/AEB is forced high when FIFOB-A is reset. |
| B0-B17 | I/O | Port B data. 18-bit bidirectional data port for side B |
| CLKA | 1 | Port A clock. CLKA is a continuous clock that synchronizes all data transfors through port $A$ to its low-to-high transition and may be asynchronous or coincident to CLKB. |
| CLKB | I | Port B clock. CLKB is a continuous clock that synchronizes all data transfers through port B to its low-to-high transition and may be asynchronous or coincident to CLKA. |
| CSA | 1 | Port A chip select. CSA must be low to enable a low-to-high transition of CLKA to either write data from AO-A17 to FIFOA-B or read data from FIFOB-A to AO-A17. The AO-A17 outputs are in the high-impedance state when CSA is high. |
| CSB | 1 | Port B chip select. CSB must be low to enable a low-to-high transition of CLKB to either write data from B0-B17 to FIFOB-A or read data from FIFOA-B to B0-B17. The B0-B17 outputs are in the high-impedance state when CSB is high. |
| HFA | 0 | FIFOA-B half-full flag. HFA is high when FIFOA-B contains 256 or more words and is low when FIFOA-B contains 255 or less words. HFA is set low after FIFOA-B is reset. |
| HFB | 0 | FIFOB-A half-full flag. HFB is high when FIFOB-A contains 256 or more words and is low when FIFOB-A contains 255 or less words. HFB is set low after FIFOB-A is reset. |
| IRA | 0 | Port A input ready flag. IRA is synchronized to the low-to-high transition of CLKA. When IRA is low, FIFOA-B is full, and writes to its array are disabled. IRA is set low during a FIFOA-B reset and is set high on the second low-to-high transition of CLKA after reset. |
| IRB | 0 | Port B input ready flag. IRB is synchronized to the low-to-high transition of CLKB. When IRB is low, FIFOB-A is full, and writes to its array are disabled. IRB is set low during a FIFOB-A reset and is set high on the second low-to-high transition of CLKB after roset. |
| ORA | 0 | Port A output ready flag. ORA is synchronized to the low-to-high transition of CLKA. When ORA is low, FIFOB-A Is empty, and reads from its array are disabled. The last valid word remains on the FIFOB-A outputs when ORA is low. Ready data is present for the AO-A17 outputs when ORA is high. ORA is set low during a FIFOB-A reset and goes high on the third low-to-high transition of CLKA after the first word is loaded to an empty FIFOB-A. |
| ORB | 0 | Port B output ready flag. ORB is synchronized to the low-to-high transition of CLKB. When ORB is low, FIFOA-B is empty, and reads from its array are disabled. The last valid word remains on the FIFOA-B outputs when ORB is low. Ready data is present for the BO-B17 outputs when ORB is high. ORB is set low during a FIFOA-B reset and goes high on the third low-to-high transition of CLKB after the first word is loaded to an ompty FIFOA-B. |
| PENA | 1 | AF/AEA program enable. After FIFOA-B is reset and before a word is written to its array, the binary value on AO-A7 is latched as an AF/AEA offset when PENA is low and CLKA is high. |
| PENB | 1 | AF/AEB program enable. After FIFOB-A is reset and before a word is written to its array, the binary value on BO-B7 is latched as an AF/AEB offset when PENB is low and CLKB is high. |
| RENA | 1 | Port A read enable. A high level on RENA enables data to be read from FIFOB-A on the low-to-high transition of CLKA when CSA is low, W/RA is low, and ORA is high. |
| RENB | 1 | Port B read enable. A high level on RENB enables data to be read from FIFOA-B on the low-to-high transition of CLKB when CSB is low, W/RB is low, and ORB is high. |
| RSTA | 1 | FIFOA-B reset. To reset FIFOA-B, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RSTA is low. This sets HFA low, IRA low, ORB low, and AF/AEA high. |
| RSTB | I | FIFOB-A reset. To reset FIFOB-A, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RSTB is low. This sets HFB low, IRB low, ORA low, and AF/AEB high. |
| WENA | I | Port A write enable. A high level on WENA enables data on AO-A17 to be written into FIFOA-B on the low-to-high transition of CLKA when W/RA is high, CSA is low, and IRA is high. |

## Terminal Functions (continued)

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :--- |
| WENB | I | Port B write enable. A high level on WENB enables data on BO-B17 to be written into FIFOB-A on the low-to-high <br> transition of CLKB when W/RB is high, CSB is low, and IRB is high. |
| W/RA | I | Port A write/read select. A high on W/RA enables AO-A17 data to be written to FIFOA-B on a low-to-high transition of <br> CLKA when WENA is high, CSA is low, and IRA is high. A low on W/RA enables data to be read from FIFOB-A on a <br> low-to-high transition of CLKA when RENA is high, CSA is low, and ORA is high. The A0-A17 outputs are in the <br> high-impedance state when W/RA is high. |
| W/RB | IPort B write/read select. A high on W/RB enables B0-B17 data to be written to FIFOB-A on a low-to-high transition of <br> CLKB when WENB is high, CSB is low, and IRB is high. A low on W/RB enables data to be read from FIFOA-B on a <br> low-to-high transition of CLKB when RENB is high, CSB is low, and ORB is high. The BO-B17 outputs are in the <br> high-impedance state when W/RB is high. |  |

## timing diagrams



AF/AEA


Figure 1. Reset Cycle For FIFOA-B ${ }^{\dagger}$
${ }^{\dagger}$ FIFOB-A is reset in the same manner.

t Written to FIFOA-B
Figure 2. Write TIming - Port A

$\ddagger$ Written to FIFOB-A
Figure 3. Write Tlming - Port B

## SN74ABT7819 512 X 32 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCBS 125A-D4502, JULY 1992-REVISED AUGUST 1992


Flgure 4. ORB Flag TIming and FIrst Data Word Fallthrough When FIFOA-B Is Empty ${ }^{\dagger}$ $\dagger$ Operation of FIFOB-A is identical to that of FIFOA-B


Figure 5. Write Cycle and IRA Flag Timing When FIFOA-B is Full ${ }^{\dagger}$
${ }^{\dagger}$ Operation of FIFOB-A is identical to that of FIFOA-B

## SN74ABT7819

## $512 \times 18$ X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY

## SCBS 125A-D4502, JULY $1992-$ REVISED AUGUST 1992

read timing diagrams

${ }^{\dagger}$ Read from FIFOB-A
Figure 6. Read TIming - Port A

$\ddagger$ Read from FIFOA-B
Figure 7. Read TIming - Port B



## 512 X 18 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY

SCBS125A-D4502, JULY 1892-REVISED AUGUST 1992

## offset values for AF/AE

The almost full/almost empty flag of each FIFO has two programmable limits, the almost empty offset value ( $X$ ) and the almost full offset value $(\mathrm{M}$. They may be programmed from the input of the FIFO after it is reset and before a word is written to its memory. An AF/AE flag will be high when its FIFO contains $X$ or less words or ( 512 minus $Y$ ) or more words.
To program the offset values for AF/AEA, PENA may be brought low after FIFOA-B is reset and only when CLKA is low. On the following low-to-high transition of CLKA, the binary value on AO-A7 is stored as the almost empty offset value $(X)$ and the almost full offset value $(Y)$. Holding PENA low for another low-to-high transition of CLKA will reprogram Y to the binary value on $\mathrm{AO}-\mathrm{A} 7$ at the time of the second CLKA low-to-high transition.
During the first two CLKA cycles used for offset programming, PENA may be brought high only when CLKA is low. PENA may be brought high at any time after the second CLKA pulse used for offset programming returns low. A maximum value of 255 may be programmed for either $X$ or $Y$. To use the default values of $X=Y=128$, PENA must be tied high. No data is stored in FIFOA-B while the AF/AEA offsets are programmed.

The AF/AEB flag is programmed in the same manner with PENB enabling CLKB to program the offset values taken from B0-B7.


Figure 9. TIming Dlagram to Program $X$ and $Y$ Separately for AF/AEA

## SN74ABT7819 $512 \times 18 \times 2$ CLOCKED FIRST-IN, FIRST-OUT MEMORY

absolute maximum ratings over operating free-air temperature (unless otherwise noted) ${ }^{\dagger}$
$\qquad$

Voltage range applied to any output in the high state or power-off state, $\mathrm{V}_{\mathrm{O}} \ldots \ldots . . . . .$.
Current into any output in the low state, lo....................................................
Input clamp current, $\mathrm{I}_{\text {K }}\left(\mathrm{V}_{1}<0\right)$........................................................................ 18 mA

Storage temperature range . ........................................................................ $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
NOTE 1: The input and output negative-voltage ratings may be exceeded if the input and output clamp-current ratings are observed.
recommended operating conditions

|  | MIN | NOM MAX | UNIT |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}} \quad$ Supply voltage | 4.5 | $5 \quad 5.5$ | V |
| $\mathrm{V}_{\text {IH }} \quad$ High-level input voltage | 2 |  | V |
| $V_{\text {IL }} \quad$ Low-level input voltage |  | 0.8 | V |
| $V_{1} \quad$ Input voltage | 0 | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{l}_{\mathrm{OH}} \quad$ High-lovel output current |  | -12 | mA |
| loL Low-level output current | . | 24 | mA |
| $\Delta t / \Delta v \quad$ Input transition rise or fall rate |  | 5 | $\mathrm{ns} / \mathrm{N}$ |
| $T_{A} \quad$ Operating free-air temperature | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  |  | MIN | TYP ${ }^{\text { }}$ | MAX | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IK }}$ |  | $V_{C C}=4.5 \mathrm{~V}, \quad Y_{1}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ |  |  | 2.5 |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=-$ | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ |  | 3 |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=-$ |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}, \quad \mathrm{I}_{0 \mathrm{~L}}=2$ |  |  |  | 0.5 |  | V |
| 4 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=\mathrm{V}_{\mathrm{C}}$ |  |  |  |  | $\pm 1$ | $\mu \mathrm{A}$ |
| ${ }^{1027}{ }^{\text {g }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| $\mathrm{lozL}^{\text {s }}$ |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $10^{1}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.5$ | $\mathrm{V}_{\mathrm{O}}=2.5 \mathrm{~V}$ |  | -40 | -100 | -180 | mA |
| Icc |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{lO}_{0}=0$, | $V_{1}=V_{c c}$ or GND | Outputs high |  |  | 15 | mA |
|  |  |  |  | Outputs low | 95 |  |  |  |
|  |  |  |  | Outputs disabled |  |  | 15 |  |
| $\mathrm{C}_{\mathrm{i}}$ | Control inputs | $\mathrm{V}_{1}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  | 6 |  | pF |
| $\mathrm{C}_{0}$ | Flags | $\mathrm{V}_{0}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  | 4 |  | pF |
| $\mathrm{C}_{\text {io }}$ | A or B ports | $\mathrm{V}_{0}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  | 8 |  | pF |

[^16]5 The parameters $\mathrm{l}_{\mathrm{OZH}}$ and $\mathrm{l}_{\mathrm{OZ}}$ include the input leakage current.
I Not more than one output should be tested at a time, and the duration of the test should not exceed one second.
timing characteristics over recommended operating free-air temperature range (unless otherwise noted)


[^17]
## SN74ABT7819

 512 X 18 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORYSCBS125A-D4502, JULY 1992-REVISED AUGUST 1992
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 10 and 12)

| PARAMETER | FROM (INPUT) | T0 (OUTPUT) | 'ABT7819-12 |  |  | 'ABT7819-15 |  | 'ABT7819-20 |  | 'ABT7819-30 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{f}_{\text {max }}$ | CLKA or CLKB |  | 80 |  |  | 67 |  | 50 |  | 33.3 |  | MHz |
| $t_{\text {pd }}$ | CLKA $\uparrow$ | A0-A17 | 4 | 7 | 9 | 4 | 10 | 4 | 12 | 4 | 14 | ns |
|  | CLKB $\dagger$ | B0-B17 | 4 | 7 | 9 | 4 | 10 | 4 | 12 | 4 | 14 |  |
| $\mathrm{t}_{\mathrm{pd}}{ }^{ \pm}$ | CLKA $\dagger$ | A0-A17 |  | 6 |  |  |  |  |  |  |  | ns |
|  | CLKB $\dagger$ | B0-B17 |  | 6 |  |  |  |  |  |  |  |  |
| $t_{\text {pd }}$ | CLKA $\dagger$ | IRA | 4 |  | 9 | 4 | 10 | 4 | 12 | 4 | 14 | ns |
|  | CLKB $\dagger$ | IRB | 4 |  | 9 | 4 | 10 | 4 | 12 | 4 | 14 |  |
| $t_{p d}$ | CLKA ${ }^{\text {a }}$ | ORA | 3.5 |  | 9 | 3.5 | 10 | 3.5 | 12 | 3.5 | 14 | ns |
|  | CLKB $\dagger$ | ORA | 3.5 |  | 9 | 3.5 | 10 | 3.5 | 12 | 3.5 | 14 |  |
| $t_{\text {pd }}$ | CLKA $\uparrow$ | AF/AEA | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
|  | CLKB $\dagger$ |  | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 |  |
| tplH | ASTA | AFIAEA | 4 |  | 12 | 4 | 14 | 4 | 15 | 4 | 16 | ns |
| $t_{\text {pd }}$ | CLKA $\dagger$ | AF/AEB | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
|  | CLKB $\dagger$ |  | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 |  |
| t+LH | RSTB | AF/AEB | 4 |  | 12 | 4 | 14 | 4 | 15 | 4 | 16 | ns |
|  | CLKA $\dagger$ | HFA | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 |  |
| triL | CLKB $\dagger$ | HFA | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
|  | RSTA |  | 4 |  | 12 | 4 | 14 | 4 | 15 | 4 | 16 |  |
| +PHL | CLKA $\dagger$ | HFB | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
| ¢LH | CLKB $\dagger$ | HFB | 8 |  | 17 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
|  | RSTB |  | 4 |  | 12 | 4 | 14 | 4 | 15 | 4 | 16 |  |
| ton | CSA | A0-A17 | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 | ns |
|  | W/RA |  | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 |  |
| ton | CSB | B0-B17 | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 | ns |
|  | W/RB |  | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 |  |
| $t_{\text {dis }}$ | CSA | A0-A17 | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 | ns |
|  | W/RA |  | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 |  |
| $t_{\text {dis }}$ | CSB | B0-B17 | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 | ns |
|  | W/RB |  | 2.5 |  | 8 | 2.5 | 9 | 2.5 | 10 | 2.5 | 11 |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This parameter measured with a 30-pF load (see Figure 10).

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
vs
LOAD CAPACITANCE


Figure 10


Figure 11

## calculating power dissipation

With ICCF taken from Figure 3, the maximum power dissipation based on all outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[I_{C C F}\right]+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f 0\right)
$$

$I_{C C F}=$ maximum ICC per clock frequency
$C_{L}=$ output capacitive load
$f_{0}=$ data output frequency

## PARAMETER MEASUREMENT INFORMATION



| PARAMETER |  | R1, R2 | $\mathrm{C}_{\mathrm{L}}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | ${ }_{4}$ | $500 \Omega$ | 50 pF | Open |
|  | $t_{\text {PzL }}$ |  |  | Closed |
| $t_{\text {dis }}$ | ${ }_{4} \mathrm{HHZ}$ | 500 ¢ | 50 pF | Open |
|  | t+LZ |  |  | Closed |
| $t_{\text {pd }}$ |  | 500 ¢ | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 12. Load Circult and Voltage Waveforms

| General Information | 1 |
| :---: | :---: |
| Unidirectional Clocked FiFos | 2 |
| Unidirectional FiFos | 3 |
| Bidirectional Clocked Firos | 4 |
| Bidirectional FIFOs | 5 |
| Product Previevs | 6 |
| Articles and Application Motes | 7 |
| Mechanical Data | 8 |

## SN74ABT7820

SCAS206A-D4503, AUGUST 1991-REVISED AUGUST 1992

- Member of the Texas Instruments Widebus ${ }^{\text {™ }}$ Family
- Independent Asynchronous Inputs and Outputs
- Produced in Advanced BICMOS Technology
- Two Separate $512 \times 18$ FIFOs Buffering Data In Opposite Directions
- Programmable Almost Full/Almost Empty Flags
- Empty, Full, and Half-Full Flags
- Fast Access Times of 12 ns With a 50-pF Load and SImultaneous Swltching Data Outputs
- Supports Clock Rates Up To 67 MHz
- Avallable In 80-Pin Quad Flat Package (PH) and Space-Saving 80-Pin Shrink Quad Flat Package (PN)




## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ABT7820 is arranged as two 512 by 18 -bit FIFOs for high speed and fast access times. It processes data at rates from 0 to 67 MHz with access times of 12 ns in a bit-parallel format.

The SN74ABT7820 consists of bus transceiver circuits, two $512 \times 18$ FIFOs, and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal FIFO memories. Enable inputs GAB and GBA control the transceiver functions. The SAB and SBA control inputs select whether real-time or stored data is transferred. The circuitry used for select control eliminates the typical decoding glitch that occurs in a multiplexer during the transition between stored and real-time data. Eight fundamental bus-management functions can be performed as shown on the operating modes page.

## SN74ABT7820 512 X 18 X 2 FIRST-IN, FIRST-OUT MEMORY

SCAS206A-D4503, AUGUST 1991-REVISED AUGUST 1992

## Terminal Functions

| NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A17 | 1/0 | Port A data. 18-bit bidirectional data port for side A. |
| AF/AEA | 0 | FIFO A almost full/almost empty flag. Depth offset values may be programmed for this fiag, or the default value of 128 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y$ ). AF/AEA is high when FIFO A contains $X$ or less words or ( 512 minus Y ) or more words. AF/AEA is set high after FIFO $A$ is reset. |
| AF/AEB | 0 | FIFO B almost full/almost empty flag. Depth offset values may be programmed for this flag, or the default value of 128 may be used for both the almost empty offset $(X)$ and the almost full offset $(Y)$. AF/AEB is high when FIFO B contains $X$ or less words or ( 512 minus $Y$ ) or more words. AF/AEB is set high after FIFO B is reset. |
| B0-B17 | 1/0 | Port B data. 18-bit bidirectional data port for side B. |
| EMPTYA | 0 | FIFO A empty flag. EMPTYA is low when FIFO A is empty and high when FIFO A is not empty. EMPTYA is set low after FIFO $A$ is reset. |
| EMPTYE | 0 | FIFO B empty flag. EMPTYB is low when FIFO B is empty and high when FIFO B is not empty. EMPTYB is set low after FIFO B is reset. |
| FULLA | 0 | FIFO A full flag. FULLA is low when FIFOA is full and high when FIFO A is not full. FULLA is set high after FIFO A is reset. |
| FULLE | 0 | FIFOB full flag. FULLB is low when FIFOB is full and high when FIFOB is not full. FULLE is set high after FIFO $B$ is reset. |
| GAB | 1 | Port B output enable. B0-B17 outputs are active when GAB is high and in the high-impedance state when GAB is low. |
| GBA | I | Port A output enable. A0-A17 outputs are active when GBA is high and in the high-impedance state when GBA is low. |
| HFA | 0 | FIFO A half-full flag. HFA is high when FIFO A contains 256 or more words and is low when FIFO A contains 255 or less words. HFA is set low after FIFO $A$ is reset. |
| HFB | 0 | FIFO B half-full flag. HFB is high when FIFO B contains 256 or more words and is low when FIFO B contains 255 or less words. HFB is set low after FIFO B is reset. |
| LDCKA | 1 | FIFO A load clock. Data is written into FIFO A on a low-to-high transition of LDCKA when FULLA is high. The first word written into an empty FIFO $A$ is sent directly to the FIFO A data outputs. |
| LDCKB | I | FIFO B load clock. Data is written into FIFO B on a low-to-high transition of LDCKB when FULLB is high. The first word written into an empty FIFO B is sent directly to the FIFO B data outputs. |
| PENA | I | FIFO A program enable. After reset and before a word is written into FIFO A, the binary value on AO-A7 is latched as an AF/AEA offset value when PENA is low and LDCKA is high. |
| PENB | I | FIFO B program enable. After reset and before a word is written into FIFO B, the binary value on BO-B7 is latched as an AF/AEB offset value when PENB is low and LDCKB is high. |
| RSTA | I | FIFO A reset. A low level on RSTA resets FIFO A forcing EMPTYA low, HFA low, FULLA high, and AF/AEA high. |
| RSTB | 1 | FIFO B reset. A low level on RSTB resets FIFO B forcing EMPTYB low, HFB low, FULLB high, and AF/AEB high. |
| SAB | I | Port $B$ read select. $S A B$ selects the source of $B 0-B 17$ read data. A low level selects real-time data from A0-A17. A high level selects the FIFO A output. |
| SBA | I | Port A read select. SBA selects the source of A0-A17 read data. A low level selects real-time data from B0 - B17. A high level selects the FIFO B output. |
| UNCKA | 1 | FIFO A unload clock. Data is read from FIFO A on a low-to-high transition of UNCKA when EMPTYA is high. |
| UNCKB | I | FIFO B unload clock. Data is read from FIFO B on a low-to-high transition of UNCKB when EMPTYB is high. |

logic symbol ${ }^{\dagger}$

$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984.
Pin numbers shown are for the PH package.
logic diagram (positive logic)


## operating modes

|  |  |
| :---: | :---: |
|  |  |
|  |  |
|  |  |

SELECT-MODE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| SBA | SAB | A BUS | B BUS |
| L | L | Real-time B to A bus | Real-time A to B bus |
| H | L | FIFO B to A bus | Real-time A to B bus |
| L | H | Real-time B to A bus | FIFO A to B bus |
| H | H | FIFO B to A bus | FIFO A to B bus |

OUTPUT-ENABLE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| GBA | GAB | A BUS | B BUS |
| L | L | Isolation/input to $A$ bus | Isolation/input to $B$ bus |
| $H$ | L | A bus enabled | Isolation/input to $B$ bus |
| L | H | Isolation/input to A bus | B bus enabled |
| H | H | A bus enabled | B bus enabled |

timing diagram for FIFO $\mathrm{A}^{\dagger}$


## offset values for AF/AE

The almost full/almost empty flag of each FIFO has two programmable limits: the almost empty offset value $(X)$ and the almost full offset value $(\mathrm{Y}$ ). The offsets of a flag may be programmed from the input of its FIFO after it is reset and before any data is written to its memory. An AF/AE flag is high when its FIFO contains X or less words or ( 512 minus $Y$ ) or more words.
To program the offset values for AF/AEA, PENA may be brought low after FIFO A is reset and only when LDCKA is low. Onthe following low-to-hightransition of LDCKA, the binary value on A0-A7 is stored as the almost empty offset value $(X)$ and the almost full offset value ( Y . Holding PENA low for another low-to-high transition of LDCKA will reprogram Y to the binary value on $\mathrm{AO}-\mathrm{A} 7$ at the time of the second LDCKA low-to-high transition.
PENA may be brought back high only when LDCKA is low during the first two LDCKA cycles. PENA may be brought high at any time after the second LDCKA pulse retums low. A maximum value of 255 may be programmed for either X or Y . To use the default values of $\mathrm{X}=\mathrm{Y}=128$ for AF/AEA, PENA must be tied high. No data is stored in the FIFO when its AF/AE offsets are programmed.
The AF/AEB flag is programmed in the same manner. PENB enables LDCKB to program the AF/AEB offset values taken from $B 0-B 7$.


Flgure 1. Timing Dlagram to Program $X$ and $Y$ Separately for AF/AEA

## 512 X 18 X 2 FIRST-IN, FIRST-OUT MEMORY

## SCAS206A-D4503,AUGUST 1991-REVISED AUGUST 1992

## absolute maximum ratings over operating free-air temperature (unless otherwise noted) ${ }^{\dagger}$

Supply voltage range, $V_{C C}$ -0.5 V to 7 V
Input voltage range, $\mathrm{V}_{1}$ (see Note 1) ........................................................ . 0.5 V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Voltage range applied to any output in the high state or power-off state, $\mathrm{V}_{\mathrm{O}} \ldots \ldots . . . .$.
Current into any output in the low state, $\mathrm{I}_{0}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 mA
Input clamp current, $\mathrm{I}_{\mathrm{IK}}\left(\mathrm{V}_{\mathrm{I}}<0\right)$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 mA
Output clamp current, $\mathrm{I}_{\mathrm{OK}}\left(\mathrm{V}_{\mathrm{O}}<0\right)$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -50 mA
Storage temperature range $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not
implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
NOTE 1: The input and output negative-voltage ratings may be exceeded if the input and output clamp-current ratings are observed.

## recommended operating conditions

|  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }} \quad$ Supply voltage | 4.5 | 4.5 | 5.5 | V |
| $\mathrm{V}_{1 \mathrm{H}} \quad$ High-lovel input voitage | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }} \quad$ Low-level input voltage |  |  | 0.8 | V |
| $\mathrm{V}_{1} \quad$ Input voltage | 0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |
| $\mathrm{l}_{\mathrm{OH}} \quad$ High-level output current |  |  | -12 | mA |
| Iol Low-level output current |  |  | 24 | mA |
| $\Delta t / \Delta v \quad$ Input transition rise or fall rate |  |  | 5 | $\mathrm{ns} / \mathrm{N}$ |
| $T_{A}$ Operating free-air tomperature | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  |  |  | MIN | TYP ${ }^{\text { }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIK |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ |  |  | 2.5 |  |  | V |
|  |  | $V_{C C}=5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ |  |  | 3 |  |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOH}^{\text {}}=-12 \mathrm{~mA}$ |  |  | 2 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=24 \mathrm{~mA}$ |  |  |  |  | 0.55 | V |
| 1 |  | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}$ or GND |  |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{lozH}^{5}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| $\mathrm{lozL}^{\text {b }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $10{ }^{1}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.5 \mathrm{~V}$ |  |  | -40 | -100 | -180 | mA |
| lcc |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | $\mathrm{I}_{0}=0$, | $\mathrm{V}_{1}=\mathrm{V}_{\mathrm{CC}}$ or GND | Outputs high |  |  | 15 | mA |
|  |  | Outputs low |  |  |  |  | 95 |  |
|  |  | Outputs disabled |  |  |  |  | 15 |  |
| $\mathrm{C}_{1}$ | Control inputs |  | $\mathrm{V}_{1}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  |  | 6 |  | pF |
| $\mathrm{C}_{0}$ | Flags |  | $\mathrm{V}_{0}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  |  | 4 |  | pF |
| $\mathrm{C}_{\mathrm{io}}$ | A or B ports | $\mathrm{V}_{0}=2.5 \mathrm{~V}$ or 0.5 V |  |  |  |  | 8 |  | pF |

## $\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.

${ }^{5}$ The parameters $\mathrm{l}_{\mathrm{OZH}}$ and $\mathrm{l}_{\mathrm{OZ}}$ include the input leakage current.
I Not more than one output should be tested at a time, and the duration of the test should not exceed one second.
timing characteristics over recommended operating free-air temperature range (unless otherwise noted)

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figure 4)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | 'ACT7820-15 |  | 'ACT7820-20 |  | 'ACT7820-25 |  | 'ACT7820-30 |  | UNT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text { }}$ MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{f}_{\text {max }}$ | LDCK, UNCK |  |  | 67 |  | 50 |  | 40 |  | 33.3 | MHz |
| $t_{\text {pd }}$ | LDCKA, LDCKB $\uparrow$ | B/A | 4 | 14 | 4 | 15 | 4 | 18 | 4 | 20 | ns |
|  | UNCKA ${ }^{\text {, }}$ UNCKB $\dagger$ |  | 4 | $9 \quad 12$ | 4 | 13.5 | 4 | 15 | 4 | 17 |  |
| $t_{\text {pd }}{ }^{\prime}$ | UNCKA ${ }^{\text {U }}$ UNCKB $\dagger$ | B/A |  | 8 |  |  |  |  |  |  | ns |
| ${ }_{\text {tPLH }}$ | LDCKA $\uparrow$, LDCKB $\uparrow$ | EMPTYA, <br> EMPTYB | 4 | 14 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| $t_{\text {PHL }}$ | UNCKA $\uparrow$, UNCKB $\dagger$ |  | 4 | 13 | 4 | 14 | 4 | 16 | 4 | 18 |  |
|  | RSTA low, RSTB low | $\begin{aligned} & \text { EMPTYA, } \\ & \text { EMPTYB } \end{aligned}$ | 6 | 16 | 6 | 16 | 6 | 18 | 6 | 20 | ns |
|  | $\begin{aligned} & \text { LDCKA }, \\ & \text { LDCKB } \dagger \end{aligned}$ | FULLA, FULLE | 6 | 13 | 6 | 14 | 6 | 16 | 6 | 18 | ns |
| ${ }_{\text {tPLH }}$ | UNCKA ${ }^{4}$, UNCKB $\dagger$ | FULLA, FULLE | 6 | 15 | 6 | 15 | 6 | 17 | 6 | 19 | ns |
|  | RSTA low, RSTB low |  | 8 | 20 | 8 | 20 | 8 | 22 | 8 | 22 |  |
| $t_{\text {pd }}$ | LDCKA LDCKB $\dagger$ | AF/AEA, AF/AEB | 8 | 16 | 8 | 17 | 8 | 18 | 8 | 20 | ns |
|  | UNCKA ${ }^{1}$, UNCKB $\dagger$ |  | 8 | 16 | 8 | 17 | 8 | 18 | 8 | 20 |  |
| tPLH | $\begin{gathered} \hline \text { RSTA low, RSTB } \\ \text { low } \end{gathered}$ | AF/AEA, AF/AEB | 2 | 12 | 2 | 14 | 2 | 16 | 2 | 18 | ns |
| tplu | LDCKA ${ }^{\text {. }}$ LDCKB $\uparrow$ | $\begin{aligned} & \mathrm{HFA}, \\ & \mathrm{HFB} \end{aligned}$ | 8 | 15 | 8 | 15 | 8 | 17 | 8 | 19 | ns |
|  | UNCKA, UNCKB | HFA, HFB | 8 | 15 | 8 | 15 | 8 | 17 | 8 | 19 | ns |
| trul $^{\text {che }}$ | RSTA low, RSTB low |  | 2 | 12 | 2 | 14 | 2 | 16 | 2 | 18 |  |
| $t_{p d}$ | SAB/SBA ${ }^{\text {¢ }}$ | B/A | 2 | 10 | 2 | 11 | 2 | 12 | 2 | 14 | ns |
|  | A/B |  | 2 | 9 | 2 | 10 | 2 | 11 | 2 | 13 |  |
| ten | GBA/GAB | A/B | 2 | 6.5 | 2 | 8 | 2 | 10 | 2 | 12 | ns |
| $\mathrm{t}_{\text {dis }}$ | GBA/GAB | A/B | 2 | 11 | 2 | 12 | 2 | 13 | 2 | 14 | ns |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
$\ddagger$ All typical values are at $5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{1}$ This parameter is measured with a $30-\mathrm{pF}$ load (see Figure 2).
§ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
vs
LOAD CAPACITANCE


Figure 2


Flgure 3

## SN74ABT7820

## 512 X 18 X 2 FIRST-IN, FIRST-OUT MEMORY

SCAS206A-D4503,AUGUST 1991-REVISED AUGUST 1992

## calculating power dissipation

With I ICF taken from Figure 3, the maximum power dissipation based on all outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}\right]+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f o\right)
$$

$I_{C C F}=$ maximum $l_{C C}$ per clock frequency
$C_{L}=$ output capacitive load
$f_{0}=$ data output frequency

PARAMETER MEASUREMENT INFORMATION


| PARAMETER |  | R1, R2 | $C_{L}{ }^{\dagger}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | tPZH | $500 \Omega$ | 50 pF | Open |
|  | tpzl |  |  | Closed |
| $t_{\text {dis }}$ | $4_{\text {PHZ }}$ | $500 \Omega$ | 50 pF | Open |
|  | $t_{\text {LLZ }}$ |  |  | Closed |
| $t_{p d}$ |  | 5008 | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Figure 4. Load CIrcult and Voltage Waveforms

- Independent Asynchronous Inputs and Outputs
- Low-Power Advanced CMOS Technology
- Bidirectional
- 1024 Words by 9 Bits Each
- Programmable Aimost Full/Almost Empty Flag
- Empty, Full, and Half-Full Flags
- Access Times of 25 ns With a 50-pF Load
- Data Rates From 0 to 50 MHz
- Fall-Through Times of 22 ns Max
- High Output Drive for Direct Bus Interface

|  | FN PACKAGE (TOP VIEW) |  |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |
| A3 |  | B2 |
| A4 |  | B3 |
| VCC | ] 9 37[ | B4 |
| A5 | ] 10 36[ | $V_{C C}$ |
| A6 | ] 11 35[ | B5 |
| A7 | ] 12 34[ | B6 |
| A8 | ] 13 33[ | B7 |
| GND | ] 14 32[ | B8 |
| AF/AEA | 15131 [ | GND |
| HFA | $] 16$ 30[ | AF/AEB |
| LDCKA | 17 29 20П | HFB |
|  | $1819202122232425262728$ |  |
|  |  |  |

## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. The SN74ACT2235 is arranged as two 1024 by 9-bit FIFOs for high speed and fast access times. It processes data at rates from 0 to 50 MHz with access times of 25 ns in a bit-parallel format.

The SN74ACT2235 consists of bus transceiver circuits, two $1024 \times 9$ FIFOs, and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal FIFO memories. Enable GAB and GBA inputs are provided to control the transceiver functions. The SAB and SBA control inputs are provided to select whether real-time or stored data is transferred. The circuitry used for select control will eliminate the typical decoding glitch that occurs in a multiplexer during the transition between stored and real-time data. Eight fundamental bus-management functions can be performed as shown on the operating modes page.

## functional description

## bus lines (A0-A8, B0-B8)

Data inputs and outputs for 9-bit wide data.

## resets (RSTA, RSTB)

A reset is accomplished in each direction by taking reset (RSTA) and (RSTB) low. This sets the empty flags (EMPTYA and EMPTYB) and the half-full flags (HFA and HFB) low. The full flags (FULLA and FULLB) and the almost ful//almost empty flags (AF/AEA and AF/AEB) are set high. Both FIFOs must be reset upon power up.
load clocks (LDCKA, LDCKB)
Data on the A bus (AO-A8) is written into FIFO A on a low-to-high transition of load clock A (LDCKA). Data on the $B$ bus ( $B 0-B 8$ ) is written into FIFO $B$ on a low-to-high transition of load clock B (LDCKB). When the FIFOs are full, load clock signals have no effect on the data residing in memory.

## unload clocks (UNCKA, UNCKB)

Data in FIFO A is read to the B bus (BO-B8) on a low-to-high transition of unload clock $A$ (UNCKA). Data in FIFO $B$ is read to the $A$ bus (AO-A8) on a low-to-high transition of unload clock B(UNCKB). When the FIFOs are empty, unload clock signals have no effect on data residing in memory.

## output enables (GAB, GBA)

The output enables (GAB, GBA) control the transceiver functions. When GBA is low, the A bus (A0-A8) is in the high-impedance state. When GAB is low, the $B$ bus ( $B 0-B 8$ ) is in the high-impedance state.
select control Inputs (SAB, SBA)
The s-control inputs (SAB, SBA) select whether real-time or stored data is transferred. A low level selects reai-time data, and a high level selects stored data. Eight fundamental bus-management functions can be performed as shown on the operating modes page.

## define flag Inputs (DAF, DBF)

The high-to-low transition of define A flag (DAF) stores the binary value on the $A$ bus (A0-AB) as the almost full/almost empty offset value for FIFO A (X). The high-to-low transition of define B flag (DBF) stores the binary value of the $B$ bus (B0-B8) as the almost full/almost empty offset value for FIFO B ( Y ).
empty flags (EMPTYA, EMPTYB)
The empty flags (EMPTYA, EMPTYB) will be low when their corresponding memories are empty, and high when they are not empty.
full flags (FULLA, FULLB)
The full flags (FULLA, FULLB) will be low when their corresponding memories are full, and high when they are not full.

## half-full flags (HFA, HFB)

The haff-full flags (HFA and HFB) are high when their corresponding memories contain 512 or more words, and low when they contain 511 or less words.

## almost full/almost empty flags (AF/AEA, AF/AEB)

The almost full/almost empty A flag (AF/AEA) is defined by the almost full/almost empty offset value for FIFO A ( $)$. The AF/AEA flag is high when FIFO A contains $X$ or less words or 1024 minus $X$ words. The AF/AEA flag is low when FIFO A contains between $X$ plus 1 or 1023 minus $X$ words. The operation of the almost full/almost empty B flag (AF/AEB) is the same as AF/AEA for FIFO B.

## functional description (continued)

## programming procedure for AF/AEA

The almost full/almost empty flags (AF/AEA, AF/AEB) are programmed during each reset cycle. The almost full/almost empty offset value FIFO $A(X)$ and for FIFO B $(\mathrm{Y})$ are either a user-defined value or the default values of $\mathrm{X}=\mathbf{2 5 6}$ and $\mathrm{Y}=\mathbf{2 5 6}$. Below are instructions to program AF/AEA using both methods. AF/AEB is programmed in the same manner for FIFO B.

## user-defined $X$

Step 1. Take DAF from high to low. This stores AO thru A8 as X.
Step 2. If RSTA is not already low, take RSTA low.
Step 3. With DAF held low, take RSTA high. This defines the AF/AEA flag using X.
Step 4. To retain the current offset for the next reset, keep DAF low.

## default $\boldsymbol{X}$

To redefine the AF/AE flag using the default value of $\mathrm{X}=256$, hold DAF high during the reset cycle.

## logic symbol ${ }^{\dagger}$



[^18]logic diagram (positive logic)

operating modes

$\dagger$ Operation of FIFO B is identical to that of FIFO A
$\ddagger$ Last valid data stays on outputs when FIFO goes empty due to a read.

| SELECT-MODE CONTROL TABLE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| CONTROL |  | OPERATION |  |  |
| SAB | SBA | A BUS | B BUS |  |
| L | L | Real-time B to A bus | Real-time A to B bus |  |
| L | H | FIFO B to A bus | Real-time A to B bus |  |
| H | L | Real-time B to A bus | FIFO A to B bus |  |
| H | H | FIFO B to A bus | FIFO A to B bus |  |


| OUTPUT-ENABLE CONTROL TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| CONTROL |  | OPERATION |  |
| GAB | GBA | A BUS |  |
| H | H | A bus enabled |  |
| L | H | A bus enabled |  |
| H | L | Isolation/input to A bus |  |
| L | L | Isolation/input to B bus |  |
| B bus enabled |  |  |  |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$
Supply voltage range, $V_{C C}$ ..... -0.5 V to 7 V
Input voltage: Control inputs ..... 7 V
I/O ports ..... 5.5 V
Voltage applied to a disabled 3-state output ..... 5.5 V
Operating free-air temperature range ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Maximum junction temperature ..... $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

SCAS148A-D3568, DECEMBER 1990-REVISED APRIL 1991
recommended operating conditions

|  |  |  | 'ACT2235-20 |  | 'ACT2235-30 |  | 'АСТ2235-40 |  | 'ACT2235-60 |  | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{V}_{\text {cc }}$ | Supply voltage |  | 4.5 | 5.5 | 4.5 | 5.5 | 4.5 | 5.5 | 4.5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  | 2 |  | 2 |  | 2 |  | V |
| $V_{12}$ | Low-level input voltage |  |  | 0.8 |  | 0.8 |  | 0.8 |  | 0.8 | V |
| lOH | High-lovel output current | A or B ports |  | -8 |  | -8 |  | -8 |  | -8 | mA |
|  |  | Status flags |  | -8 |  | -8 |  | -8 |  | -8 |  |
| lol | Low-lovel output current | A or B ports |  | 16 |  | 16 |  | 16 |  | 16 | mA |
|  |  | Status flags |  | 8 |  | 8 |  | 8 |  | 8 |  |
| fflock | Clock frequency | LDCKA or LDCKB |  | 50 |  | 33 |  | 25 |  | 16.7 | MHz |
|  |  | UNCKA or UNCKB |  | 50 |  | 33 |  | 25 |  | 16.7 |  |
| tw | Pulse duration | RSTA or RSTB low | 20 |  | 20 |  | 25 |  | 25 |  | ns |
|  |  | LDCKA or LDCKB low | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | LDCKA or LDCKB high | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | UNCKA or UNCKB low | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | UNCKA or UNCKB high | 8 |  | 10 |  | 14 |  | 20 |  |  |
|  |  | DAF or DEF high | 10 |  | 10 |  | 10 |  | 10 |  |  |
| ${ }_{\text {tsu }}$ | Setup time | Data before LDCKA or LDCKB $\dagger$ | 4 |  | 4 |  | 5 |  | 5 |  | ns |
|  |  | Define AF/AE: D0-D8 before DAF or DBF $\downarrow$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
|  |  | Define AF/AE: DAF or DBF , before RSTA or RSTB $\dagger$ | 7 |  | 7 |  | 7 |  | 7 |  |  |
|  |  | Defino AF/AE (default): DAF or DBF high before RSTA or RSTB $\dagger$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
|  |  | RSTA or RSTB inactivo (high) before LDCKA or LDCKB $\dagger$ | 5 |  | 5 |  | 5 |  | 5 |  |  |
| $\psi_{h}$ | Hold time | Data after LDCKA or LDCKB $\dagger$ | 1 |  | 1 |  | 2 |  | 2 |  | ns |
|  |  | Define AF/AE: D0-D8 after DAF or DBF $\downarrow$ | 0 |  | 0 |  | 0 |  | 0 |  |  |
|  |  | Dofine AF/AE: DAF or DBF low after RSTA or RSTB $\dagger$ | 0 |  | 0 |  | 0 |  | 0 |  |  |
|  |  | Define AF/AE (default): DAF or DBF high after RSTA or RSTB $\dagger$ | 0. |  | 0 |  | 0 |  | 0 |  |  |
| $\mathrm{T}_{A}$ | Operating free-air tomperature |  | 0 | 70 | 0 | 70 | 0 | 70 | 0 | 70 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDMONS |  | MIN | TYP ${ }^{\dagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VOH |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| VOL | Flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{LL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | I/O ports | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{lcc}^{\ddagger}$ |  | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}-0.2 \mathrm{~V}$ or 0 |  |  | 10 | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{CCC}^{\text {s }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | PF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ Icc tested with outputs open.
${ }^{\$}$ This is the supply current when each input is at one of the specified TTL voltage levels rather than $O \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$.
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 1 and 2)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | 'ACT2235-20 |  |  | 'ACT2235-30 |  | 'ACT2235-40 |  | 'ACT2235-60 |  | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  | 50 |  |  | 33 |  | 25 |  | 16.7 |  | MHz |
|  | UNCK |  | 50 |  |  | 33 |  | 25 |  | 16.7 |  |  |
| $t_{\text {pd }}$ | LDCK $\dagger$, LDCKB $\uparrow$ | B or A | 8 |  | 22 | 8 | 22 | 8 | 24 | 8 | 26 | ns |
| $t_{p d}$ | UNCKA $\uparrow$, UNCKB $\dagger$ | B or A | 12 | 17 | 25 | 12 | 25 | 12 | 35 | 12 | 45 | ns |
| tply | LDCK $\dagger$, LDCKB $\dagger$ | $\begin{aligned} & \hline \text { EMPTYA, } \\ & \text { EMPTYB } \end{aligned}$ | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| $t_{\text {PHL }}$ | UNCKA ${ }^{\text {, }}$ UNCKB $\dagger$ | EMPTYA, EMPTYB | 2 |  | 17 | 2 | 17 | 2 | 19 | 2 | 21 | ns |
| $t_{\text {PHL }}$ | RSTA $\downarrow$, RSTE $\downarrow$ | EMPTYA, EMPTYB | 2 |  | 18 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| truL | LDCK ${ }^{\text {, LDCKB } \uparrow}$ | FULLA, FULLE | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| trin | UNCKAT, UNCKB $\uparrow$ | FULLA, FULLE | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| ${ }_{\text {tPLH }}$ | RSTÃ ${ }^{\text {d }}$, RSTB $\downarrow$ | FULLA, FULLE | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| ${ }_{\text {¢ }}^{\text {LLH }}$ | RSTA $\downarrow$, RSTB $\downarrow$ | AF/AEA, AF/AEB | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| ${ }_{\text {¢ }}^{\text {LH }}$ | LDCK $\uparrow$, LDCKB $\dagger$ | HFA, HFB | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| $t_{\text {PHL }}$ | UNCKA $\uparrow$, UNCKB $\dagger$ | HFA, HFB | 4 |  | 18 | 4 | 18 | 4 | 20 | 4 | 22 | ns |
| $\mathrm{t}_{\mathrm{PHL}}$ | RSTA $\downarrow$, RSTB! | HFA, HFB | 1 |  | 15 | 1 | 15 | 1 | 17 | 1 | 19 | ns |
| $t_{\text {pd }}$ | SAB or SBA ${ }^{\text {d }}$ | Bor A | 1 |  | 11 | 1 | 11 | 1 | 12 | 1 | 14 | ns |
| $t_{\text {pd }}$ | A or B | B or A | 1 |  | 11 | 1 | 11 | 1 | 12 | 1 | 14 | ns |
| $t_{\text {pd }}$ | LDCK $\dagger$, LDCKB $\dagger$ | AF/AEA, AF/AEB | 2 |  | 18 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| $t_{\text {pd }}$ | UNCKA UNCKB $\dagger$ | AF/AEA, AF/AEB | 2 |  | 18 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| $t_{\text {en }}$ | GBA or GAB | A or B | 2 |  | 11 | 2 | 11 | 2 | 13 | 2 | 15 | ns |
| $t_{\text {dis }}$ | GBA or GAB | A or B | 1 |  | 9 | 1 | 9 | 1 | 11 | 1 | 13 | ns |

[^19]operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  |  | TEST CONDITIONS |  | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{pd}}$ | Power dissipation capacitance per 1 Kbits | Outputs enabled | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$, | $\mathrm{f}=5 \mathrm{MHz}$ | 71 | pF |
|  |  | Outputs disabled |  |  | 57 |  |

PARAMETER MEASUREMENT INFORMATION


LOAD CIRCUTT
TOTEM-POLE OUTPUTS
Flgure 1. Standard CMOS Outputs (All Flags)


| PARAMETER |  | $\mathrm{R}_{\mathrm{L}}$ | $C_{L}{ }^{+}$ | S1 | S2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ten | $\mathrm{t}_{\text {PZH }}$ | 500 Q | 50 pF | Open | Closed |
|  | tpz |  |  | Closed | Open |
| $t_{\text {dis }}$ | $t_{\text {PHz }}$ | 500 \& | 50 pF | Open | Closed |
|  | tPLz |  |  | Closed | Open |
| $\mathrm{t}_{\text {od }}$ or $\mathrm{t}_{4}$ |  | - | 50 pF | Open | Open |

$\dagger$ Includes probe and test fixture capacitance.
Flgure 2. 3-State Outputs (A0-A8, B0-B8)

## TYPICAL CHARACTERISTICS

PROPAGATION DELAY TIME
LOAD CAPACITANCE


Figure 3


Flgure 4

## 1024 X 9 X 2 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

## calculating power dissipation

With IccF taken from Figure 4, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[I_{C C F}+\left(N \times \Delta l_{C C} \times d C\right)\right]+\Sigma\left(C_{L} \times V_{C C}{ }^{2} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+\left(N \times \Delta l_{c c} \times d c\right)\right]+\Sigma\left(C_{p d} \times V_{c c}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c}^{2} \times f o\right)
$$

$\mathrm{I}_{\mathrm{cc}}=$ power-down Icc maximum
$N=$ number of inputs driven by a TTL device
$\Delta I_{\text {CC }}=$ increase in supply current
$\mathrm{dc}=$ duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\text {pd }}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$f_{i}=$ data input frequency
$\mathrm{f}_{0}=$ data output frequency
－Independent Asynchronous Inputs and Outputs
－Low－Power Advanced CMOS Technology
－Bldirectional
－ 1024 Words by 9 BIts Each
－Programmable Almost Full／Almost Empty Flag
－Empty，Full，and Halt－Full Flags
－Access TImes of 25 ns With a 50－pF Load
－Data Rates From 0 to 50 MHz
－Fall－Through Times of $\mathbf{2 3} \mathbf{n s}$ Max
－High Output Drlve for Dlrect Bus Interface
－3－State Outputs

|  | FN PACKAGE （TOP VIEW） |  |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |
| A3 |  | B2 |
| A4 | 8 边 | B3 |
| $V_{\text {cc }}$ | 9 行 | B4 |
| A5 |  | Vcc |
| A6 | 11 35［ | B5 |
| A7 | 12 近 | B6 |
| A8 |  | B7 |
| GND | 714 － 32 ［ | B8 |
| AF／AEA | 15 行 | GND |
| HFA | 1616 | AF／AEB |
| LDCKA | 17 29 20 | HFB |
|  | 1819202122232425262728 |  |
|  |  |  |

## description

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates．The SN74ACT2236 is arranged as two 1024 by 9 －bit FIFOs for high speed and fast access times． It processes data at rates from 0 to 50 MHz with access times of 25 ns in a bit－parallel format．
The SN74ACT2236 consists of bus transceiver circuits，two $1024 \times 9$ FIFOs，and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal FIFO memories．Enable OE and DIR inputs are provided to control the transceiver functions．The SAB and SBA control inputs are provided to select whether real－time or stored data is transferred．The circuitry used for select control will eliminate the typical decoding glitch that occurs in a multiplexer during the transition between stored and real－time data．Five fundamental bus－management functions can be performed as shown on the operating modes page．

## functional description

bus lines (A0-A8, BO-B8)
Data inputs and outputs for 9-bit wide data.

## resets (RSTA, RSTB)

A reset is accomplished in each direction by taking reset (RSTA) and (RSTB) low. This sets the empty flags (EMPTYA and EMPTYB) and the half-full flags (HFA and HFB) low. The full flags (FULLA and FULLB) and the almost full/almost empty flags (AF/AEA and AF/AEB) are set high. Both FIFOs must be reset upon power up.

## load clocks (LDCKA, LDCKB)

Data on the $A$ bus (A0-A8) is written into FIFO A on a low-to-high transition of load clock A (LDCKA). Data on the $B$ bus ( $B 0-B 8$ ) is written into FIFO $B$ on a low-to-high transition of load clock B (LDCKB). When the FIFOs are full, load clock signals have no effect on the data residing in memory.

## unload clocks (UNCKA, UNCKB)

Data in FIFO $A$ is read to the $B$ bus ( $B 0-B 8$ ) on a low-to-high transition of unload clock $A$ (UNCKA). Data in FIFO $B$ is read to the $A$ bus (AO-A8) on a low-to-high transition of unload clock $B$ (UNCKB). When the FIFOs are empty, unload clock signals have no effect on data residing in memory.
enable Inputs ( $\mathrm{OE}, \mathrm{DIR}$ )
The enable inputs control the transceiver functions. When $\overline{\mathrm{E}}$ is high, both buses ( $\mathrm{A} 0-\mathrm{AB}, \mathrm{BO}-\mathrm{B} 8$ ) are in the high-impedance state and may be used as inputs. With $\bar{O}$ low and DIR high, the $A$ bus is in the high-impedance state and $B$ bus is active. When both $\bar{O}$ and DIR are low, the $A$ bus is active and the $B$ bus is in the high-impedance state.
select control Inputs (SAB, SBA)
The select control inputs (SAB, SBA) select whether real-time or stored data is transferred. A low level selects real-time data, and a high level selects stored data. Five fundamental bus-management functions can be performed as shown on the operating modes page.
define flag inputs (DAF, DBF)
The high-to-low transition of define A flag (DAF) stores the binary value on the A bus (A0-A8) as the almost full/almost empty offset value for FIFO A (X). The high-to-low transition of define B flag (DBF) stores the binary value of the $B$ bus (B0-B8) as the almost full/almost empty offset value for FIFO B ( Y ).
empty flags (EMPTYA, EMPTYB)
The empty flags (EMPTYA, EMPTYB) will be low when their corresponding memories are empty, and high when they are not empty.
full flags (FULLA, FOLLE)
The full flags (FULLA, FULLE) will be low when their corresponding memories are full, and high when they are not full.
half-full flags (HFA, HFB)
The half-full flags (HFA and HFB) are high when their corresponding memories contain 512 or more words, and low when they contain 511 or less words.

## almost full/almost empty flags (AF/AEA, AF/AEB)

The almost full/almost empty A flag (AF/AEA) is defined by the almost full/almost empty offset value for FIFO A (X). The AF/AEA flag is high when FIFO A contains $X$ or less words or 1024 minus $X$ words. The AF/AEA flag is low when FIFO A contains between $X$ plus 1 or 1023 minus $X$ words. The operation of the almost full/almost empty B flag (AF/AEB) is the same as AF/AEA for FIFO B.

## functional description (continued)

## programming procedure for AF/AEA

The almost full/almost empty flags (AF/AEA, AF/AEB) are programmed during each reset cycle. The almost full/almost empty offset value FIFO $A(X)$ and for FIFO B $(Y)$ are either a user-defined value or the default values of $\mathrm{X}=\mathbf{2 5 6}$ and $\mathrm{Y}=256$. Below are instructions to program AF/AEA using both methods. AF/AEB is programmed in the same manner for FIFO B.

## user-defined $X$

Step 1. Take DAF from high to low. This stores AO thru A8 as $X$.
Step 2. If RSTA is not already low, take RSTA high.
Step 3. With DAF held low, take RSTA high. This defines the AF/AEA flag using $X$.
Step 4. To retain the current offset for the next reset, keep DAF low.

## default $\boldsymbol{X}$

To redefine the AF/AE flag using the default value of $X=256$, hold DAF high during the reset cycle.

## logic symbol ${ }^{\dagger}$



[^20]
## SN74ACT2236 <br> 1024 X 9 X 2 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

SCAS149-D3489, APRIL 1990-REVISED DECEMBER 1990
logic diagram (positive logic)

operating modes



SELECT-MODE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| SAB | SBA | A BUS | B BUS |
| L | L | Real-time B to A bus | Real-time A to B bus |
| L | H | FIFO B to A bus | Real-time A to B bus |
| H | L | Real-time B to A bus | FIFO A to B bus |
| H | H | FIFO B to A bus | FIFO A to B bus |

OUTPUT-ENABLE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| DIR | OE | A BUS | B BUS |
| X | H | Input | Input |
| L | L | Output | Input |
| H | L | Input | Output |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

Input voltage: Control inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 F
I/O ports ........................................................................... 5.5 V
Voltage applied to a disabled 3 -state output ............................................................... 5.5 V
Operating free-air temperature range $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . ..................................................................... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Maximum junction temperature.................................................................. $.150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

SCAS149-D3489, APRIL 1990-REVISED DECEMBER 1990
recommended operating conditions

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | Flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | I/O ports | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| $I_{1}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $V_{1}=V_{C C}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lcc ${ }^{\ddagger}$ |  | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}-0.2 \mathrm{~V}$ or 0 |  |  | 10 | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcc}^{5}$ | DIR, $\overline{O E}$ | $V_{C C}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 2 | mA |
|  | Other inputs |  |  |  |  | 1 |  |
| $\mathrm{C}_{i}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 8 |  | pF |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger I_{c c}$ tested with outputs open.
$\S$ This is the supply current when each input is at one of the specified TTL voltage levels rather than 0 V or $V_{c c}$.
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figures 1 and 2)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | 'ACT2236-20 |  |  | 'ACT2236-30 |  | 'ACT2236-40 |  | 'ACT2236-60 |  | UNT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYPt ${ }^{\text {t }}$ | MAX | Min | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  | 50 |  |  | 33 |  | 25 |  | 16.7 |  | MHz |
|  | UNCK |  | 50 |  |  | 33 |  | 25 |  | 16.7 |  |  |
| $t_{\text {pd }}$ | LDCK ${ }^{\text {, LDCKB } \dagger}$ | B or A | 8 |  | 23 | 8 | 23 | 8 | 25 | 8 | 27 | ns |
| $t_{\text {pd }}$ | UNCKA ${ }^{\text {a }}$ UNCKB $\dagger$ | B or A | 10 | 17 | 25 | 10 | 25 | 10 | 35 | 10 | 45 | ns |
| tPLH | LDCKı, LDCKB $\uparrow$ | EMPTYA, EMPTYB | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| 4 PHL | UNCKA $\uparrow$, UNCKB ${ }^{+}$ | EMPTYA, EMPTYB | 2 |  | 17 | 2 | 17 | 2 | 19 | 2 | 21 | ns |
| $t_{\text {PHL }}$ | RSTA $\downarrow$, RSTE $\downarrow$ | EMPTYA, EMPTYB | 2 |  | 18 | 2 | 18 | 2 | 20 | 2 | 22 | ns |
| tpHL | LDCK $\uparrow$, LDCKB $\dagger$ | FULLA, FULLE | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| tply | UNCKAT, UNCKB $\uparrow$ | FULLA, FULLE | 4 |  | 15 | 4 | 15 | 4 | 17 | 4 | 19 | ns |
| $\mathrm{t}_{\mathrm{L} \text { LH }}$ | RSTA $\downarrow$, RSTE $\downarrow$ | FULLA, FULLE | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| tpLH | RSTA $\downarrow$, RSTE $\downarrow$ | AF/AEA, AF/AEB | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| tpLH | LDCK $\dagger$, LDCKB $\dagger$ | HFA, HFB | 2 |  | 15 | 2 | 15 | 2 | 17 | 2 | 19 | ns |
| ${ }_{\text {tPHL }}$ | UNCKAt. UNCKB $\uparrow$ | HFA, HFB | 4 |  | 19 | 4 | 19 | 4 | 21 | 4 | 23 | ns |
| ${ }_{\text {PPHL }}$ | RSTA $\downarrow$, RSTE $\downarrow$ | HFA, HFB | 1 |  | 15 | 1 | 15 | 1 | 17 | 1 | 19 | ns |
| $t_{\text {pd }}$ | SAB or SBA ${ }^{\text { }}$ | B or A | 1 |  | 11 | 1 | 11 | 1 | 13 | 1 | 15 | ns |
| $t_{\text {pd }}$ | A or B | B or A | 1 |  | 11 | 1 | 11 | 1 | 13 | 1 | 15 | ns |
| $t_{\text {pd }}$ | LDCK $\uparrow$, LDCKB $\dagger$ | AF/AEA, AF/AEB | 2 |  | 19 | 2 | 19 | 2 | 21 | 2 | 23 | ns |
| $t_{\text {pd }}$ | UNCKA $\dagger$, UNCKB $\uparrow$ | AF/AEA, AF/AEB | 2 |  | 19 | 2 | 19 | 2 | 23 | 2 | 23 | ns |
| ten | DIR, $\overline{\text { E }}$ | A or B | 2 |  | 12 | 2 | 12 | 2 | 14 | 2 | 16 | ns |
| $t_{\text {dis }}$ | DIR, $\overline{\text { OE }}$ | A or B | 1 |  | 10 | 1 | 10 | 1 | 12 | 1 | 14 | ns |

[^21]
## 1024 X 9 X 2 ASYNCHRONOUS FIRST-IN, FIRST-OUT MEMORY

operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$

| PARAMETER |  |  | TEST CONDITIONS |  | TYP | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{pd}}$ | Power dissipation capacitance per 1 Kbits | Outputs enabled | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$, | $\mathrm{f}=5 \mathrm{MHz}$ | 71 |  |
|  |  | Outputs disabled |  |  | 57 | pF |

PARAMETER MEASUREMENT INFORMATION


Figure 1. Standard CMOS Outputs (All Flags)


| PARAMETER |  | $\mathbf{R}_{\mathrm{L}}$ | $\mathrm{C}_{\mathrm{L}}{ }^{\text {t }}$ | S1 | S2 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ten | $\mathrm{t}_{\text {PZH }}$ | 500 ¢ | 50 pF | Open | Closed |
|  | tpz |  |  | Closed | Open |
| $\mathrm{t}_{\text {dis }}$ | tPHz | $500 \Omega$ | 50 pF | Open | Closed |
|  | trLZ |  |  | Closed | Open |
| tod or ${ }^{\text {a }}$ |  | - | 50 pF | Open | Open |

$t$ Includes probe and test fixture capacitance.
Figure 2. 3-State Outputs (A0-A8, B0-B8)


Flgure 3

POWER DISSIPATION CAPACITANCE
V
SUPPLY VOLTAGE


Flgure 4

## calculating power dissipation

With ICCF taken from Figure 4, the maximum power dissipation based on all data outputs changing states on each read may be calculated using:

$$
P_{t}=V_{C C} \times\left[l_{C C F}+\left(N \times \Delta l_{C C} \times d c\right)\right]+\Sigma\left(C_{L} \times V_{C C} \times f 0\right)
$$

A more accurate power calculation based on device use and average number of data outputs switching can be found using:

$$
P_{t}=V_{c c} \times\left[l_{c c}+(N \times \Delta l c c \times d c)\right]+\Sigma\left(C_{p d} \times V_{c c^{2}}^{2} \times f i\right)+\Sigma\left(C_{L} \times V_{c c}{ }^{2} \times f o\right)
$$

$\mathrm{I}_{\mathrm{Cc}}=$ power-down Icc maximum
$\mathrm{N}=$ number of inputs driven by a TTL device
$\Delta \mathrm{I}_{\mathrm{CC}}=$ increase in supply current
dc = duty cycle of inputs at a TTL high level of 3.4 V
$\mathrm{C}_{\mathrm{pd}}=$ power dissipation capacitance
$C_{L}=$ output capacitive load
$\mathrm{f}_{\mathrm{i}}=$ data input frequency
$\mathrm{f}_{0}=$ data output frequency

- Independent Asychronous Inputs and Outputs
- Bldirectlonal
- 32 Words by 9 Blts Each
- Programmable Depth
- Data Rates from 0 to $\mathbf{4 0} \mathbf{~ M H z}$
- Fall-Through Time ... 22 ns Typ
- 3-State Outputs


## description

This 576-bit memory uses Advanced Low-Power Schottky IMPACT-X ${ }^{\text {w }}$ technology and features high speed and fast fall-through times. It consists of two FIFOs organized as 32 words by 9 bits each.

A FIFO memory is a storage device that allows data to be written into and read from its array at independent data rates. These FIFOs are designed to process data at rates from 0 to 40 MHz in a bit-parallel format, word by word.

The SN74ALS2238 consists of bus transceiver circuits, two $32 \times 9$ FIFOs, and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal FIFO memories. Enables GAB and GBA are provided to control the transceiver functions. The SAB and SBA control pins are provided to select whether real-time or stored data is transferred. The circuitry used for select control eliminates the typical decoding glitch that occurs in a multiplexer during the transition between stored and real-time data. A low level selects real-time data and a high selects stored data. Eight fundamental bus-management functions can be performed as shown on the operating modes page.
Data on the $A$ or $B$ data bus, or both, is written into the FIFOs on a low-to-high transition at the load clock input (LDCKA or LDCKB) and is read out on a low-to-high transition at the unload clock input (UNCKA or UNCKB). The memory is full when the number of words clocked in exceeds, by the defined depth, the number of words clocked out.

When the memory is full, LDCK signals have no effect on the data residing in memory. When the memory is empty, UNCK signals have no effect.
N PACKAGE
(TOP VEW)

| RSTA 1 |  | ] RSTB |
| :---: | :---: | :---: |
| DAF [ 2 | 39 | DBF |
| A0 3 | 38 | 1 BO |
| A1 [ 4 | 37 | 1 B1 |
| A2 [ 5 | 36 | ] B2 |
| GND 6 | 35 | $]$ GND |
| A3 7 | 34 | B3 |
| A4 [ 8 | 33 | B4 |
| A5 9 | 32 | B5 |
| A6 10 | 31 | ] B6 |
| GND 11 | 30 | GND |
| $V_{C C} 12$ | 29 | $] \mathrm{V}_{\mathrm{cc}}$ |
| A7 13 | 28 | $] \mathrm{B7}$ |
| A8 [ 14 | 27 | B8 |
| LDCKA 15 | 26 | LDCKB |
| FULLA [16 | 25 | 1 FULLB |
| UNCKB 17 | 24 | $]$ UNCKA |
| EMPTYE 18 | 23 | EMPTYA |
| SAB 19 | 22 | SBA |
| GAB 20 | 21 | GBA |

FN PACKAGE
(TOP VIEW)


## description (continued)

Status of the FIFO memories is monitored by the FULLA, FULLEB, EMPTYA, and EMPTYB output flags. The FULLA and FULLE are definable full flags. A high-to-low transition on DAF stores the binary value of A0 through A4 into a register for use as the value of $X$. A high-to-low transition on DBF stores the binary value of BO through B4 into a register for use as the value of Y . In this way, the depth of either FIFO can be defined to be one to thity-two words deep. The value of $X$ and $Y$ must be defined after power up or the stored value of $X$ and $Y$ will be ambiguous. The FULLA and FULLB outputs are low when their corresponding memories are full and high when the memories are not full.

The EMPTYA and EMPTYB outputs are low when their corresponding memories are empty and high when they are not empty. The status flag outputs are always active.

A low-level pulse on the RSTA or RSTB inputs resets the control pointers on FIFO A or FIFO B and also sets EMPTYA low and FULLX high or EMPTYB low and FULLE high. The outputs are not reset to any specific logic levels. With DAF at a low level, a low-level pulse on RSTA sets FIFO A to a depth of 32 minus $X$, where $X$ is the value stored above. With DAF at a high level, a low level pulse on RSTA sets FIFO A to a depth of 32 words. The depth of FIFO B is set in a similar manner. The first low-to-high transition on LDCKA or LDCKB, either after a reset pulse or from an empty condition, will cause EMMPTYA or EMPTYB to go high and the data to appear on the Q outputs. It is important to note that the first word does not have to be unloaded. Cascading is easily accomplished in the word-width direction, but is not possible in the word-depth direction.

## logic symbol ${ }^{\dagger}$


${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984.
Pin numbers shown are for the $N$ package.
logic diagram (positive logic)


## operating modes


timing diagram
FFO 'A' OPERATION ${ }^{\dagger}$

$\dagger$ Operation of FIFO B is the same as shown above.
$\ddagger \times$ includes A0 through A4 only. A5 through A8 are ignored.

SELECT-MODE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| SAB | SBA | A BUS | B BUS |
| L | L | Real-time $B$ to $A$ bus | Real-time $A$ to $B$ bus |
| L | H | FIFO $B$ to $A$ bus | Real-time $A$ to $B$ bus |
| H | L | Real-time $B$ to $A$ bus | FIFO $A$ to $B$ bus |
| H | H | FIFO B to $A$ bus | FIFO $A$ to $B$ bus |

OUTPUT-ENABLE CONTROL TABLE

| CONTROL |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| GAB | GBA | A BUS | B BUS |
| H | H | A bus enabled | B bus enabled |
| L | H | A bus enabled | Isolation/input to B bus |
| H | L | Isolation/input to A bus | B bus enabled |
| L | L | Isolation/input to $A$ bus | Isolation/input to B bus |

programming procedure for depth of FIFO A ${ }^{\dagger}$
Program:
Step 1. With RSTA at a high level, take DAF from a high level to a low level. The high-to-low transition on DAF stores the binary value of A0-A4 for use as the value of ' $X$ ' in defining the depth of FIFO A.
Step 2. With DAF held low, pulse the RSTA signal low. On the low-to-high transition of RSTA, FIFO A is set to a depth of 32 minus ' X ', where X is the value of A0-A4 stored above.

Step 3. To redefine the depth of FIFO A to 32 words, hold DAF at a high level and pulse the RSTA signal low.
${ }^{\dagger}$ The programming procedures used to define the depth of FIFO B are the same as the procedure above.

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\boldsymbol{\ddagger}}$

$\qquad$
Input voltage: Control inputs .............................................................................. 7 V
I/O ports ............................................................................. 5.5 V
Voltage applied to a diabled 3 -state output ................................................................. 5.5 V
Operating free-air temperature range ............................................................... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

Maximum junction temperature................................................................. $.150^{\circ} \mathrm{C}$
$\ddagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.
recommended operating conditions (see Note 1)

|  |  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 | V |
| loh | High-level output current | A or B ports |  |  | -15 | mA |
|  |  | Status flags |  |  | -0.4 |  |
| lob | Low-level output current | A or B ports |  |  | 24 | mA |
|  |  | Status flags |  |  | 8 |  |
| $t_{\text {clock }}$ | Clock frequency | LDCKA or LDCKB | 0 |  | 40 | MHz |
|  |  | UNCKA or UNCKB | 0 |  | 40 |  |
| tw | Pulse duration | RSTA or RSTB low | 17 |  |  | ns |
|  |  | LDCKA or LDCKB low | 12.5 |  |  |  |
|  |  | LDCKA or LDCKB high | 10 |  |  |  |
|  |  | UNCKA or UNCKB low | 12.5 |  |  |  |
|  |  | UNCKA or UNCKB high | 10 |  |  |  |
|  |  | DAF or DBF high | 10 |  |  |  |
| $t_{\text {su }}$ | Setup time | Data before LDCKA or LDCKB $\dagger$ | 7 |  |  | ns |
|  |  | Define depth: D4-D0 before DAF or DBF $\downarrow$ | 6 |  |  |  |
|  |  | Define depth: DAF or DBF $\downarrow$ before RSTA or RSTB $\uparrow$ | 45 |  |  |  |
|  |  | Define depth (32): DAF or DBF high before RSTA or RSTB $\uparrow$ | 32 |  |  |  |
|  |  | LDCKA or LDCKB (inactive) before RSTA or RSTB $\uparrow$ | 5 |  |  |  |
| th | Hold time | Data after LDCKA or LDCKB $\uparrow$ | 3 |  |  | ns |
|  |  | Define depth: D4-D0 after DAF or DBF $\downarrow$ | 4 |  |  |  |
|  |  | Define depth: DAF or DBF low after RSTA or RSTB $\dagger$ | 0 |  |  |  |
|  |  | Define depth (32): DAF or DBF high after RSTA or RSTB $\uparrow$ | 0 |  |  |  |
|  |  | LDCKA or LDCKB (inactive) after RSTA or RSTB $\uparrow$ | 5 |  |  |  |
|  | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 1: To ensure proper operation of this high-speed FIFO device, it is necessary to provide a clean signal to the LDCKA or LDCKB and UNCKA or UNCKB clock inputs. Any excessive noise or glitching on the clock inputs (which violates the $\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IH}}$, or minimum pulse duration limits) can cause a false clock or improper operation of the internal read and write pointers.

## SN74ALS2238

## 32 X 9 X 2 ASYNCHRONOUS BIDIRECTIONAL

 FIRST-IN, FIRST-OUT MEMORYD3501, APRIL 1990
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITONS |  | MIN | TYPt | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IK}}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| V OH | Status flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | A or B ports | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOH}^{\text {}}=-15 \mathrm{~mA}$ | 2 |  |  |  |
| VoL | A or B ports | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{2}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | Status flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{l} \mathrm{OLL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| 1 | DAF, DBF, RSTA, RSTB, GAB, GBA, SAB, SBA, LDCKA, LDCKB, UNCKA, UNCKB | $V_{C C}=5.5 \mathrm{~V}$, | $V_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
|  | A or B ports |  |  |  |  | 0.2 |  |
| $\mathrm{I}_{\mathrm{H}}$ | DAF, DBF, RSTA, RSTB, GAB, GBA, SAB, SBA, LDCKA, LDCKB, UNCKA, UNCKB | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports ${ }^{\ddagger}$ |  |  |  |  | 40 |  |
| HL | DAF, DBF, RSTA, RSTB, GAB, GBA, SAB, SBA, LCKA, LDCKB, UNCKA, UNCKB | $V_{C C}=5.5 \mathrm{~V}$, | $V_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 | mA |
|  | A or B ports ${ }^{\ddagger}$ |  |  |  |  | -0.4 |  |
| $10^{5}$ | A or B ports ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -20 |  | -130 | mA |
|  | Status flags |  |  | -15 |  | -100 |  |
| Icc |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |  |  | 190 | 350 | mA |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ For I/O ports, the parameters $\mathrm{I}_{\mathrm{IH}}$ and $\mathrm{I}_{\mathrm{IL}}$ include the offstate output current.
${ }^{\delta}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.
switching characteristics (see Note 2)

| PARABIETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \mathrm{\Omega}, \\ & \mathrm{R} 2=500 \mathrm{\Omega}, \\ & \mathrm{~T}_{\mathrm{A}}=\operatorname{BIN} \text { to } \operatorname{HAX} \end{aligned}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $t_{\text {max }}$ | LDCK, UNCK |  | 40 |  |  | MHz |
| $t_{p d}$ | LDCKA $\uparrow$, LDCKB $\dagger$ | B/A | 7 | 22 | 33 | ns |
|  | UNCKA $\uparrow$, UNCKB $\dagger$ |  | 7 | 20 | 29 |  |
| tplH | LDCKA $\uparrow$, LDCKB $\dagger$ | EMPTYA, EMPTYB | 5 | 12 | 22 | ns |
| $\mathrm{t}_{\mathrm{HL}}$ | UNCKA $\uparrow$, UNCKB $\dagger$ |  | 5 | 12 | 22 |  |
| $\mathrm{t}_{\mathrm{HHL}}$ | RSTA $\downarrow$, RSTB $\downarrow$ | EMPTYA, EMPTYB | 5 | 12 | 22 | ns |
| ${ }_{\text {¢ }}^{\text {HL }}$ | LDCKA $\uparrow$, LDCKB $\dagger$ | FULLA, FULLE | 5 | 12 | 22 | ns |
| ${ }_{\text {tplu }}$ | UNCKA $\uparrow$, UNCKB $\uparrow$ | FULLA, FULLE | 5 | 12 | 23 | ns |
|  | RSTA $\downarrow$, RSTE $\downarrow$ |  | 6 | 15 | 28 |  |
| $t_{\text {pd }}$ | SAB/SBA ${ }^{\ddagger}$ | B/A | 2 | 11 | 18 | ns |
|  | A/B |  | 2 | 8 | 15 |  |
| $t_{\text {en }}$ | GBA/GAB | A/B | 2 | 6 | 15 | ns |
| $t_{\text {dis }}$ | GBA/GAB | A/B | 1 | 5 | 12 | ns |

[^22]
## Unidirectional Clocked FiFOs



Bidirectional Clocked FIFOs:

Bidirectional Firos

Product Previews

Articles and Application Notes
2

Mechanical Data

## 64 X 36 X 2 CLOCKED FIRST-IN, FIRST-OUT MAEMORY WITH BUS MATCHING AND BYTE SWAPPING <br> SCBS126-JUNE 1992

- Free-Running CLKA and CLKB May Be Asynchronous or Coincident
- Two Independent $64 \times 36$ Clocked FIFOs Buffering Data In Opposite Directions
- Mallbox Bypass Reglster for Each FIFO
- Dynamic Port B Bus SIzing of 36 Bits (Long Word), 18 Blts (Word), and 9 Blts (Byte)
- Selection of Blg- or Little-Endian Format for Word and Byte Bus Sizes
- Three Modes of Byte Order Swapping on Port B
- Almost Full and Almost Empty Flags
- Microprocessor Interface Control Logic
- EFA, FFA, AEA, and AFA Flags Synchronized by CLKA
- EFB, FFB, $\overline{A E B}$, and $\overline{A F B}$ Flags Synchronized by CLKB
- Passive Parity CheckIng on Each Port
- Parlty Generation Can Be Selected for Each Port
- Low-Power Advanced BICMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Tlmes of 10 ns
- Avallable In 132-Pin Quad Flatpack (PQ) or Space-Saving 120-Pin Shrink Quad Flatpack (PCB)


## description

The SN74ABT7815 is a high-speed, low-power BiCMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 10 ns . Two independent $64 \times 36$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. Each FIFO has flags to indicate empty and full conditions and two programmable flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. FIFO data on port B may be input and output in 36 -bit, 18 -bit, and 9 -bit formats with a choice of big- or little-endian configurations. Three modes of byte order swapping are possible with any bus size selection. Communication between each port may bypass the FIFOs via two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if not desired. Parity generation can be selected for data read from each port.
The SN74ABT7815 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses controlled by a synchronous interface.
The full flag and almost full flag of a FIFO are two-stage synchronized to the port clock that writes data to its array. The empty flag and almost empty flag of a FIFO are two-stage synchronized to the port clock that reads data from its array.

PCB PACKAGE (TOP VEW)


## functional block diagram



Terminal Functions

| PIN NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A35 | 1/0 | Port A data. 36-bit bidirectional data port for side A. |
| AEA | 0 | FIFO2 almost empty flag. $\overline{A E A}$ is synchronous to CLKA and is low when the number of 36 -bit long words in FIFO2 is less than or equal to the selected offset value. |
| AEB | 0 | FIFO1 almost empty flag. $\overline{A E B}$ is synchronous to CLKB and is low when the number of 36 -bit long words in FIFO1 is less than or equal to the selected offiset value. |
| AFA | 0 | FIFO1 almost full flag. AFA is synchronous to CLKA and is low when the number of 36 -bit empty locations in FIFO1 is less than or equal to the selected offset value. |
| AFB | 0 | FIFO2 almost full flag. $\overline{A F B}$ is synchronous to CLKB and is low when the number of 36 -bit empty locations in FIFO2 is less than or equal to the selected offset value. |
| B0-B35 | 1/0 | Port B data. 36 -bit bidirectional data port for side B. |
| BE | 1 | Big-endian select. Selects the bytes on port B for use with byte or word data transfers. A low on BE selects the most significant bytes of $\mathrm{BO}-\mathrm{B} 35$ for use, and a high selects the least significant bytes. |
| CLKA | 1 | Port A clock. CLKA is a continuous clock that synchronizes all data transfers through port A and may be asynchronous or coincident to CLKB. EFA, FFA, AFA, and AEA are all synchronous to the low-to-high transition of CL.KA. |
| CLKB | 1 | Port B clock. CLKB is a continuous clock that synchronizes all data transfers through port B and may be asynchronous or coincident to CLKA. Port B byte swapping and data port sizing operations are also synchronous to the low-to-high transition of CLKB. EFB, FFB, $\overline{\mathrm{AFB}}$, and $\overline{\mathrm{AEB}}$ are synchronous to the low-to-high transition of CLKB. |
| CSA | 1 | PortA chip select. CSA mustbe low to enable a low-to-high transition of CLKA to read or write data on port A. The AO-A35 outputs are in the high-impedance state when CSA is high. |
| CSB | 1 | Port B chip select. CSB must be low to enable a low-to-high transition of CLKB to read or write data on port B. The BO-B35 outputs are in the high-impedance state when CSB is high. |
| EFA | 0 | FIFO2 empty flag. EFA is synchronized to the low-to-high transition of CLKA. When EFA is low, FIFO2 is empty, and reads are disabled. EFA is forced low when FIFO2 is reset and goes high on the second low-to-high transition of CLKA after data is loaded to empty memory. |
| EFB | 0 | FIFO1 empty flag. EFB is synchronized to the low-to-high transition of CLKB. When EFB is low, FIFO1 is empty, and reads are disabled. EFB is forced low when FIFO1 is reset and goes high on the second low-to-high transition of CLKB after data is loaded to empty memory. |
| ENA | 1 | Port A master enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A. |
| ENB | 1 | Port B master enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B. |
| FFA | 0 | FIFO1 full flag. FFA is synchronized to the low-to-high transition of CLKA. When FFA is low, FIFO1 is full, and writes to its array are disabled. FFA goes low when FIFO1 is reset and goes high on the second low-to-high transition of CLKA after reset. |
| FFB | 0 | FIFO2 full flag. FFB is synchronized to the low-to-high transition of CLKB. When FFB is low, FIFO2 is full, and writes to its array are disabled. FFB goes low when FIFO2 is reset and goes high on the second low-to-high transition of CLKB after reset. |
| FSO, FS1 | 1 | Flag offset selects. The low-to-high transition of RESET latches the value of the FSO and FS1, which selects one of four preset values for the almost empty and almost full offisets. |
| MBA | 1 | Port A mailbox select. A high level chooses a mailbox register for a port A read or write operation. When the A0-A35 outputs are active, a high level on MBA selects data from the mail2 register for output, and a low level selects FIFO2 data for output. |
| MBF1 | 0 | Mail1 register flag. MBFT is set low by the low-to-high transition of CLKA that writes data to the mail1 register. MBF1 is set back high by a low-to-high transition of CLKB when a port B read is selected and both $\mathrm{SIZ1}$ and SIZO are high. MBFT is set high when FIFO1 is reset. |
| MBF2 | 0 | Mail2 register flag. MBF2 is set low by the low-to-high transition of CLKB that writes data to the mail2 register. MBF2 is set back high by a low-to-high transition of CLKA when a port $A$ read is selected and MBA is high. MBF2 is set high when FIFO2 is reset. |
| $\begin{aligned} & \text { ODD/ } \\ & \text { EVEN } \end{aligned}$ | 1 | Odd/even parity select. Odd parity is checked on each port when ODD/EVEN is high, and even parity is checked when ODD/EVEN is low. ODD/EVEN also solects the typo of parity generated for each port if parity generation is enabled for read operations. |

Terminal Functions (continued)

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: |
| PEFA | 0 | Port A parity error flag. When any byte on A0-A35 fails parity, PEFA is forced low. Bytes are organized as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte serving as the parity bit. The type of parity checked is determined by the level on the ODD/EVEN select input. |
| PEFB | 0 | Port B parity error flag. When any valid byte on B0-B35 fails parity, PEFB is forced low. Bytes are organized as $\mathrm{BO}-\mathrm{B8}$, B9-B17, B18-B26, and B27-B35, with the most significant bit of each byto serving as the parity bit. A byte is valid when it is used in the bus size selection for port B. The type of parity checked is determined by the level on the ODD/EVEN select input. |
| PGA | 1 | Port A parity generation. A high on PGA selects parity to be generated for data read from port A. The level on the ODD/EVEN parity select input determines the type of parity generated. |
| PGB | 1 | Port B parity generation. A high on PGB selects parity to be generated for data read from port B. The level on the ODD/EVEN parity select input determines the type of parity generated. |
| RESET | 1 | Reset. To reset the device, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RESET is low. This sets the AFA and AFB flags high and the EFA, EFB, AEA, AEB, FFA, and FFB flags low. The low-to-high transition of RESET latches the status of FS1 and FSO for almost full and almost empty offset selection. |
| SIZ0, SIZ1 | 1 | Port B bus size selects. A low-to-high transition of CLKB latches the value of SIZO, SIZ1, and BE for a bus size select, and the following low-to-high transition of CLKB implements the latched value as a port B bus size. Port B bus sizes may be selected from long word, word, and byte. A high on both SIZ1 and SIZO directs a write or read on port B to a mailbox register. |
| SW0, SW1 | 1 | Port B byte swap selects. At the beginning of each long word transfer, one of four modes of byte order swapping is selected by SW0 and SW1. The four modes of byto order swapping are no swap, byto swap, word swap, and byte-word swap. Byte order swapping is possible with any bus size selection. |
| W/FA | 1 | Port A writerread select. A high selects a write operation and a low selects a read operation on port A for a low-to-high transition of CLKA. The AO-A35 outputs are in the high-impedance state when W/FA is high. |
| W/RB | 1 | Port B write/read select. A high selects a write operation and a low selects a read operation on port B for a low-to-high transition of CLKB. The BO-B35 outputs are in the high-impedance state when W/RB is high. |

## FIFO function

The state of the AO-A35 outputs is controlled by CSA and W/RA. When both CSA andW/RA are low, the outputs are active. The outputs are in the high-impedance state when either CSA or W/RA is high. Data is written to FIFO1 from port A on the low-to-high transition of CLKA when CSA is low, W/RA is high, MBA is low, ENA is high, and the FFA flag is high. Data is read from FIFO2 to the A0-A35 outputs on the low-to-high transition of CLKA when CSA is low, W/RA is low, MBA is low, ENA is high, and the EFA flag is high.
The state of the B0-B35 outputs is controlled by CSB and W/RB. When bothCSB and W/RB are low, the outputs are active. The outputs are in the high-impedance state when either CSB or W/RB is high. Data is written to FIFO2 from port B on the low-to-high transition of CLKB when CSB is low, W/RB is high, ENB is high, the FFB flag is high, and either SIZ0 or SIZ1 is low. Data is read from FIFO1 to the port B outputs on the low-to-high transition of CLKB when CSB is low, W/RB is low, ENB is high, the EFB flag is high, and either SIZO or SIZ1 is low.
The setup and hold time constraints to the port clocks for the chip selects (CSA, CSB) and write/read selects (W/RA, W/RB) are for enabling write and read operations and are not related to high-impedance control of the data outputs. If the master enable signal for a port (ENA or ENB) is set low during a clock cycle, the chip select and write/read select may switch at any time during the cycle to change the state of the data outputs.
Each FIFO flag is two-stage synchronized to a port clock for use as a reliable synchronous control signal. CLKA synchronizes the status of the empty flag (EFA) and almost empty flag (AEA) of FIFO2 and the full flag (FFA) and almost full flag (AFA) of FIFO1. CLKB synchronizes the status of the empty flag (EFB) and almost empty flag (AEB) of FIFO1 and the full flag (FFB) and almost full flag ( $\overline{\mathrm{AFB}}$ ) of FIFO2.

## FIFO function (continued)

When the full flag (FFA, FFB) of a port is low, the FIFO receiving input from the port is full, and writes are disabled to its array. When the empty flag (EFA, EFB) of a port is low, the FIFO that outputs data to the port is empty, and reads from its memory are disabled.

## mailbox registers

A 36-bit data word may be exchanged between ports and circumvent the normal FIFO path. The mailbox select input (MBA) chooses between a mail register and a FIFO for a port A data transfer operation. Port B accesses a mail register when the bus size select inputs (SIZO, SIZ1) are both high. A0-A35 data is written to the mail1 register on a low-to-high transition of CLKA when CSA is low, W/RA is high, ENA is high, and MBA is high. B0-B35 data is written to the mail2 register on a low-to-high transition of CLKB when CSB is low, W/RB is high, ENB is high, and both SIZO and SIZ1 are high.

When data is written to a mail register, its mailbox flag (MBF1, MBF2) is set low. The MBF1 flag is set high on a low-to-high transition of CLKB when a read is selected for port B and both SIZO and SIZ1 are high. The MBF2 flag is set high on a low-to-high transition of CLKA when a read is selected for port A and the MBA input is high. The data in a mailbox register remains intact after it is read and changes only when new data is writen to the register. When the B0-B35 outputs are active, mail1 data is output if both SIZ0 and SIZ1 are high, and FIFO1 data is output if either bus size input is low. The level on MBA selects between FIFO2 and mail2 data for output on A0-A35.

## reset

The SN74ABT7815 is reset by taking the reset input (RESET) low for at least four CLKA and four CLKB low-to-high transitions. This resets the internal read and write pointers of each FIFO to their initial locations and forces $\overline{A F A}$ and $\overline{A F B}$ flags high and EFA, EFB, FFA, FFB, $\overline{A E A}$, and $\overline{A E B}$ flags low. The reset input may by asynchronous with respect to either clock. Resetting the device also forces the mailbox flags (MBF1, MBF2) high. Data outputs of the FIFO and mailbox register are not reset to any specific logic level. The device must be reset upon power up.

## almost full and almost empty flags

Four preset values are available for the offsets of the almost full and almost empty flags of the SN74ABT7815. The flag select inputs (FSO, FS1) are sampled by the low-to-high transition of the reset input (RESET), and the offsets for $\overline{A F A}, \overline{A E A}, \overline{A F B}$, and $\overline{A E B}$ are set according to the flag programming table.
An almost empty flag is low when the number of 36 -bit words stored in its FIFO is less than or equal to the flag's offset value. An almost full flag is low when the number of empty locations left in its FIFO is less than or equal to the flag's offset value. Data in the output register of a FIFO has been read from memory, and its previous location is free.

FLAG PROGRAMMING TABLE

| FS1 | FSO | RESET | AF AND AE <br> OFFSET |
| :---: | :---: | :---: | :---: |
| H | H | $\dagger$ | 16 |
| H | L | $\uparrow$ | 12 |
| L | H | $\dagger$ | 8 |
| L | L | $i$ | 4 |

# SN74ABT7815 <br> 64 X 36 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING 

## dynamic bus sizing

Port B may be configured in a 36 -bit long-word, 18 -bit-word, or 9 -bit-byte bus size with a choice of big- or little-endian formats to read data from FIFO1 or input data to FIFO2. The bus size can be changed synchronous to CLKB to accommodate peripherals of various bus sizes.
A bus size is selected on the low-to-high transition of CLKB by the levels on the bus size inputs (SIZO, SIZ1) and the big-endian input (BE) according to Figure 1. The bus size is implemented on port B by the following low-to-high transition of CLKB. When reading data from FIFO1 and a bus size of word or byte length is implemented for port B, the unused outputs of BO-B35 remain active but static, holding the last data value to decrease power consumption.
The port B almost empty flag ( $\overline{\mathrm{AEB}}$ ) and almost full flag ( $\overline{\mathrm{AFB}}$ ) always measure the number of 36 -bit memory locations in the FIFOs regardless of the bus size. The port B empty flag (EFB) and full flag (FFB) are based on the bus size selection.

## SN74ABT7815

64 X 36 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY
WITH BUS MATCHING AND BYTE SWAPPING
SCBS126-JUNE 1992

BYTE ORDER ON PORT A:


Write to FIFO2/Read From FIFO1

| BE | SIZ: | SIZO |
| :---: | :---: | :---: |
| $X$ | $L$ | $L$ |



Road From FFO1/Writo to FFO2
(a) LONG WORD SIZE

| BE | SIZ1 | SIZO |
| :---: | :---: | :---: |
| $L$ | $L$ | $H$ |


(b) WORD SIZE-BIG ENDIAN

(c) WORD SIZE-LITTLE ENDIAN

(d) BYTE SIZE-BIG ENDIAN

Figure 1. Dynamic Bus Sizing


Figure 1. Dynamic Bus SIzing (continued)

## byte swapping

The byte order of port B can be changed synchronous to CLKB for FIFO data passing through port B. Four modes of byte order swapping (including no swap) can be done with any data port size selection. The order of the bytes can be rearranged, but the bit order within the bytes remains constant.
When reading data from FIFO1 to port B, the byte arrangement is chosen by the swap inputs (SW0, SW1) on a low-to-high transition of CLKB that reads a new long word from FIFO1. Data is unloaded to the data outputs according to Figure 2.
When writing data from port B to FIFO2, the byte arrangement is chosen by the swap inputs (SW0, SW1) on a low-to-high transition of CLKB that writes a new long word to FIFO2. Data is loaded to memory according to Figure 2. The status of the SWO and SW1 inputs has no effect when a port B read or write operation accesses a bypass register.

| SW1 | SW0 |
| :---: | :---: |
| $L$ | $L$ |


(a) NO SWAP

| SW1 | SW0 |
| :---: | :---: |
| $\mathbf{L}$ | $H$ |


(b) BYTE SWAP

| SW1 | sW0 |
| :---: | :---: |
| $H$ | $L$ |


(c) WORD SWAP

| SW1 | swo |
| :---: | :---: |
| $H$ | $H$ |


(d) BYTE-WORD SWAP

Flgure 2. Byte Swapping (Long Word Size Example)

## SN74ABT7815 <br> 64 X 36 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY WITH BUS MATCHING AND BYTE SWAPPING <br> SCBS126-JUNE 1992

## parity checking and parity generation

The parity error flag for port $A$ (PEFA) is low if any byte on A0-A35 fails a parity check. The bytes are arranged as A0-A8, A9-A17, A18-A26, and A27-A35, with the most significant bit of each byte used as the parity bit. The bytes on port B are also arranged as $\mathrm{B} 0-\mathrm{B} 8, \mathrm{~B} 9-\mathrm{B} 17, \mathrm{~B} 18-\mathrm{B} 26$, and $\mathrm{B} 27-\mathrm{B} 35$ with the most signicant bit of each byte used for parity. Only the port B bytes selected by the bus sizing inputs (BE, SIZ1, SIZ0) are checked for parity, with a parity failure of any of the selected bytes forcing a low on the port B parity error flag (PEFB). The odd/even select input (ODD/EVEN) chooses the type of parity checked on both port $A$ and port $B$.

Parity can be generated for data read from a port by asserting the port's parity generation input (PGA, PGB) for the low-to-high transition of the clock that reads the data to the output. When parity generation is selected for a port read, parity is generated for each byte based on the ODD/EVEN input selection and stored in the most significant bit of the byte. Parity can be generated for reads from FIFO memory and reads from the mailbox register.

## recommended operating conditions

|  |  | MIN | MAX |
| :--- | :--- | ---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5.5 |
| $\mathrm{~V}_{\mathrm{IH}}$ | High-level input voltage | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage | 2 | V |
| $\mathrm{I}_{\mathrm{OH}}$ | High-level output current | 0.8 | V |
| $\mathrm{I}_{\mathrm{OL}}$ | Low-level output current | -4 | mA |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | 8 | mA |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (unless otherwise noted)

| PARAMETER | FROM (INPUT) | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | 'ACT7815-15 | 'ACT7815-20 | 'ACT7815-25 | 'ACT7815-40 | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX | MIN MAX | MIN MAX | MIN MAX |  |
| $f_{\text {max }}$ | CLKA or CLKB |  | 67 | 50 | 40 | 25 | M Hz |
| $t_{\text {pd }}$ | CLKA $\dagger$ | A0-A35 | 10 | 12 | 14 | 16 | ns |
|  | CLKB $\dagger$ | B0-B35 | 10 | 12 | 14 | 16 |  |
|  | CLKA $\dagger$ | EFA, FFA, $\overline{A E A}, \overline{\mathrm{~A} F A}$ | 10 | 12 | 14 | 16 |  |
|  | CLKB $\dagger$ | EFB, FFB, $\overline{A E B}, \overline{\mathrm{AFB}}$ | 10 | 12 | 14 | 16 |  |
| $t_{\text {pd }}$ | MBA | A0-A35 | 11 | 12 | 14 | 16 |  |
|  | SIZ1, SIZO ${ }^{\text {¢ }}$ | B0-B35 | 11 | 12 | 14 | 16 |  |
| $t_{\text {pd }}{ }^{\ddagger}$ | MBA | A8, A17, A26, A35 | 14 | 15 | 17 | 19 | ns |
|  | SIZ1, SIZO | B8, B17, B26, B35 | 14 | 15 | 17 | 19 |  |
| tPHL | CLKA $\dagger$ | MBF1 | 10 | 12 | 14 | 16 | ns |
| tplH | CLKB $\dagger$ |  | 9 | 11 | 13 | 15 |  |
| tpHL | CLKB ${ }^{\text {¢ }}$ | MBF2 | 10 | 12 | 14 | 16 | ns |
| tpli | CLKA ${ }^{\text {¢ }}$ |  | 9 | 11 | 13 | 15 |  |
| $t_{p d}$ | A0-A35 | PEFA | 13 | 14 | 16 | 18 | ns |
|  | B0-B35 | PEFB | 13 | 14 | 16 | 18 |  |
| ${ }^{t} \mathrm{pd}$ | ODD/EVEN | PEFA | 12 | 13 | 15 | 17 | ns |
|  |  | PEFB | 12 | 13 | 15 | 17 |  |
| tphL | RESET | $\overline{\text { AEA, }}$ AEB |  |  |  |  | ns |
| ${ }_{\text {tpl }}$ | RESET | AFA, AFB |  |  |  |  | ns |
|  |  | MBFT, MBF2 |  |  |  |  |  |
| ten | CSA, W/RA | A0-A35 |  |  |  |  | ns |
|  | CSB, W/RB | B0-B35 |  |  |  |  |  |
| $t_{\text {dis }}$ | CSA, W/RA | A0-A35 |  |  |  |  | ns |
|  | CSB, W/RB | B0-B35 |  |  |  |  |  |

$\uparrow$ Selecting between FIFO1 and mail1 output with SIZ1 and SIZO
$\ddagger$ Parity generation is selected when reading a bypass register.

- Free-Running CLKA and CLKKB May Be Asynchronous or Coincident
- Two Independent $64 \times 36$ Clocked FIFOs Buffering Data In Opposite Directions
- Almost Full/Almost Empty Flags
- Microprocessor Interface Control Logic
- IRA, ORA, AEA and AFA Synchronized to CLKA
- IRB, ORB, AEB and AFB Synchronized to CLKB
- Passive Parlty Checking on Each Port
- Parlty Generation Can Be Selected for Each Port
- Low-Power Advanced BICMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Times of 11 ns
- Avallable In 132-pin Quad Flat Package (PQ) or Space-Saving 120-pin Shrink Quad Flat Package (PCB)


## description

The SN74ABT7816 is a high-speed, low-power BiCMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 11 ns . Two independent $64 \times 36$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. Each FIFO has flags to indicate empty and full conditions and two flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. Communication between each port may bypass the FIFOs via two 36 -bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if it is not desired. Parity generation can be selected for the data read from each port.
The SN74ABT7816 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.
The input ready flag and almost full flag of a FIFO are two-stage synchronized to the port clock that writes data to its array. The output ready flag and almost empty flag of a FIFO are two-stage synchronized to the port clock that reads data from its array.

PCB PACKAGE
(TOP VEW)


NC-No internal connection

- Member of the Texas Instruments Widebus ${ }^{\text {TM }}$ Family
- Free-Running CLKA and CLKB May Be Asynchronous or Coincident
- $64 \times 36$ Clocked FIFO Buffering Data From Port A to Port B
- Mailbox Reglster In Each Direction
- Dynamic Port B Bus Sizing of 36 Bits (Long Word), 18 Blts (Word), and 9 Blts (Byte)
- Selection of Blg- or Little-Endlan Format for Word and Byte Bus Sizes
- Three Modes of Byte Order SwappIng on Port B
- Almost Full and Almost Empty Flags
- Microprocessor Interface Control Logic
- FF and AF Flags Synchronized by CLKA
- EF and AE Flags Synchronized by CLKB
- Passive Parlty CheckIng on Each Port
- Parity Generation Can Be Selected for Each Port
- Low-Power Advanced BICMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Times of 11 ns
- Avallable In 132-PIn Quad Flat Package (PQ) or Space-Saving 120-Pin Shrink Quad Flat Package (PCB)


## description

The SN74ABT7817 is a high-speed, low-power BiCMOS clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 11 ns . The $64 \times 36$ dual-port SRAM FIFO buffers data from port A to port B. The FIFO has flags to indicate empty and full conditions and two programmable flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. FIFO data on port B may be output in 36 -bit, 18 -bit, and 9 -bit formats with a choice of big- or little-endian configurations. Three modes of byte order swapping are possible with any bus size selection. Communication between each port may take place with two 36 -bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if not desired. Parity generation can be selected for data read from each port.
The SN74ABT7817 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-hightransition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.
The full flag (FF) and almost full flag (AF) of the FIFO are two-stage synchronized to CLKA. The empty flag (EF) and almost empty flag (AE) of the FIFO are two-stage synchronized to CLKB.

PCB PACKAGE
(TOP VEW)


NC-No internal connection

- Passive Party Checking on Each Port
- Parity Generation Can Be Selected for Each Port
- Low-Power Advanced BICMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Times of 11 ns
- Avallable In 132-PIn Quad Flat Package (PQ) or Space-Saving 120-PIn Shrink Quad Flat Package (PCB)


## description

The SN74ABT7818 is a high-speed, low-power BiCMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 11 ns . The $64 \times 36$ dual-port SRAM FIFO buffers data from port A to port B. The FIFO has flags to indicate empty and full conditions and two flags. (almost full and almost empty) to indicate when a selected number of words is stored in memory. Communication between each port may take place with two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Parity is checked passively on each port and may be ignored if it is not desired. Parity generation can be selected for the data read from each port.

The SN74ABT7818 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.

The input ready flag (IR) and almost full flag (AF) of the FIFO are two-stage synchronized to CLKA. The output ready flag (OR) and almost empty flag ( $\overline{\mathrm{AE}}$ ) of the FIFO are two-stage synchronized to CLKB.


NC-No internal connection

- Dual Independent FIFOs Organized As:
- 64 Words by 1 Blt Each - SN74ACT2226
- 256 Words by 1 Blt Each - SN74ACT2228
- Free-Running Read and Write Clocks May Be Asynchronous or CoIncldent on Each FIFO
- Input Ready Flags Synchronized to Write Clocks
- Output Ready Flags Synchronized to Read Clocks
- Half-Full and Almost Full/Almost Empty Flags
- Support Clock Frequencles Up To 15 MHz
- Characterized for Operation Over the Industrial Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}$ )
- Access Times of 20 ns
- Low-Power Advanced CMOS Technology
- Avallable In 24-PIn SOIC (DW) Package


## description

The SN74ACT2226 and SN74ACT2228 are dual FIFOs suited for a wide range of serial data buffering applications including elastic stores for frequencies up to T2 telecommunication rates. Each FIFO on the chip is arranged as $64 \times 1$ (SN74ACT2226) or $256 \times 1$ (SN74ACT2228) and has control signals and status flags for independent operation. Output flags per FIFO include input ready (1IR or 2IR), output ready (1OR or 2OR), half-full ( 1 HF or 2 HF ), and almost full/almost empty (1AF/AE or 2AF/AE).
Serial data is written into a FIFO on the low-to-high transition of the write-clock (1WRTCLK or 2WRTCLK) input when the write enable (1WRTEN or 2WRTEN) input and input ready flag (1IR or 2IR) output are both high. Serial data is read from a FIFO on the low-to-high transition of the read clock (1RDCLK or 2RDCLK) input when the read enable (1RDEN or 2RDEN) input and output ready flag (1OR or 2OR) output are both high. The read and write clocks of a FIFO may be asynchronous to one another.

## logic symbols ${ }^{\dagger}$


$\dagger$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.

SN74ACT2226 functional block diagram (each FIFO)


## SN74ACT2228 functional block diagram (each FIFO)



| PIN |  | 1／0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO． |  |  |
| $\begin{aligned} & \text { 1AF/AE } \\ & 2 A F / A E \end{aligned}$ | $\begin{gathered} 2 \\ 14 \end{gathered}$ | 0 | Almost full／almost empty flag．AF／AE is high when the memory is eight locations or less from a full or empty state． AF／AE is set high after reset． |
| 1D，2D | 6，18 | 1 | Data input |
| GND | 7 |  | Ground |
| $\begin{aligned} & 1 \mathrm{HF} \\ & 2 \mathrm{HF} \end{aligned}$ | $\begin{gathered} 1 \\ 15 \end{gathered}$ | 0 | Half－full flag．HF is high when the number of bits stored in memory is greater than or equal to half the FIFO depth． HF is set low after reset． |
| $\begin{aligned} & 11 R \\ & 2!R \end{aligned}$ | $\begin{gathered} 5 \\ 17 \end{gathered}$ | 0 | Input ready flag．IR is synchronized to the low－to－high transition of WRTCLK．When IR is low，the FIFO is full and writes are disabled．IR is set low during reset and is set high on the second low－to－high transition of WRTCLK after reset． |
| $\begin{aligned} & \text { 1OR } \\ & \text { 2OR } \end{aligned}$ | $\begin{aligned} & 22 \\ & 10 \end{aligned}$ | 0 | Output ready flag．OR is synchronized to the low－to－high transition of RDCLK．When OR is low，the FIFO is empty and reads are disabled．Ready data is present on the data output when OR is high．OR is set low during reset and set high on the third low－to－high transition of RDCLK after the first word is loaded to empty memory． |
| $\begin{aligned} & 1 Q \\ & 2 Q \end{aligned}$ | $\begin{gathered} 21 \\ 9 \end{gathered}$ | 0 | Data outputs．After the first valid write to empty memory，the first bit is output on the third rising edge of RDCLK． OR for the FIFO is also asserted high at this time to indicate ready data． |
| 1RDCLK 2RDCLK | $\begin{aligned} & 24 \\ & 12 \end{aligned}$ | 1 | Read clock．RDCLKis a continuous clock and may be independent of any other clock on the device．Alow－to－high transition of RDCLK reads data from memory when the FIFO＇s RDEN and OR are high．OR is synchronous with the low－to－high transition of RDCLK． |
| $\begin{aligned} & \text { 1RDEN } \\ & \text { 2RDEN } \end{aligned}$ | $\begin{aligned} & 23 \\ & 11 \end{aligned}$ | 1 | Read enable．When the RDEN and OR of a FIFO are high，data is read from the FIFO on the low－to－high transition of RDCLK． |
| $\begin{aligned} & \text { 1RESET } \\ & \text { 2RESET } \end{aligned}$ | $\begin{gathered} 8 \\ 20 \end{gathered}$ | I | Reset．To reset the FIFO，four low－to－high transitions of RDCLK and four low－to－high transitions of WRTCLK must occur while RESET is low．This sets HF，IR，and OR low and AF／AE high． |
| $\mathrm{V}_{\mathrm{CC}}$ | 19 |  | Supply voltage |
| 1WRTCLK 2WRTCLK | $\begin{gathered} 3 \\ 15 \end{gathered}$ | 1 | Write clock．WRTCLK is a continuous clock and may be independent of any other clock on the device．A low－to－high transition of WRTCLK writes data to memory when WRTEN and IR are high．IR is synchronous with the low－to－high transition of WRTCLK． |
| 1WRTEN 2WRTEN | $\begin{gathered} 4 \\ 16 \\ \hline \end{gathered}$ | I | Write enable．When WRTEN and IR are high，data is written to the FIFO on a low－to－high transition of WRTCLK． |

timing diagrams


Figure 1. FIFO Reset



Figure 2. FIFO Write


Flgure 3. FIFO Read

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$


Input voltage, $\mathrm{V}_{1}$

Storage temperature range
er $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## SN74ACT2226, SN74ACT2228

DUAL 64 X 1 AND DUAL 256 X1
CLOCKED FIRST-IN, FIRST-OUT MEMORIES
JUNE 1992

## recommended operating conditions

|  |  |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{C C}$ | Supply voltage |  | 4.5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 | V |
| $\mathrm{IOH}^{2}$ | High-level output current | Q outputs, flags |  | -8 | mA |
| lol | Low-level output current | Q outputs |  | 16 | mA |
|  |  | Flags |  | 8 |  |
| $T_{A}$ | Operating free-air temperature |  | -40 | 85 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\dagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | Flags | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\text {OL }}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| $\mathrm{I}_{1}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lcc |  | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcc}{ }^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, One input at 3.4 V, | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{\mathrm{i}}$ |  | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current when each input is at one of the specified TTL voltage levels rather than 0 V or $\mathrm{V}_{\mathrm{CC}}$.
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figure 4)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | MIN TYP ${ }^{\text {¢ }}$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {max }}$ | 1WRTCLK, 2WRTCLK, or 1RDCLK, 2RDCLK |  | 15 | MHz |
| $t_{\text {pd }}$ | 1RDCLK $\uparrow$, 2RDCLK $\dagger$ | 1Q, 2Q | 20 | ns |
| $t_{\text {pd }}$ | 1WRTCLK $\uparrow$, 2WRTCLK $\dagger$ | 11R, 2IR | 20 | ns |
| $t_{\text {pd }}$ | 1RDCLK $\dagger$, 2RDCLK $\dagger$ | 10R, 20R | 20 | ns |
| $t_{\text {pd }}$ | 1WRTCLK $\uparrow$, 2WRTCLK $\uparrow$ | 1AF/AE, 2AF/AE | 20 | ns |
| $t_{\text {pd }}$ | 1RDCLK $\dagger$, 2RDCLK $\dagger$ | 1AF/AE, 2AF/AE | 20 | ns |
| tpLH | 1WRTCLK $\dagger$, 2WRTCLK $\dagger$ | 1HF, 2HF | 20 | ns |
| $\mathrm{t}_{\mathrm{pHL}}$ | 1RDCLK $\uparrow$, 2RDCLK $\dagger$ |  | 20 |  |
| tplH | 1RESET, 2RESET low | 1AF/AE, 2AF/AE |  | ns |
| $t_{\text {PHL }}$ |  | 1HF, 2HF |  |  |

operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | TYP | UNIT |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $C_{\text {pd }}$ | Power dissipation capacitance | Outputs enabled | $C_{L}=50 \mathrm{pF}, \quad \mathrm{f}=5 \mathrm{MHz}$ |  | pF |

## PARAMETER MEASUREMENT INFORMATION



Figure 4. Load Clrcult and Voltage Waveforms

- Dual Independent FIFOs Organized As:
- 64 Words by 1 BIt Each - SN74ACT2227
- 256 Words by 1 Blt Each - SN74ACT2229
- Free-Running Read and Write Clocks May Be Asynchronous or CoIncldent on Each FIFO
- Input Ready Flags Synchronized to Write Clocks
- Output Ready Flags Synchronized to Read Clocks
- Half-Full and Almost Full/Almost Empty Flags
- Characterized for Operation Over the Industrial Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}$ )
- Support Clock Frequencles Up To 60 MHz
- Access Times of 12 ns
- 3-State Data Outputs
- Low-Power Advanced CMOS Technology
- Avallable In 28-Pin SOIC (DW) or SSOP (DL) Packages


## description

The SN74ACT2227 and SN74ACT2229 are dual FIFOs suited for a wide range of serial data buffering applications including elastic stores for frequencies up to $\mathrm{OC}-1$ telecommunication rates. Each FIFO on the chip is arranged as $64 \times 1$ (SN74ACT2227) or $256 \times 1$ (SN74ACT2229) and has control signals and status flags for independent operation. Output flags per FIFO include input ready (1IR or 2IR), output ready (1OR or 20R), half-full ( 1 HF or 2HF), and almost full/almost empty (1AF/AE or 2AF/AE).
Serial data is written into a FIFO on the low-to-high transition of the write-clock (1WRTCLK or 2WRTCLK) input when the write enable (1WRTEN or 2WRTEN) input and input ready flag (1IR or 21R) output are both high. Serial data is read from a FIFO on the low-to-high transition of the read clock (1RDCLK or 2RDCLK) input when the read enable (1RDEN or 2RDEN) input and output ready flag (10R or 20R) output are both high. The read and write clocks of a FIFO may be asynchronous to one another. A FIFO data output (1Q or 2 Q ) is in the high-impedance state when its output-enable (10E or 2OE) input is low.
logic symbols ${ }^{\dagger}$

$\dagger$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.

## SN74ACT2227 functional block diagram (each FIFO)



## SN74ACT2229 functional block diagram (each FIFO)



Terminal Functions

| PIN |  | 1／O | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO． |  |  |
| $\begin{aligned} & \text { 1AF/AE } \\ & \text { 2AF/AE } \end{aligned}$ | $\begin{gathered} 2 \\ 16 \end{gathered}$ | 0 | Almost full／almost empty flag．AF／AE is high when the memory is eight locations or less from a full or empty state． AF／AE is set high after reset． |
| 1D，2D | 6，20 | 1 | Data input |
| GND | 7， 8 |  | Ground |
| $\begin{aligned} & 1 \mathrm{HF} \\ & 2 \mathrm{HF} \end{aligned}$ | $\begin{gathered} 1 \\ 15 \end{gathered}$ | 0 | Half－full flag．HF is high when the number of bits stored in memory is greater than or equal to half the FIFO depth． HF is set low after reset． |
| $\begin{aligned} & 1 \mathrm{IR} \\ & 2 \mathbb{R} \end{aligned}$ | $\begin{gathered} 5 \\ 19 \end{gathered}$ | 0 | Input ready flag．IR is synchronized to the low－to－high transition of WRTCLK．When IR is low，the FIFO is full and writes are disabled．IR is set low during reset and is set high on the second low－to－high transition of WRTCLK after reset． |
| $\begin{aligned} & \text { 10E } \\ & \text { 2OE } \end{aligned}$ | $\begin{aligned} & 28 \\ & 14 \end{aligned}$ | 1 | Output enable．The data output of a FIFO is active when OE is high and in the high－impedance state when OE is low． |
| $\begin{aligned} & 10 R \\ & 20 R \end{aligned}$ | $\begin{aligned} & 25 \\ & 11 \end{aligned}$ | 0 | Output ready flag．OR is synchronized to the low－to－high transition of RDCLK．When OR is low，the FIFO is empty and reads are disabled．Ready data is present on the data output when OR is high．OR is set low during reset and set high on the third low－to－high transition of RDCLK after the first word is loaded to empty memory． |
| $\begin{aligned} & 1 Q \\ & 2 Q \end{aligned}$ | $\begin{aligned} & 24 \\ & 10 \end{aligned}$ | 0 | Data outputs．After the first valid write to empty memory，the first bit is output on the third rising edge of RDCLK． OR for the FIFO is also asserted high at this time to indicate ready data． |
| 1RDCLK 2RDCLK | $\begin{aligned} & 27 \\ & 13 \end{aligned}$ | I | Read clock．RDCLKis a continuous clock and may be independent of any other clock on the device．Alow－to－high transition of RDCLK reads data from memory when the FIFO＇s RDEN and OR are high．OR is synchronous with the low－to－high transition of RDCLK． |
| $\begin{aligned} & \text { 1RDEN } \\ & \text { 2RDEN } \end{aligned}$ | $\begin{aligned} & 26 \\ & 12 \end{aligned}$ | I | Read enable．When the RDEN and OR of a FIFO are high，data is read from the FIFO on the low－to－high transition of RDCLK． |
| $\begin{aligned} & \text { 1RESET } \\ & \text { 2RESET } \end{aligned}$ | $\begin{gathered} 9 \\ 23 \end{gathered}$ | I | Reset．To reset the FIFO，four low－to－high transitions of RDCLK and four low－to－high transitions of WRTCLK must occur while RESET is low．This sets HF，IR，and OR low and AF／AE high． |
| $V_{\text {cc }}$ | 21, 22 |  | Supply voltage |
| 1WRTCLK 2WRTCLK | $\begin{gathered} 3 \\ 17 \end{gathered}$ | 1 | Write clock．WRTCLK is a continuous clock and may be independent of any other clock on the device．A low－to－high transition of WRTCLK writes data to memory when WRTEN and IR are high．IR is synchronous with the low－to－high transition of WRTCLK． |
| IWRTEN 2WRTEN | $\begin{gathered} 4 \\ 18 \\ \hline \end{gathered}$ | I | Write enable．When WRTEN and IR are high，data is written to the FIFO on a low－to－high transition of WRTCLK． |

## timing diagrams



Flgure 1. FIFO Reset


Figure 2. FIFO Write


FIgure 3. FIFO Read
absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

Input voltage, $V_{1}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Voltage applied to a disabled 3-state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
${ }^{\dagger}$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions

|  |  |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5.5 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | High-level input voltage |  | 2 |  | V |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage |  |  | 0.8 | V |
| IOH | High-level output current | Q outputs, flags |  | -8 | mA |
| Iol | Low-level output current | Q outputs |  | 16 | mA |
|  |  | Fags |  | 8 |  |
| $T_{A}$ | Operating free-air temperature |  | -40 | 85 | ${ }^{\circ} \mathrm{C}$ |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDTIONS |  | MIN | TYP ${ }^{\text {t }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-8 \mathrm{~mA}$ | 2.4 |  |  | V |
| Vol | Flags | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  | 0.5 | V |
|  | Qoutputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.5 |  |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cC }}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| 102 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{cc}}$ or 0 |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| Icc |  | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}-0.2 V_{\text {or }} 0$ |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{cc}^{5}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, One input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{1}$ |  | $\mathrm{V}_{1}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  | 4 |  | pF |
| $\mathrm{C}_{0}$ |  | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  | 8 |  | pF |

$\dagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\ddagger}$ This is the supply current when each input is at one of the specified TTL voltage levels rather than 0 V or $\mathrm{V}_{\mathrm{cc}}$.
switching characteristics over recommended ranges of supply voltage and operating free-alr temperature, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) (see Figure 4)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (NPUT) } \end{aligned}$ | TO (OUTPUT) | MIN TYP ${ }^{\text {t }}$ MAX | UNIT. |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {max }}$ | 1WRTCLK, 2WRTCLK, or 1RDCLK, 2RDCLK |  | 60 | MHz |
| $t_{\text {pd }}$ | 1RDCLK $\dagger$, 2RDCLK $\dagger$ | 1Q, 20 | 12 | ns |
| $t_{\text {pd }}$ | 1WRTCLK $\uparrow$, 2WRTCLK $\dagger$ | 1/R, 21R | 10 | ns |
| $t_{p d}$ | 1RDCLK $\dagger$, 2RDCLK $\dagger$ | 10R, 20R | 10 | ns |
| $t_{\text {pd }}$ | 1WRTCLK $\uparrow$, 2WRTCLK $\dagger$ | 1AF/AE, 2AF/AE | 17 | ns |
| $t_{\text {pd }}$ | 1RDCLK $\dagger$, 2RDCLK $\dagger$ | 1AF/AE, 2AF/AE | 18 | ns |
| tpli | 1WRTCLK $\uparrow$, 2WRTCLK $\uparrow$ | 1HF, 2HF | 15 | ns |
| ${ }_{\text {PHL }}$ | 1RDCLK $\uparrow$, 2RDCLK $\dagger$ |  | 19 |  |
| t+LH | 1RESET, 2RESET low | 1AF/AE, 2AF/AE |  | ns |
| ${ }_{4}{ }_{\text {PHL }}$ |  | 1HF, 2HF |  |  |
| $t_{\text {en }}$ | 10E, 20E | 1Q, 2Q | 14 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  | 14 |  |

operating characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDTTIONS | TYP | UNIT |  |
| :--- | :--- | :--- | :--- | :--- |
| $\mathrm{C}_{\mathrm{pd}}$ | Power dissipation capacitance | Outputs enabled | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \mathrm{F}_{1} \mathrm{f}=5 \mathrm{MHz}$ |  |

## PARAMETER MEASUREMENT INFORMATION



VOLTAGE WAVEFORBS
ENABLE AND DISABLE TIHES

| PARAMETER |  | R1, R2 | $\mathrm{C}_{\mathrm{L}}{ }^{\text {t }}$ | S1 |
| :---: | :---: | :---: | :---: | :---: |
| ten | tpZH | 500 ¢ | 50 pF | Open |
|  | teZL |  |  | Closed |
| $t_{\text {dis }}$ | ${ }_{\text {tehz }}$ | $500 \Omega$ | 50 pF | Open |
|  | tpLZ |  |  | Closed |
| $t_{\text {pd }}$ |  | 5009 | 50 pF | Open |

$\dagger$ Includes probe and test fixture capacitance.
Flgure 4. Load CIrcult and Voltage Waveforms

## SN74ACT7821 512 X 32 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY

- Free-Running CLKA and CLKB May Be Asynchronous or CoIncident
- Two Independent $512 \times 32$ Clocked FIFOs Buffering Data In Opposite DIrections
- Read Retransmit Capabllity From FIFO on Port B
- Mallbox Bypass Reglster for Each FIFO
- Programmable Almost Full and Almost Empty Flags
- Microprocessor Interface Control Loglc
- IRA, ORA, AEA, and AFA Flags Synchronized by CLKA
- IRB, ORB, $\overline{\mathrm{AEB}}$, and $\overline{\mathrm{AFB}}$ Flags Synchronized by CLKB
- Low-Power 0.8-MIcron Advanced CMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Times of 12 ns
- Avallable in 132-Pln Quad Flatpack (PQ) or Space-Saving 120-PIn Shrink Quad Flatpack (PCB)

PCB PACKAGE
(TOP VIEW)

|  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
| CSA |  |  | 90 | CSB |
| W/FA | 2 |  | 89 | W/RB |
| ENA 5 | 3 |  | 88 | $\square \mathrm{ENB}$ |
| CLKA | 4 |  | 87 | $\square$ CLKB |
| $\mathrm{V}_{\mathrm{Cc}} 5$ | 5 |  | 86 | $\square \mathrm{GND}$ |
| A31 | 6 |  | 85 | B B31 |
| A30 4 | 7 |  | 84 | ® 830 |
| GND ${ }^{\text {a }}$ | 8 |  | 83 | B29 |
| A29 | 9 |  | 82 | B28 |
| A28 5 | 10 |  | 81 | B27 |
| A27 5 | 11 |  | 80 | - 226 |
| A26 | 12 |  | 79 | $\mathrm{V}_{\mathrm{cc}}$ |
| A25 | 13 |  | 78 | B25 |
| A24 | 14 |  | 77 | B24 |
| A23 | 15 |  | 76 | $\square$ GND |
| GND | 16 |  | 75 | B23 |
| A22 | 17 |  | 74 | В B22 |
| $V_{\text {cc }}$ | 18 |  | 73 | 曰 B21 |
| A21 | 19 |  | 72 | B20 |
| A20 5 | 20 |  | 71 | - B19 |
| A19 | 21 |  | 70 | B18 |
| A18 | 22 |  | 69 | $\square$ GND |
| GND 5 | 23 |  | 68 | B17 |
| A17 5 | 24 |  | 67 | $\square \mathrm{B} 16$ |
| A16 5 | 25 |  | 66 | $\square \mathrm{Vcc}$ |
| A15 5 | 26 |  | 65 | B15 |
| A14 | 27 |  | 64 | $\square \mathrm{B} 14$ |
| A13 | 28 |  | 63 | - 13 |
| $\mathrm{V}_{\mathrm{cc}}$ | 29 |  | 62 | $\square 12$ |
| A12 | 30 |  | 61 | GND |
|  |  |  |  |  |

## JUNE 1992

## description

The SN74ACT7821 is a high-speed, low-power CMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 12 ns . Two independent $512 \times 32$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. The FIFO memory buffering data from port A to port B has retransmit capability, which allows previously read data to be accessed again. Each FIFO has flags to indicate empty and full conditions and two programmable flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. Communication between each port may bypass the FIFOs via two 32 -bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Two or more devices may be used in parallel to create wider data paths.

The SN74ACT7821 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.
The input ready flag and almost full flag of a FIFO are two-stage synchronized to the port clock that writes data to its array. The output ready flag and almost empty flag of a FIFO are two-stage synchronized to the port clock that reads data from its array. Offsets for the almost full and almost empty flags of both FIFOs can be programmed from port A .

## functional block diagram



Terminal Functions

| PIN NAME | 1/O | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A31 | 1/0 | Port A data. 32-bit bidirectional data port for side A. |
| AEA | 0 | FIFO2 almost empty flag. Programmable flag synchronized to CLKA. It is low when the number of words in FIFO2 is less than or equal to the selected value. |
| AEB | 0 | FIFO1 almost empty flag. Programmable flag synchronized to CLKB. It is low when the number of words in FIFO1 is less than or equal to the selected value. |
| AFA | 0 | FIFO1 almost full flag. Programmable flag synchronized to CLKA. It is low when the number of empty locations in FIFO1 is less than or equal to the selected value. |
| AFB | 0 | FIFO2 almost full flag. Programmable flag synchronized to CLKB. It is low when the number of empty locations in FIFO2 is less than or equal to the selected value. |
| B0-831 | I/O | Port B data. 32-bit bidirectional data port for side B. |
| CLKA | I | Port A clock. CLKA is a continuous clock that synchronizes all data transfers through port $A$ and may be asynchronous or coincident to CLKB. IRA, ORA, $\overline{A F A}$, and $\overline{A E A}$ are synchronous to the low-to-high transition of CLKA. |
| CLKB | 1 | Port B clock. CLKB is a continuous clock that synchronizes all data transfers through port $B$ and may be asynchronous or coincident to CLKA. IRB, ORB, $\overline{\mathrm{AFB}}$, and $\overline{A E B}$ are synchronous to the low-to-high transition of CLKB. |
| CSA | 1 | PortA chip select. CSA must be low to enable a low-to-high transition of CLKA to read or write data on port A. The AO-A31 outputs are in the high-impedance state when CSA is high. |
| CSB | 1 | Port B chip select. CSB must be low to enable a low-to-high transition of CLKB to read or write data on port B. The B0 - B31 outputs are in the high-impedance state when CSB is high. |
| ENA | 1 | Port A master enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A. |
| ENB | 1 | Port B master enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B. |
| FS1, FS0 | 1 | Flag offiset selects. The low-to-high transition of a FIFO's reset input latches the value of FSO and FS1. If either FS0 or FS1 is high when a reset input goes high, one of three preset values is selected as the offset for the FIFO's almost full and almost empty flags. If both FIFOs are reset simultaneously and both FS0 and FS1 are low when RST1 and RST2 go high, the first four writes to FIFO1 program the almost full and almost empty offsets for both FIFOs. |
| IRA | 0 | FIFO1 input ready flag. IRA is synchronized to the low-to-high transition of CLKA. When IRA is low, FIFO1 is full and writes to its array are disabled. When FIFO1 is in retransmit mode, IRA indicates when the memory has been filled to the point of the retransmit data and prevents further writes. IRA is set low when FIFO1 is reset and is set high on the second low-to-high transition of CLKA after reset. |
| IRB | 0 | FIFO2 input ready flag. IRB is synchronized to the low-to-high transition of CLKB. When IRB is low, FIFO2 is full, and writes to its array are disabled. IRB is set low when FIFO2 is reset and is set high on the second low-to-high transition of CLKB after reset. |
| MBA | 1 | Port A mailbox select. A high level chooses a mailbox register for a port A read or write operation. When the A0-A31 outputs are active, a high level on MBA selects data from the mail2 register for output, and a low level selects FIFO2 data for output. |
| MBB | 1 | Port B mailbox select. A high level chooses a mailbox register for a port B read or write operation. When the B0-B31 outputs are active, a high level on MBB selects data from the mail1 register for output, and a low level selects FIFO1 data for output. |
| MBF1 | 0 | Mail1 register flag. MBF1 is set low by the low-to-high transition of CLKA that writes data to the mail1 register. MBF1 is sethigh by a low-to-high transition of CLKB when a port B read is selected and MBB is high. MBF1 is set high when FIFO1 is reset. |
| MBF2 | 0 | Mail2 register flag. MBF2 is set low by the low-to-high transition of CLKB that writes data to the mail2 register. MBF2 is sethigh by a low-to-high transition of CLKA when a port A read is selected and MBA is high. MBF2 is set high when FIFO2 is reset. |
| ORA | 0 | FIFO2 output ready flag. ORA is synchronized to the low-to-high transition of CLKA. When ORA is low, FIFO2 is empty, and reads are disabled. Ready data is present on the output register of FIFO2 when ORA is high. ORA is forced low when FIFO2 is reset and goes high on the third low-to-high transition of CLKA after a word is loaded to empty memory. |

# SN74ACT7821 512 X 32 X 2 CLOCKED FIRST-IN, FIRST-OUT MEMORY 

JUNE 1992

Terminal Functions (continued)

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: |
| ORB | 0 | FIFO1 output ready flag. ORB is synchronized to the low-to-high transition of CLKB. When ORB is low, FIFO1 is empty, and reads are disabled. Ready data is present on the output register of FIFO1 when ORB is high. ORB is forced low when FIFO1 is reset and goes high on the third low-to-high transition of CLKB after a word is loaded to empty memory. |
| RDYA | 0 | Port A ready. A high on W/RA selects the inverted state of IRA for output on RDYA, and alow on W/RA selects the inverted state of ORA for output on RDYA. |
| RDYB | 0 | Port B ready. A low onW/RB selects the inverted state of IRB for output on RDYB, and a high on W/RB selects the inverted state of ORB for output on RDYB. |
| RFM | 1 | FIFO1 read from mark. When FIFO1 is in retransmit mode, a high on RFM enables a low-to-high transition of CLKB to reset the FIFO1 read pointer to the retransmit location and output the first retransmit data. |
| RST1 | 1 | FIFO1 reset. To reset FIFO1, four low-to-high transitions of CLKA and four low-to-high transitions of CL.KB must occur while RST1 is low. Tho low-to-high transition of RST1 latches the status of FS0 and FS1 for AFA and AEB offset selection. |
| RST2 | 1 | FIFO2 reset. To reset FIFO2, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RST2 is low. The low-to-high transition of RST2 latches the status of FSO and FS1 for AFB and AEA offset selection. |
| RTM | 1 | FIFO1 retransmit mode. When RTM is high and valid data is prosent on the output of FIFO1, a low-to-high transition of CLKB solects the data for the beginning of a FIFO1 retransmit. The selected position remains the initial retransmit point until a low-to-high transition of CLKB occurs while RTM is low, which takes FIFO out of retransmit mode. |
| W/RA | 1 | Port A write/read select. A high selects a write operation and a low selects a read operation on port A for a low-to-high transition of CLKA. The AO-A31 outputs are in the high-impedance state when W/RA is high. |
| W/RB | 1 | Port B write/read select. A low selects a write operation and a high selects a read operation on port B for a low-to-high transition of CLKB. The B0-B31 outputs are in the high-impedance state when W/RB is low. |

## FIFO function

The state of the A0-A31 outputs is controlled by CSA and W/RA. When both CSA and W/RA are low, the outputs are active. The outputs are in the high-impedance state when either CSA or W/RA is high. Data is written to FIFO1 from port A on the low-to-high transition of CLKA when CSA is low, W/RA is high, MBA is low, ENA is high, and the IRA flag is high. Data is read from FIFO2 to the A0-A31 outputs on the low-to-high transition of CLKA when CSA is low, W/RA is low, MBA is low, ENA is high, and the ORA flag is high.
The state of the B0-B31 outputs is controlled by CSB and W/RB. When CSB is low and W/RB is high, the outputs are active. The outputs are in the high-impedance state when either CSB is high or W/RB is low. Data is written to FIFO2 from port B on the low-to-high transition of CLKB when CSB is low, W/RB is low, MBB is low, ENB is high, and the IRB flag is high. Data is read from FIFO1 to the B0-B31 outputs on the low-to-high transition of CLKB when CSB is low, W/RB is high, MBB is low, ENB is high, and the ORB flag is high.
The setup and hold time constraints to the port clocks for the chip selects (CSA, CSB) and write/read selects (W/RA, W/RB) are for enabling write and read operations and are not related to high-impedance control of the data outputs. If the master enable signal for a port (ENA or ENB) is set low during a clock cycle, the chip select and write/read select may switch at any time during the cycle to change the state of the data outputs.

Each FIFO flag is two-stage synchronized to a port clock for use as a reliable synchronous control signal. CLKA synchronizes the status of the output ready flag (ORA) and almost empty flag (AEA) of FIFO2 and the input ready flag (IRA) and almost full flag (AFA) of FIFO1. CLKB synchronizes the status of the output ready flag (ORB) and almost empty flag ( $\overline{\mathrm{AEB}}$ ) of FIFO1 and the input ready flag (IRB) and almost full flag ( $\overline{\mathrm{AFB}}$ ) of FIFO2.

## FIFO function (continued)

When the input ready flag (IRA, IRB) of a port is low, the FIFO receiving input from the port is full, and writes are disabled to its array. When the output ready flag (ORA, ORB) of a port is low, the FIFO that outputs data to the port is empty, and reads from its memory are disabled. The first word loaded to an empty memory is sent to the FIFO's output register when the port's output ready fiag is asserted (high). When the memory is read empty and the output ready flag is forced low, the last valid data remains on the FIFO outputs until the output ready flag is asserted (high) again. In this way, a high on the output ready flag indicates that new data is present on the FIFO outputs. The ready flag (RDYA or RDYB) of a port is low when the FIFO selected by the write/read select is ready for data transfer.

## mailbox registers

A 32-bit word may be exchanged between ports and circumvent the normal FIFO path. The mailbox select inputs (MBA, MBB) choose between a mail register and a FIFO for a port data transfer operation. A0-A31 data is written to the mail1 register on a low-to-high transition of CLKA when CSA is low, W/RA is high, ENA is high, and MBA is high. B0-B31 data is written to the mail2 register on a low-to-high transition of CLKB when CSB is low, W/RB is low, ENB is high, and MBB is high.

When data is written to a mail register, its mailbox flag (MBF1, MBF2) is set low. The MBF1 flag is set back high on a low-to-high transition of CLKB when a read is selected for port $B$ and the MBB input is high. The MBF2 flag is set high on a low-to-high transition of CLKA when a read is selected for port A and the MBA input is high. The data in a mailbox register remains intact after it is read and changes only when new data is written to the register. When a port's data output registers are active, a high on the mailbox enable (MBA or MBB) selects mail data to be output on the port, and a low selects FIFO data for output.

## reset

The FIFO memories on the SN74ACT7821 are reset separately by taking their reset input (RST1 or RST2) low for at least four CLKA and four CLKB low-to-high transitions. The reset inputs may be asynchronous with respect to either clock. This resets the internal read and write pointers to the initial location and forces the FIFO's AF flag high and IR, OR, and $\overline{A E}$ flags low. Resetting a FIFO also forces the flag of its parallel mailbox register high. Data outputs of the FIFO and mailbox register are not reset to any specific logic level. Both FIFOs must be reset upon power up.

## almost full and almost empty flags

Three default values are available for the offsets of the almost full and almost empty flags of a FIFO, or values can be programmed for each flag from port A. The flag select inputs (FS0, FS1) are sampled for each FIFO by the low-to-high transition of its reset input. If the values of FS0 and FS1 select a preset value at the time of the rising edge of RST1 or RST2, the value is set as the offset for the almost full and almost empty flags of the FIFO.
To program the almost full and almost empty flags of FIFO1 and FIFO2, both FIFOs should be reset simultaneously with the flag select inputs low during the low-to-high transition of the reset signals. After this reset cycle, IRA is forced high on the second low-to-high transition of CLKA, but IRB remains low until the programming is complete. The first four writes from port A to FIFO1 program offsets for flags in the order of $\overline{A E A}$, $\overline{A E B}, \overline{A F A}$ and $\overline{A F B}$. The offsets may be programmed from 1 to 508 . The IRB flag is asserted high by the second CLKB low-to-high transition after the $\overline{A F B}$ offset is programmed. The fifth write from port A to FIFO1 stores the first word in its memory.

An almost empty flag is low when the number of 32-bit words stored in its FIFO is less than or equal to the flag's offset value. An almost full flag is low when the number of empty locations left in its FIFO is less than or equal to the flag's offset value. Data in the output register of a FIFO has been read from memory, and its previous location is free.

## SN74ACT7821 

FLAG PROGRAMMING TABLE

| FS1 | FSO | RST1 | RST2 | FIFO1 OFFSET | FIFO2 OFFSET |
| :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | $\uparrow$ | X | 64 | X |
| H | H | X | $\uparrow$ | X | 64 |
| H | L | $\uparrow$ | $X$ | 16 | $X$ |
| H | L | X | $\uparrow$ | X | 16 |
| L | H | $\uparrow$ | $X$ | 8 | $X$ |
| L | H | X | $\uparrow$ | X | 8 |
| L | L | $\uparrow$ | $\uparrow$ | Programmed from port A | Programmed from port A |

## retransmit

A selected portion of the data in FIFO1 may be read repeatedly when FIFO1 is in retransmit mode. The FIFO is put in retransmit mode by asserting the retransmit mode input (RTM) high during a low-to-high transition of CLKB. If valid data is present on the bus at this time, it is the first data to be output when retransmit is activated. FIFO1 is in retransmit mode until RTM is low during a low-to-high transition of CLKB. While the FIFO is in retransmit mode, the FIFO is filled by the 512th word written after the first retransmit data.

When FIFO1 is in retransmit mode, a high on the read from mark input (RFM) enables a low-to-high transition of CLKB to begin retransmit. This clock edge resets the read pointer to the first retransmit location and outputs the first retransmit data. Data may be retransmitted from the selected starting position repeatedly. A new retransmit starting position may be selected after taking FIFO1 out of retransmit mode by asserting RTM high during a low-to-high transition of CLKB when the selected starting data is present of the FIFO1 outputs.
recommended operating conditions

|  |  | MIN | MAX |
| :--- | :--- | :---: | :---: |
| $V_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5.5 |
| $\mathrm{~V}_{\mathrm{IH}}$ | High-level input voltage | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage | 2 | V |
| $\mathrm{l}_{\mathrm{OH}}$ | High-level output current | 0.8 | V |
| $\mathrm{I}_{\mathrm{OL}}$ | Low-level output current | -4 | mA |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | mA |  |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDTIONS |  |  | MIN | TYPt | Max | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| 1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{l}_{\mathrm{OZ}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {cc }}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcC}^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | One input at 3.4 V , | Other inputs at $\mathrm{V}_{C C}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ | $V_{1}=0$, | $f=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| $\mathrm{C}_{0}$ | $V_{0}=0$, | $f=1 \mathrm{MHz}$ |  |  | 8 |  | pF |

[^23]switching characteristics over recommended ranges of supply voltage and operating free－air temperature， $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$（unless otherwise noted）

| PARAMETER | FROM （INPUT） | TO （OUTPUT） | ＇ACT7821－15 | ＇ACT7821－20 | ＇ACT7821－25 | ＇ACT7821－40 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX | MIN MAX | MIN MAX | MIN MAX |  |
| $f_{\text {max }}$ | CLKA or CLKB |  | 67 | 50 | 40 | 25 | MHz |
| $t_{\text {pd }}$ | CLKA $\uparrow$ | A0－A31 | 12 | 13 | 15 | 17 | ns |
|  | CLKB $\dagger$ | B0－B31 | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | IRA | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | IRB | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | ORA | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | ORB | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | $\overline{\text { AFA }}$ | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | $\overline{\mathrm{AFB}}$ | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | $\overline{\text { AEA }}$ | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | AEB | 12 | 13 | 15 | 17 |  |
| tPHL | CLKA $\dagger$ | MBFT | 11 | 12 | 14 | 16 | ns |
| ¢ PLH | CLKB $\dagger$ |  | 11 | 12 | 14 | 16 |  |
| $\dagger_{\text {PHL }}$ | CLKB $\dagger$ | MBF2 | 11 | 12 | 14 | 16 | ns |
| tply | CLKA ${ }^{\text {¢ }}$ |  | 11 | 12 | 14 | 16 |  |
| $t_{\text {pd }}$ | MBA | A0－A31 | 11 | 12 | 14 | 16 | ns |
|  | MBB | B0－B31 | 11 | 12 | 14 | 16 |  |
| $\dagger_{\text {¢HL }}$ | RST1 | $\overline{\text { AEB }}$ |  |  |  |  | ns |
|  | RST2 | $\overline{\text { AEA }}$ |  |  |  |  |  |
| ${ }_{\text {tplH }}$ | RSTT | $\overline{\text { AFA }}$ |  |  |  |  | ns |
|  | RST2 | $\overline{\mathrm{AFB}}$ |  |  |  |  |  |
| trim | RSTT | MBFT |  |  |  |  | ns |
|  | AST2 | MBF2 |  |  |  |  |  |
| $t e n$ | CSA，W／RA | A0－A31 |  |  |  |  | ns |
|  | CSB，W／RB | B0－B31 |  |  |  |  |  |
| $t_{\text {dis }}$ | CSA，W／RA | A0－A31 |  |  |  |  | ns |
|  | CSB，W／RB | B0－B31 |  |  |  |  |  |

- Free-Running CLKA and CLKB May Be Asynchronous or Coincident
- Two Independent $512 \times 36$ Clocked FIFOs Buffering Data in Opposite Directions
- Mailbox Bypass Register for Each FIFO
- Programmable Almost Full and Almost Empty Flags
- Microprocessor Interface Control Logic
- IRA, ORA, AEA, and AFA Flags Synchronized by CLKA
- IRB, ORB, $\overline{A E B}$, and $\overline{A F B}$ Flags Synchronized by CLKB
- Low-Power 0.8-Micron Advanced CMOS Technology
- Supports Clock Frequencies up to 67 MHz
- Fast Access Times of 12 ns
- Available in 132-Pin Quad Flatpack (PQ) or Space-Saving 120-Pin Shrink Quad Flatpack (PCB)


## description

The SN74ACT7822 is a high-speed, low-power CMOS bidirectional clocked FIFO memory. It supports clock frequencies up to 67 MHz and has read access times as fast as 12 ns . Two independent $512 \times 36$ dual-port SRAM FIFOs on board the chip buffer data in opposite directions. Each FIFO has flags to indicate empty and full conditions and two programmable flags (almost full and almost empty) to indicate when a selected number of words is stored in memory. Communication between each port may bypass the FIFOs via two 36-bit mailbox registers. Each mailbox register has a flag to signal when new mail has been stored. Two or more devices may be used in parallel to create wider data paths.
The SN74ACT7822 is a clocked FIFO, which means each port employs a synchronous interface. All data transfers through a port are gated to the low-to-high transition of a continuous (free-running) port clock by enable signals. The continuous clocks for each port are independent of one another and can be asynchronous or coincident. The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and/or buses with synchronous control.

The input ready flag and almost full flag of a FIFO are two-stage synchronized to the port clock that writes data to its array. The output ready flag and almost empty flag of a FIFO are two-stage synchronized to the port clock that reads data from its array. Offsets for the almost full and almost empty flags of both FIFOs can be programmed from port A.

PCB PACKAGE
(TOP VIEW)


## functional block diagram



## Terminal Functions

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A35 | 1/O | Port A data. 36-bit bidirectional data port for side A. |
| AEA | 0 | FIFO2 almost empty flag. Programmable flag synchronized to CLKA. It is low when the number of words in FIFO2 is less than or equal to the selected value. |
| AEB | 0 | FIFO1 almost empty flag. Programmable flag synchronized to CLKB. It is low when the number of words in FIFO1 is less than or equal to the selected value. |
| AFA | 0 | FIFO1 almost full flag. Programmable flag synchronized to CLKA. It is low when the number of empty locations in FIFO1 is less than or equal to the selected value. |
| AFB | 0 | FIFO2 almost full flag. Programmable flag synchronized to CLKB. It is low when the number of empty locations in FIFO2 is less than or equal to the selected value. |
| B0-B35 | 1/0 | Port B data. 36-bit bidirectional data port for side B. |
| CLKA | 1 | Port A clock. CLKA is a continuous clock that synchronizes all data transfers through port A and may be asynchronous or coincident to CLKB. IRA, ORA, $\overline{A F A}$, and $\overline{A E A}$ are all synchronous to the low-to-high transition of CLKA. |
| CLKB | 1 | Port B clock. CLKB is a continuous clock that synchronizes all data transfers through port B and may be asynchronous or coincident to CLKA. IRB, ORB, $\overline{A F B}$, and $\overline{A E B}$ are synchronous to the low-to-high transition of CLKB. |
| CSA | I | PortA chip select. CSA must be low to enable a low-to-high transition of CLKA to read or write data on port A. The A0-A35 outputs are in the high-impedance state when CSA is high. |
| CSB | I | Port B chip select. CSB must be low to enable a low-to-high transition of CLKB to read or write data on port B. The B0-B35 outputs are in the high-impedance state when CSB is high. |
| ENA | 1 | Port A master enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A. |
| ENB | 1 | Port B master enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B. |
| FS1, FS0 | 1 | Flag offset selects. The low-to-high transition of a FIFO's reset input latches the values of FS0 and FS1. If either FS0 or FS1 is high when a reset input goes high, one of three preset values is selected as the offset for the FIFO's almost full and almost empty flags. If both FIFOs are reset simultaneously and both FS0 and FS1 are low when RST1 and RST2 go high, the first four writes to FIFO1 program the almost full and almost empty offsets for both FIFOs. |
| IRA | 0 | FIFO1 input ready flag. IRA is synchronized to the low-to-high transition of CLKA. When IRA is low, FIFO1 is full, and writes to its array are disabled. IRA is set low when FIFO1 is reset and is set high on the second low-to-high transition of CLKA after reset. |
| IRB | 0 | FIFO2 input ready flag. IRB is synchronized to the low-to-high transition of CLKB. When IRB is low, FIFO2 is full, and writes to its array are disabled. IRB is set low when FIFO2 is reset and is set high on the second low-to-high transition of CLKB after reset. |
| MBA | 1 | Port A mailbox select. A high level chooses a mailbox register for a port A read or write operation. When the AO-A35 outputs are active, a high level on MBA selects data from the mail2 register for output, and a low level selects FIFO2 data for output. |
| MBB | I | Port B mailbox select. A high level chooses a mailbox register for a port B read or write operation. When the B0-B35 outputs are active, a high level on MBB selects data from the mail1 register for output, and a low level selects FIFO1 data for output. |
| MBF1 | 0 | Mail1 register flag. MBF1 is set low by the low-to-high transition of CLKA that writes data to the mail1 register. MBF1 is set high by a low-to-high transition of CLKB when a port $B$ read is selected and MBB is high. MBFT is also set high when FIFO1 is reset. |
| MBF2 | 0 | Mail2 register flag. MBF2 is set low by the low-to-high transition of CLKB that writes data to the mail2 register. MBF2 is set high by a low-to-high transition of CLKA when a port A read is selected and MBA is high. MBF2 is also set high when FIFO2 is reset. |
| ORA | 0 | FIFO2 output ready flag. ORA is synchronized to the low-to-high transition of CLKA. When ORA is low, FIFO2 is empty, and reads are disabled. Ready data is present on the output register of FIFO2 when ORA is high. ORA is forced low when FIFO2 is reset and goes high on the third low-to-high transition of CLKA after a word is loaded to empty memory. |

## Terminal Functions (continued)

| PIN NAME | I/O | DESCRIPTION |
| :---: | :---: | :--- |
| ORB | 0 | FIFO1 output ready flag. ORB is synchronized to the low-to-high transition of CLKB. When ORB is low, FIFO1 is empty, <br> and reads are disabled. Ready data is present on the output register of FIFO1 when ORB is high. ORB is forced low <br> when FIFO1 is reset and goes high on the third low-to-high transition of CLLKB after a word is loaded to empty memory. |
| RST1 | I | FIFO1 reset. To reset FIFO1, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must oceur <br> while RST1 is low. The low-to-high transition of RST1 latches tho status of FS0 and FS1 for AFA and AEB offset <br> selection. |
| RST2 | I | FIFO2 reset. To reset FIFO2, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must oceur <br> while RST2 is low. The low-to-high transition of RST2 latches the status of FS0 and FS1 for AFB and AEA offset <br> selection. |
| W/RA | I | Port A write/read select. A high selects a write operation and a low selects a read operation on port A for a low-to-high <br> transition of CLKA. The A0-A35 outputs aro in the high-impedance state when W/RA is high. |
| W/RB | I | Port B write/read select. A low selects a write operation and a high selects a read operation on port B for a low-to-high <br> transition of CLKB. The B0-B35 outputs are in the high-impedance state when W/RB is low. |

## FIFO function

The state of the A0-A35 outputs is controlled by CSA and W/RA. When both CSA and W/RA are low, the outputs are active. The outputs are in the high-impedance state when either CSA or W/RA is high. Data is written to FIFO1 from port A on the low-to-high transition of CLKA when CSA is low, W/RA is high, MBA is low, ENA is high, and the IRA flag is high. Data is read from FIFO2 to the AO-A35 outputs on the low-to-high transition of CLKA when CSA is low, W/RA is low, MBA is low, ENA is high, and the ORB flag is high.

The state of the B0-B35 outputs is controlled by CSB and W/RB. When CSB is low and W/RB is high, the outputs are active. The outputs are in the high-impedance state when either CSB is high or W/RB is low. Data is written to FIFO2 from port B on the low-to-high transition of CLKB when CSB is low, W/RB is low, MBB is low, ENB is high, and the IRB flag is high. Data is read fromFIFO1 to the B0-B35 outputs on the low-to-high transition of CLKB when CSB is low, W/RB is high, MBB is low, ENB is high, and the ORB flag is high.
The setup and hold time constraints to the port clocks for the chip selects (CSA, CSB) and write/read selects (W/RA, W/RB) are for enabling write and read operations and are not related to high-impedance control of the data outputs. If the master enable signal for a port (ENA or ENB) is set low during a clock cycle, the chip select and write/read select may switch at any time during the cycle to change the state of the data outputs.
Each FIFO flag is two-stage synchronized to a port clock for use as a reliable synchronous control signal. CLKA synchronizes the status of the output ready flag (ORA) and almost empty flag (AEA) of FIFO2 and the input ready flag (IRA) and almost full flag ( $\overline{\mathrm{AFA}}$ ) of FIFO1. CLKB synchronizes the status of the output ready flag (ORB) and almost empty flag ( $\overline{\mathrm{AEB}}$ ) of FIFO1 and the input ready flag (IRB) and almost full flag ( $\overline{\mathrm{A} F B}$ ) of FIFO2.

When the input ready flag (IRA, IRB) of a port is low, the FIFO receiving input from the port is full, and writes are disabled to its array. When the output ready flag (ORA, ORB) of a port is low, the FIFO that outputs data to the port is empty, and reads from its memory are disabled. The first word loaded to an empty memory is sent to the FIFO's output register when the port's output ready flag is asserted (high). When the memory is read empty and the output ready flag is forced low, the last valid data remains on the FIFO outputs until the output ready flag is asserted (high) again. In this way, a high on the output ready flag indicates that new data is present on the FIFO outputs.

## mailbox registers

A 36-bit word may be exchanged between ports and circumvent the normal FIFO path. The mailbox select inputs (MBA, MBB) choose between a mail register and a FIFO for a port data transfer operation. A0-A35 data is written to the mail1 register on a low-to-high transition of CLKA when CSA is low, W/RA is high, ENA is high, and MBA is high. B0-B35 data is written to the mail2 register on a low-to-high transition of CLKB when CSB is low, W/RB is low, ENB is high, and MBB is high.

When data is written to a mail register, its mailbox flag (MBF1, MBF2) is set low. The MBF1 flag is set high on a low-to-high transition of CLKB when a read is selected for port B and the MBB input is high. The MBF2 flag is set high on a low-to-high transition of CLKA when a read is selected for port A and the MBA input is high. The data in a mailbox register remains intact after it is read and changes only when new data is writtento the register. When a port's data output registers are active, a high on the mailbox enable (MBA or MBB) selects mail data to be output on the port, and a low selects FIFO data for output.

## reset

The FIFO memories of the SN74ACT7822 are reset separately by taking their reset inputs (RST1 or RST2) low for at least four CLKA and four CLKB low-to-high transitions. The reset inputs may be asynchronous with respect to either clock. This resets the internal read and write pointers to their initial locations and forces the FIFOs' AF flags high and IR, OR, and AE flags low. Resetting a FIFO also forces the flag of its parallel mailbox register high. Data outputs of the FIFO and mailbox register are not reset to any specific logic level. Both FIFOs must be reset upon power up.

## almost full and almost empty flags

Three preset values are available for the offsets of the almost full and almost empty flags of a FIFO, or values can be programmed for each flag from port A. The flag select inputs (FS0, FS1) are sampled for each FIFO by the low-to-high transition of its reset input. If the values of FS0 and FS1 select a flag default value at the time of the rising edge of RST1 or RST2, the default value is set as the offset for the almost full and almost empty flags of the FIFO.
To program the almost full and almost empty flags of FIFO1 and FIFO2, both FIFOs should be reset simultaneously with FSO and FS1 low during the low-to-high transition of the reset signals. After this reset cycle, IRA is forced high on the second low-to-high transition of CLKA, but IRB remains low until the programming is
 offsets may be programmed from 1 to 508. The IRB flag is asserted high by the second CLKB low-to-high transition after the $\overline{\mathrm{AFB}}$ offset is programmed. The fifth write to FIFO1 stores the first word in its memory array.
An almost empty flag is low when the number of 36 -bit words stored in its FIFO is less than or equal to the flag's offset value. An almost full flag is low when the number of empty locations left in its FIFO is less than or equal to the flag's offset value. Data in the output register of a FIFO has been read from memory, and its previous location is free.

FLAG PROGRAMMING TABLE

| FS1 | FSO | RSTi | RST2 | FIFO1 OFFSET | FFO2 OFFSET |
| :---: | :---: | :---: | :---: | :---: | :---: |
| H | H | $\uparrow$ | X | 64 | X |
| H | H | X | $\uparrow$ | X | 64 |
| H | L | $\uparrow$ | X | 16 | X |
| H | L | X | $\uparrow$ | X | 16 |
| L | H | $\uparrow$ | X | 8 | X |
| L | H | X | $\uparrow$ | X | 8 |
| L | L | $\uparrow$ | $\uparrow$ | Programmed from port A | Programmed from port A |

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted) ${ }^{\dagger}$

$\qquad$
Input voltage, $\mathrm{V}_{1}$7 V
Voltage applied to a disabled 3-state output ..... 5.5 V
Operating free-air temperature range ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
$\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

## recommended operating conditions

|  |  | MIN | MAX |
| :--- | :---: | :---: | :---: |
| $V_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5.5 |
| $\mathrm{~V}_{\mathrm{IH}}$ | High-level input voltage | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level input voltage | 2 | V |
| $\mathrm{IOH}_{\mathrm{OH}}$ | High-level output current | $\mathbf{V}$ |  |
| $\mathrm{IOL}_{\mathrm{OL}}$ | Low-level output current | 0.8 | V |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | mA |  |

electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITIONS |  |  | MIN | TYP ${ }^{\text { }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\mathrm{O}}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| I | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz | $\mathrm{V}_{C C}=5.5 \mathrm{~V}_{1}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lc | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{C C}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta l_{\text {cC }}{ }^{\text {s }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | Ons input at 3.4 V , | Other inputs at $\mathrm{V}_{\mathrm{CC}}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ | $\mathrm{V}_{1}=0$, | $f=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| $\mathrm{C}_{0}$ | $\mathrm{V}_{0}=0$, | $f=1 \mathrm{MHz}$ |  |  | 8 |  | pF |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\mathbf{s}}$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{Cc}}$.
switching characteristics over recommended ranges of supply voltage and operating free－air temperature， $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$（unless otherwise noted）

| PARAMETER | FROM （INPUT） | TO （OUTPUT） | ＇ACT7822－15 | ＇ACT7822－20 | ＇ACT7822－25 | ＇ACT7822－40 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX | MIN MAX | MIN MAX | MIN MAX |  |
| $f_{\text {max }}$ | CLKA or CLKB |  | 67 | 50 | 40 | 25 | MHz |
| $t_{\text {pd }}$ | CLKA ${ }^{\text {a }}$ | AO－A35 | 12 | 13 | 15 | 17 | ns |
|  | CLKB $\dagger$ | B0－B35 | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | IRA | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | IRB | 12 | 13 | 15 | 17 |  |
|  | CLKA ${ }^{\text {a }}$ | ORA | 12 | 13 | 15 | 17 |  |
|  | CLKB ${ }^{\text {a }}$ | ORB | 12 | 13 | 15 | 17 |  |
|  | CLKA ${ }^{\text {a }}$ | AFA | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | $\overline{\text { AFB }}$ | 12 | 13 | 15 | 17 |  |
|  | CLKA ${ }^{\text {a }}$ | AEA | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | AEB | 12 | 13 | 15 | 17 |  |
| ¢ HL | CLKA ${ }^{\text {a }}$ | MBFT | 11 | 12 | 14 | 16 | ns |
| ${ }_{4}$ | CLKB $\dagger$ |  | 11 | 12 | 14 | 16 |  |
| ¢ ${ }^{\text {PLL }}$ | CLKB ${ }^{\text {d }}$ | MBF2 | 11 | 12 | 14 | 16 | ns |
| ${ }_{\text {¢ }}^{\text {LH }}$ | CLKA ${ }^{\text {a }}$ |  | 11 | 12 | 14 | 16 |  |
| $t_{p o}$ | MBA | A0－A35 | 11 | 12 | 14 | 16 | ns |
|  | MBB | B0－B35 | 11 | 12 | 14 | 16 |  |
| ${ }_{\text {tr }}^{\text {HL }}$ | RST1 | $\overline{\text { AEB }}$ |  |  |  |  | ns |
|  | RST2 | $\overline{\text { AEA }}$ |  |  |  |  |  |
| t＋u | RSTT | AFA |  |  |  |  | ns |
|  | RST2 | $\overline{\text { AFB }}$ |  |  |  |  |  |
| tPLH | RSTT | MBFT |  |  |  |  | ns |
|  | RST2 | MBF2 |  |  |  |  |  |
| ton | CSA，W／RA | A0－A35 |  |  |  |  | ns |
|  | CSB，W／RB | B0－B35 |  |  |  |  |  |
| $t_{\text {dis }}$ | CSA，W／RA | A0－A35 |  |  |  |  | ns |
|  | CSB，W／RB | B0－B35 |  |  |  |  |  |

- Member of the Texas Instruments Widebus ${ }^{\text {™ }}$ Family
- Free-Running CLKA and CLKB May Be Asynchronous or CoIncldent
- $1024 \times 36$ Clocked FIFO Buffering Data From Port A to Port B
- Retransmit Capabillty
- Hallbox Reglater In Each Directlon
- Programmable Almost Full and Almost Empty Flags
- MIcroprocessor Interface Control Loglc
- IR and AF Flags Synchronized by CLKA
- OR and $\overline{A E}$ Flags Synchronized by CLKB
- Low-Power 0.8-MIcron Advanced CMOS Technology
- Supports Clock Frequencles up to 67 MHz
- Fast Access Times of 12 ns
- Avallable In 132-PIn Quad Flatpack (PQ) or Space-Saving 120-PIn Shrink Quad Flatpack (PCB)


NC - No internal connection

Widebus + is a trademark of Texas Instruments Incorporated.

## description

The SN74ACT7823 is a high－speed，low－power CMOS clocked FIFO memory．It supports clock frequencies up to 67 MHz and has read access times as fast as 12 ns ．The $1024 \times 36$ dual－port SRAM FIFO buffers data from port A to port B．The FIFO memory has retransmit capability，which allows previously read data to be accessed again．The FIFO has flags to indicate empty and full conditions and two programmable flags（almost full and almost empty）to indicate when a selected number of words is stored in memory．Communication between each port may take place with two 36－bit mailbox registers．Each mailbox register has a flag to signal when new mail has been stored．Two or more devices may be used in parallel to create wider data paths．

The SN74ACT7823 is a clocked FIFO，which means each port employs a synchronous interface．All data transfers through a port are gated to the low－to－high transition of a continuous（free－running）port clock by enable signals．The continuous clocks for each port are independent of one another and can be asynchronous or coincident．The enables for each port are arranged to provide a simple bidirectional interface between microprocessors and／or buses with synchronous control．

The input ready flag（IR）and almost full flag（AF）of the FIFO are two－stage synchronized to CLKA．The output ready flag（OR）and almost empty flag（AE）of the FIFO are two－stage synchronized to CLKB．Offsets for the almost full and almost empty flags of the FIFO can be programmed from port A．

## functional block diagram



# SN74ACT7823 <br> 1024 X 36 CLOCKED FIRST-IN, FIRST-OUT MEMKORY 

JUNE 1992

## FIFO function

The state of the AO-A35 outputs is controlled by CSA and W/RA. When both CSA and W/RA are low, the outputs are active. The outputs are in the high-impedance state when either CSA or W/RA is high. Data is written to the FIFO on the low-to-high transition of CLKA when CSA is low, W/RA is high, MBA is low, ENA is high, and the IR flag is high.
The state of the B0-B35 outputs is controlled by CSB and W/RB. When CSB is low and W/R B is high, the outputs are active. The outputs are in the high-impedance state when either CSB is high or W/RB is low. Data is read from the FIFO to the BO-B35 outputs on the low-to-high transition of CLKB when CSB is low, W/RB is high, MBB is low, ENB is high, and the ORB flag is high.
The setup and hold time constraints to the port clocks for the chip selects (CSA, CSB) and write/read selects (W/RA, W/RB) are for enabling write and read operations and are not related to high-impedance control of the data outputs. If the master enable signal for a port (ENA or ENB) is set low during a clock cycle, the chip select and read/write select may switch at any time during the cycle to change the state of the data outputs.
Each FIFO flag is two-stage synchronized to a port clock for use as a reliable synchronous control signal. CLKA synchronizes the status of the input ready flag (IR) and almost full flag (AF) of the FIFO. CLKB synchronizes the status of the output ready flag (OR) and almost empty flag ( $\overline{\text { AE }}$ ) of the FIFO.

When the input ready flag is low, the FIFO is full, and writes are disabled to its array. When the output ready flag is low, the FIFO is empty, and reads from memory are disabled. The first word loaded to an empty memory is sent to the FIFO's output register when the output ready flag is asserted (high). When the memory is read empty and the output ready flag is forced low, the last valid data remains on the FIFO outputs until the output ready flag is asserted (high) again. In this way, a high on the output ready flag indicates that new data is present on the FIFO outputs.

## mailbox registers

Bidirectional communication between ports may take place through the mailbox registers. The mailbox-select inputs (MBA, MBB) choose between a mail register and a FIFO for a port data transfer operation. A0-A35 data is written to the mail1 register on a low-to-high transition of CLKA when CSA is low, W/RA is high, ENA is high, and MBA is high. BO-B35 data is written to the mail2 register on a low-to-high transition of CLKB when CSB is low, W/RB is low, ENB is high, and MBB is high.
When data is written to a mail register, its mailbox register flag (MBF1, MBF2) is set low. The MBF1 flag is set high on the low-to-high transition of CLKB when a read is selected for port B and the MBB input is high. The MBF2 flag is set high on the low-to-high transition of CLKA when a read is selected for port A and the MBA input is high. The data in a mailbox register remains intact after it is read and changes only when new data is written to the register. When the data outputs of port B are active, a high on MBB selects mail1 data to be output on the port, and a low selects FIFO data for output.

## reset

The SN74ACT7823 is reset by taking the reset input (RST) low for at least four CLKA and four CLKB low-to-high transitions. The reset input may be asynchronous with respect to either clock. This resets the internal read and write pointers to the initial location and forces the FIFO's AF flag high and IR, OR, and AE flags low. Resetting the device also forces the mailbox register flags (MBFT, MBF2) high. Data outputs of the FIFO and mailbox registers are not reset to any specific logic level. The device must be reset upon power up.

## JUNE 1992

## almost full and almost empty flags

Three preset values are available for the offsets of the almost full and almost empty flags, or offsets can be programmed for each flag from port A. The flag select inputs (FSO, FS1) are sampled by the low-to-high transition of the reset input. If the values on FS0 and FS1 select a flag preset value at the time of the rising edge of RST, the preset value is set as the offset for the almost full and almost empty flags (see flag programming table).

To program the almost full and almost empty flags from port A, the flag select inputs must be low during the low-to-high transition of the reset signal. After this reset cycle, the first write to the FIFO programs the AE offset, and the second write programs the $\overline{A F}$ offset. Flag offset values may be programmed from 1 to 1000 . The third write to the FIFO stores the first word in its memory array.

The almost empty flag is low when the number of 36 -bit words stored in the FIFO is less than or equal to the flag's offset value. An almost full flag is low when the number of empty locations left in the FIFO is less than or equal to the flag's offset value. Data in the output register of the FIFO has been read from memory, and its previous location is free.

FLAG PROGRAMMING TABLE

| FS1 | FS0 | RST | AF and $\overline{\text { AE }}$ |
| :---: | :---: | :---: | :---: |
| H | H | $\uparrow$ | 64 |
| H | L | $\uparrow$ | 16 |
| L | H | $\uparrow$ | 8 |
| L | L | $\uparrow$ | Programmed from port A |

## retransmit

A selected portion of data in the FIFO may be read repeatedly when it is put in retransmit mode. The FIFO is put in retransmit mode by asserting the retransmit mode input (RTM) high during a low-to-high transition of CLKB. If valid data is present on the bus at this time, it is the first data to be output when retransmit is activated. The FIFO is in retransmit mode until RTM is low during a low-to-high transition of CLKB. While the FIFO is in retransmit mode, it is filled by the 1024th word written after the first retransmit data.

When the FIFO is in the retransmit mode, a high level on the RFM input enables a low-to-high transition of CLKB to begin a retransmit. This clock edge resets the read pointer to the first retransmit location and outputs the first retransmit data. Data may be retransmitted from the selected starting position repeatedly. A new retransmit starting position is selected after taking the FIFO out of retransmit mode by putting the device in retransmit mode again.

## SN74ACT7823 1024 X 36 CLOCKED FIRST-IN, FIRST-OUT MEMORY

## Terminal Functlons

| PIN NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| A0-A35 | 1/0 | Port A data. 36-bit bidirectional data port for sido A . |
| $\overline{\text { AE }}$ | 0 | Almost empty flag. Programmable flag synchronized to CLKB. It is low when the number of words in the FIFO is less than or equal to the selected value. |
| AF | 0 | Almost full flag. Programmable flag synchronized to CLKA. It is low when the number of empty locations in the FIFO is less than or equal to the selected value. |
| B0-B35 | 1/0 | Port B data. 36-bit bidirectional data port for side B. |
| CLKA | 1 | Port A clock. CLKA is a continuous clock that synchronizes all data transfers through port A and may be asynchronous or coincident to CLKB. IR and $\overline{A F}$ are synchronous to the low-to-high transition of CLKA. |
| CLKB | 1 | Port B clock. CLKB is a continuous clock that synchronizes all data transfers through port B and may be asynchronous or coincident to CLKA. OR and $\overline{A E}$ are synchronous to the low-to-high transition of CLKB. |
| CSA | 1 | Port A chip select. CSA must be low to enable a low-to-high transition of CLKA to read or write data on port A. The AO-A35 outputs are in the high-impedance state when CSA is high. |
| CSB | 1 | Port B chip select. CSB must be low to enable a low-to-high transition of CLKB to read or write data on port B. The B0-B35 outputs are in the high-impedance state when CSB is high. |
| ENA | 1 | Port A master enable. ENA must be high to enable a low-to-high transition of CLKA to read or write data on port A . |
| ENB | 1 | Port B master enable. ENB must be high to enable a low-to-high transition of CLKB to read or write data on port B. |
| FS1, FS0 | 1 | Flag offset selects. The low-to-high transition of RST latches the states of FS0 and FS1. If either FS0 or FS1 is high when the reset input goes high, one of three preset values is selected as the offset for the almost full and almost empty flags. If both FSO and FS1 are low when RST goes high, the first two writes to the FIFO program the almost full and almost empty offsets. |
| IR | 0 | Input ready flag. IR is synchronized to the low-to-high transition of CLKA. When IR is low, the FIFO is full, and writes to its array are disabled. When the FIFO is in retransmit mode, IR indicates when the memory has been filled to the point of the retransmit data and prevents further writes. IR is set low during reset and is set high on the second low-to-high transition of CLKA after reset. |
| MBA | 1 | Port A mailbox select. A high level chooses a mailbox register for a port A read or write operation. |
| MBB | 1 | Port B mailbox select. A high level chooses a mailbox register for a port B read or write operation. When the B0-835 outputs are active, a high level on MBB selects data from the mail1 register for output, and a low level selects FIFO data for output. |
| MBF7 | 0 | Mail1 register flag. MBF-1 is set low by the low-to-high transition of CLKA that writes data to the mail1 register. MBF1 is set high by a low-to-high transition of CLKB when a port B read is selected and MBB is high. MBFT is set high by a reset. |
| MBF2 | 0 | Mail2 register flag. MBF2 is set low by the low-to-high transition of CLKB that writes data to the mail2 register. MBF2 is set high by a low-to-high transition of CLKA when a port A read is selected and MBA is high. MBF2 is set high by a reset. |
| OR | 0 | Output ready flag. OR is synchronized to the low-to-high transition of CLKB. When OR is low, the FIFO is empty, and reads are disabled. Ready data is present on the output register of the FIFO when OR is high. OR is forced low during the reset and goes high on the third low-to-high transition of CLKB after a word is loaded to empty memory. |
| RFM | I | Read from mark. When the FIFO is in retransmit mode, a high on RFM enables a low-to-high transition of CLKB to reset the read pointer to the retransmit location and output the first selected retransmit data. |
| RST | I | Reset. To reset the device, four low-to-high transitions of CLKA and four low-to-high transitions of CLKB must occur while RST is low. The low-to-high transition of RST latches the status of FS0 and FS1 for AF and AE offset selection. |
| RTM | 1 | FIFO retransmit mode. When RTM is high and valid data is present on the output of the FIFO, a low-to-high transition of CLKB selects the data for the beginning of a retransmit. The selected position remains the initial retransmit point until a low-to-high transition of CLKB occurs while RTM is low, which takes the FIFO out of retransmit mode. |
| W/RA | 1 | Port A write/read select. A high selects a write operation and a low selects a read operation on port A for a low-to-high transition of CLKA. The AO-A35 outputs are in the high-impedance state when W/RA is high. |
| W/RB | I | Port B write/read select. A low selects a write operation and a high selects a read operation on port B for a low-to-high transition of CLKB. The B0-B35 outputs are in the high-impedance state when W/RB is low. |

## 1024 X 36 CLOCKED FIRST-IN, FIRST-OUT MEMORY

JUNE 1992

## recommended operating conditions

|  |  | MIN | MAX |
| :--- | :--- | ---: | :---: |
| $V_{C C}$ | Supply voltage | 4.5 | 5.5 |
| $V_{I H}$ | High-level input voltage | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Low-level Input voltage | 2 | V |
| $\mathrm{IOH}_{\mathrm{OH}}$ | High-level output current | 0.8 | V |
| $\mathrm{IOL}^{\mathrm{OL}}$ | Low-level output current | -4 | mA |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | 8 | mA |

## electrical characteristics over recommended operating free-air temperature range (unless

 otherwise noted)| PARAMETER | TEST CONDTIONS |  |  | MIN | TYPt | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |  | 2.4 |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  | 0.5 | V |
| 1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| loz | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or 0 |  |  |  | $\pm 5$ | $\mu \mathrm{A}$ |
| lcc | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=\mathrm{V}_{\text {cc }}-0.2 \mathrm{~V}$ or 0 |  |  |  | 400 | $\mu \mathrm{A}$ |
| $\Delta \mathrm{lcc}^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | One input at 3.4 V , | Other inputs at $\mathrm{V}_{\text {CC }}$ or GND |  |  | 1 | mA |
| $\mathrm{C}_{i}$ | $V_{1}=0$, | $f=1 \mathrm{MHz}$ |  |  | 4 |  | pF |
| $\mathrm{C}_{0}$ | $V_{0}=0$, | $\mathrm{f}=1 \mathrm{MHz}$ |  |  | 8 |  | pF |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$
switching characteristics over recommended ranges of supply voltage and operating free-air temperature, $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ (unless otherwise noted)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | 'ACT7823-15 | 'ACT7823-20 | 'ACT7823-25 | 'ACT7823-40 | UNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX | MIN MAX | MIN MAX | MIN MAX |  |
| $\mathrm{f}_{\text {max }}$ | CLKA or CLKB |  | 67 | 50 | 40 | 25 | MHz |
| $t_{\text {Pd }}$ | CLKB $\uparrow$ | B0-B35 | 12 | 13 | 15 | 17 | ns |
|  | CLKA ${ }_{\text {¢ }}$ | IR | 12 | 13 | 15 | 17 |  |
|  | CLKB ${ }^{\text {P }}$ | OR | 12 | 13 | 15 | 17 |  |
|  | CLKA $\dagger$ | $\overline{\mathrm{AF}}$ | 12 | 13 | 15 | 17 |  |
|  | CLKB $\dagger$ | $\overline{A E}$ | 12 | 13 | 15 | 17 |  |
| $\mathrm{t}_{\mathrm{PHL}}$ | CLKA ${ }^{\text {a }}$ | MBFT | 11 | 12 | 14 | 16 | ns |
| ${ }_{\text {tPLH }}$ | CLKB $\dagger$ |  | 11 | 12 | 14 | 16 |  |
| $\mathrm{t}_{\mathrm{pHL}}$ | CLKB $\uparrow$ | MBF2 | 11 | 12 | 14 | 16 | ns |
| 4 | CLKA $\dagger$ |  | 11 | 12 | 14 | 16 |  |
| $\mathrm{t}_{\mathrm{pd}}$ | MBB | B0-B35 | 11 | 12 | 14 | 16 | ns |
| triL $^{\text {che }}$ | RST | $\overline{\bar{A} E}$ |  |  |  |  | ns |
| telh | RST | $\overline{\mathrm{AF}}$ |  |  |  |  | ns |
|  |  | MBF7, MBF2 |  |  |  |  |  |
| ten | CSA, W/RA | A0-A35 | 10 | 11 | 12 | 13 | ns |
|  | CSB, W/RB | B0-B35 | 10 | 11 | 12 | 13 |  |
| $\mathrm{t}_{\text {dis }}$ | CSA, W/RA | A0-A35 | 10 | 11 | 12 | 13 | ns |
|  | CSB, W/RB | B0-B35 | 10 | 11 | 12 | 13 |  |


| General Information | 1194x |
| :---: | :---: |

Unidirectional Cloclied FiFos ..... $2 \pi$ ..... 3


Bidirectional Clocled FIFOs
Bidirectional FiFOs

Product Previews6
Articles and Application Notes ..... 7.
Mechanical Data ..... 8 ${ }^{4}$

# 64-Byte FiFOs SN74ALS2232A and SN74ALS2233A 

# First-In, First-Out Technology 

Kam Kittrell<br>General Purpose Logic - Semiconductor Group Texas instruments

## 64-Byte FIFOs SN74ALS2232A and SN74ALS2233A

## Introduction

First-In, First-Out memories (FIFOs) are irreplaceable bus logic when interfacing two asynchronous systems or controlling data flow paths. The SN74ALS2232A $64 \times 8$ and SN74ALS2233A $64 \times 9$ FIFOs from Texas Instruments offer high-performance buffering for shallow-word-depth applications. These devices are produced in TI's IMPACT-X bipolar technology and are packaged in 24- or 28-pin DIP and 28-pin PLCC.

## Clocking

The SN74ALS2232A and SN74ALS2233A FIFOs are organized with dual-port SRAM, write addressing, read addressing, and address comparator logic for flag generation. As opposed to shift-register architectures, the dual-port SRAM architecture allows data to pass from the input to the output of an empty FIFO with a minimal delay independent of FIFO depth and also allows high-frequency data transfers.
The load clock (LDCK) and unload clock (UNCK) inputs of a FIFO are low-to-high-edge triggered clocks that initiate memory operations and control addressing increments. By allowing a single clock edge to activate action on the circuit and automating the memory timing and address increment timing, data transfer control is made easy. Only the rising edge of each device clock must be maintained for precise timing, while the falling edge may vary greatly within the cycle without altering performance (see Figure 1). This is a feature of all TI FIFOs with dual-port SRAM architecture.

$$
t_{w 1}=12 \mathrm{~ns} \quad t_{w 2}=13 \mathrm{~ns}
$$

Figure 1. SN74ALS2232A and SN74ALS2233A Clock Input Clrcult

## Noise Control

Ground bounce is a voltage transient produced by current surges through the ground pin. Due to bond wire, lead, and board parasitic inductance, changes in the ground current will result in a voltage forced on ground. A ground voltage transient peak-to-peak value increases with an increase in the number of outputs switching from high to low, an increase in output load capacitance, and an increase in $\mathrm{V}_{\mathrm{CC}}$. The chip's ground voltage can also be influenced by following negative undershoot voltages applied to inputs and outputs.

The inputs of a digital device are referenced to its ground. Large voltage transients applied to ground can cause threshold switching by steady-state low or high levels applied to an input. For the SN74ALS2232A and SN74ALS2233A, an unwanted threshold crossing creates the most problems on the rising-edge-triggered clocks, LDCK and UNCK, by generating false clocks. The results of false clocking produced by high ground noise levels can appear as multiple storage of data words, missed data words in a stream, or the inability to empty the device.

By placing the GND pin of the SN74ALS2232A and SN74ALS2233A in the center of the DIP and PLCC packages to employ the shortest bond wire and lead path, package inductance and ground bounce effects are minimized. Ground bounce can be minimized further by decoupling the power planes of the board in close proximity to the device with a capacitor (about $0.1 \mu \mathrm{~F}$ ). Undershoot voltages on the inputs and outputs of a device are controlled by eliminating voltage reflections due to transmission line effects.

In an unusually noisy environment such as a wire-wrap prototype wherein it is difficult to control input and output undershoot voltages, generating the LDCK and UNCK inputs as inactive high reduces the possibility of false clocking. Figure 2 shows the one-shot circuit for the LDCK and UNCK inputs. When the input to the one-shot is at a steady-state low logic level, a very quick voltage transient (about 3 to 5 ns ) caused by ground noise can trigger a pulse on the one-shot output. A low-noise pulse of the same duration is less likely to pass through the circuit if the input is at a steady-state high logic level.


Figure 2. SN74ALS2232A and SN74ALS2233A Clock Input Circult

## Applications

## FIFO Flags

The FULL and EMPTY flags are provided to indicate FIFO boundary conditions and prevent overflow and underflow conditions from occurring. The flags are the outputs of a circuit that compares the write and read addresses of the dual-port SRAM. In cases where the LDCK and UNCK inputs operate asynchronously to each other, these signals are useful for read and write control after synchronization. Figure 3 is an example of flag synchronization for clock control. The FULL flag is synchronized to LDCK to indicate when the device has exited a full state and prevent additional memory write attempts when is is filled again. Likewise, the EMPTY flag is synchronized to UNCK to indicate when the device is no longer empty and prevent memory read attempts when it is empty.
In addition to the $\overline{\text { FULL }}$ and EMPTY flags, the SN74ALS2233A also has a HALF-FULL flag that is high when 32 or more words are contained in memory and an AF/AE flag (almost full/almost empty) that is high when eight or less locations in memory are filled or eight or less empty locations are available. These flags are useful for signaling when blocks of data may be transferred through the FIFO in consecutive clock cycles.


Figure 3. Clock Generation WIth Two-Stage Synchronization of FULL and EMPTY

## Bus Conversion

Shallow FIFO memories are often used when data is transferred between a 16 - or 32 -bit bus to an 8 -bit memory or peripheral device. Figure 4 is an example in which two SN74ALS2232A or two SN74ALS2233A devices are used for converting (folding) a 16-bit bus into an 8-bit bus. The three-state outputs of the FIFOs are used to "ping-pong" between devices. This configuration can be expanded using similar control to accomodate a 32 -bit input bus with an 8 - or 16 -bit output bus. The FIFOs allow data to be transferred in burst mode from the input bus without being slowed by the smaller output bus. With the same folding logic designed to control the input of the FIFOs, data may be transferred from an 8- or 16 -bit bus and unfolded to a 16 - or 32 -bit bus.


Figure 4. Bus Folding Logle

# $1 \mathrm{~K} \times 9 \times 2$ Asynchronous FIFOs SN74ACT2235 and SN74ACT2236 

# First-In, First-Out Technology 

Kam Kittrell<br>Semiconductor Group<br>Texas Instruments

## $1 K \times 9 \times 2$ Asynchronous FIFOs SN74ACT2235 and SN74ACT2236

## Introduction

Texas Instruments designed the 'ACT2235 to meet a variety of synchronous or asynchronous bidirectional applications. Two $1 \mathrm{~K} \times 9$ First-In, First-Out (FIFO) memories are arranged in parallel to buffer data in opposite directions. Data ports may also exchange real-time data. Three-state control (GAB, GBA) and real-time/stored data select (SAB, SBA) match the popular '652 transceiver logic. Produced in TI's EPIC CMOS process, the inputs accept TTL voltage levels. An option to the 'ACT2235 is the 'ACT2236, which has ' 646 transceiver control (DIR, $\bar{G}$ ).


Figure 1. SN74ACT2235 Block Dlagram

## FIFO Control

The 'ACT2235 consists of two FIFO memories, FIFOA and FIFOB. Both FIFOs can be accessed from either port A or port B. Four control signal lines (GAB, GBA, SAB and SBA) control the eight possible data flow paths through the device (these data paths are illustrated in the device data sheet). Each FIFO has a load clock (LDCK) that writes data into memory and an unload clock (UNCK) that reads the data in the same order it was written. Both clocks are positive-edge-triggered and may operate asynchronously to one another. The first word loaded into an empty FIFO propagates directly to the outputs, and the EMPTY flag switches high. EMPTY represents the valid state of data on the outputs (data is valid when EMPTY is high and invalid when EMPTY is low). EMPTY may be used to enable an UNCK pulse when it is synchronized with the bus that will read the data. FULL can qualify a LDCK pulse in the same way.
Figure 2 is an example of an 'ACT2235 interfacing two asynchronous systems. Each system provides a read enable, write enable, and free-running clock. A flag must be synchronized to the system clock to use it as device clock control. Although the flag's high-to-low transition is synchronous to the clock it enables, the low-to-high transition is asynchronous. The output of the latch qualifying this transition can go metastable when bistable (setup and hold) conditions are not met. An output is metastable if it lingers between the specified $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ levels. Two-stage synchronization of the flags reduces the probability of a metastable-induced failure.


Note: Two devices are used for 18-bit width expansion.
Flgure 2. Controlling the 'ACT2235 Using a Clock, Write Enable, and Read Enable Per System

## High-Frequency Applications

A unique feature of the 'ACT2235 is that the UNCK cycle time may be less than the device access time. The 'ACT2235-20 has a maximum LDCK and UNCK frequency of 50 MHz ( 20 ns cycle time) and a $25-\mathrm{ns}$ maximum access time ( $\mathrm{t}_{\mathrm{pd}}$ UNCKA or UNCKB to B bus or A bus). In a series of FIFO reads, the next access may be initiated before the present one is complete. The largest concern associated with this technique is the length of time data will be guaranteed as valid. Minimum access time from the rising edge of UNCK may also be viewed as minimum data hold time on the bus. Timing for this relationship is shown in Figure 3. Valid data time from the 'ACT2235 over the commercial temperature range and $\pm 10 \% \mathrm{~V}_{\mathrm{CC}}$ is given by:

$$
\begin{equation*}
t_{v}=t_{\text {cycle }}+t_{p d} \min -t_{p d} \max \tag{1}
\end{equation*}
$$

Data from an 'ACT2235 operating at a $50-\mathrm{MHz}$ clock frequency is valid for at least 7 ns . This allows a 4-ns setup and 1 -ns hold with 2 ns of tolerance to the next device in the data path.


For 'ACT2235-20: $t_{p d} m i n=12 n s, t_{p d} \max =25 n s, t_{v}=7 n s$
Figure 3. Read Operation When Cycle Time is Less Than Access Time

## Programmable Flags

Data is often transmitted in packets, where each packet is a specific number of bytes and must be delivered in an unbrokenstream. A FIFO transmitting packeted data needs a flag that shows the number of bytes stored. This keeps from breaking the transmission of a packet due to an empty or full condition. The 'ACT2235 has a programmable almost full/almost empty flag for this application. The AF/AEA offset value ( X ) and the AF/AEB offset value ( Y ) are programmed separately. AF/AEA is high when FIFOA contains $X$ or fewer words or ( 1024 minus $X$ ) or more words. It is low when FIFOA contains between ( $X+1$ ) and ( 1023 minus $X$ ) words. AF/AEB functions in the same manner with its programmed value, Y. The programmed or default value of 256 is chosen during a reset of each FIFO.

The device's internal flag programming logic is illustrated in Figure 4. Programming the AF/AE flag value for each FIFO is done with the define flag inputs ( $\overline{\mathrm{DAF}}, \overline{\mathrm{DBF}}$ ) and resets ( $\overline{\mathrm{RSTA}}, \overline{\mathrm{RSTB}}$ ). Define flag inputs are negative-edge-triggered clocks that store input data to a register. If $\overline{\mathrm{DAF}}$ or $\overline{\mathrm{DBF}}$ is low when the rising edge of $\overline{\mathrm{RSTA}}$ or RSTB occurs, the registered value is used for the FIFO's AF/AE flag. The flag uses the default value of 256 if DAF or $\overline{\mathrm{DBF}}$ is high during the rising edge of $\overline{\mathrm{RSTA}}$ or $\overline{\mathrm{RSTB}}$.


Figure 4. AF/AEA Flag Programming Logic for FIFOA
Programming both flag offset values from one port is possible using real-time select. Figure 5 is a timing example of programming $A F / A E B$ from port $A$. To program the $A F / A E B$ offset value $(Y)$ from port $A$, the binary value for $Y$ is on $A 0-A 8, S A B$ is low, and GAB is high. With this configuration, the port $A$ data appears on the inputs of FIFOB, and a falling edge of $\overline{\mathrm{DBF}}$ stores the Y value.


Figure 5. Programming AF/AEB Flag of FIFOB From Port A

## Output Drive

Charging and discharging the load of a bus with acceptable speed requires high device output drive. The I/O ports of the ' ACT 2235 provide a $16-\mathrm{mA} \mathrm{I}_{\mathrm{OL}}$ and an $8-\mathrm{mA} \mathrm{I}_{\mathrm{OH}}$ for this task.

Most memory devices have low drive capability and require buffers to interface to a bus. Large output transistors that support high current are not used because in doing so, the rate of change of current with respect to time ( $\mathrm{di} / \mathrm{dt}$ ) increases. When several outputs switch high or low simultaneously, the rate of change of current through ground and $\mathrm{V}_{\mathrm{CC}}$ lines multiplies. Voltage transients on the power lines are given by:

$$
\begin{equation*}
\mathrm{v}=-\mathrm{L} \times \mathrm{di} / \mathrm{dt} \tag{2}
\end{equation*}
$$

where $L$ equals the inductance of the bond wire and package lead.
The 'ACT2235 provides a twofold solution to allow high output current capability for quickly charging and discharging bus loads with low noise. One solution is to reduce the inductance of ground and $\mathrm{V}_{\mathrm{CC}}$ lines. The 'ACT2235 has four GND and two $\mathrm{V}_{\mathrm{CC}}$ pins in parallel. The resulting ground inductance is about $1 / 4$ that of a single connection, and $\mathrm{V}_{\mathrm{CC}}$ inductance is divided in half.
Reducing di/dt per output transistor is another way to minimize voltage transients. TI's patented Output Edge Control (OEC) design divides a large transistor into smaller segments that turn on in series and turn off simultaneously. OEC lowers di/dt, maintains a quick voltage transition through threshold, and avoids the high power consumed when gradually turned off. ${ }^{1}$

The result of a $V_{\text {OLP }}$ test on the 'ACT2235 is shown in Figure $6 . V_{\text {OLP }}$ is a measurement of ground voltage noise when all outputs of a bus are switched from high to low. Eight of nine outputs of a bus are switched, and the peak voltage rise of the steady-state low output is measured. Maximum ground voltage rise is only 700 mV . Also note that the output fall time is less than 3 ns with a $50-\mathrm{pF}$ load.

[^24]

Note: 8 bus outputs switching; 1 remains low
Figure 6

## Conclusion

The 'ACT2235 and 'ACT2236provide several advantages for high-speed asynchronousbus interfacing. Simple control logic offers great design flexibility. Programmable flags may be used for data flow optimization. High output drive for bus loading is balanced with noise reduction through package and circuit design.

# FAFO Solutions <br> for Increasing Clock Rates and Data Widths 

# First-In, First-Out Technology 

Kam Kittrell<br>General Purpose Logic - Semiconductor Group<br>Texas Instruments

## FIFO Solutions for Increasing Clock Rates and Data Widths

## Introduction

Steady increases in microprocessor operating frequencies and bus widths over recent years have challenged system designers to find FIFO memories that meet their needs. To assist the designer, new FIFOs from Texas Instruments are available with features that complement these microprocessor trends.
Higher data transfer rates have dictated the need for FIFOs to evolve into clocked architecture wherein data is moved in and out of the device with synchronous controls. Each synchronous control of the clocked FIFO uses enable signals that synchronize the data exchange to a free-running (continuous clock).

Since the continuous clocks on each port of a clocked FIFO may operate asynchronously to each other, internal status signals indicating when the FIFO is empty or full can change with respect to either clock. To use a status signal for port control, it is synchronized to the port's clock on a clocked FIFO. Synchronization of these signals with flip-flops introduces metastability failures that increase with clock frequency. Texas Instruments uses two-stage flag synchronization to greatly improve reliability.

Higher clock frequencies augment raw speed, but greater bandwidth is also achieved by increasing the data width. Wider data paths can have the associated cost of large board area due to increased package sizes. New compact packages for TI's FIFOs reduce this cost.

## Clocked FIFOs

Clocked FIFOs have become popular for relieving bottlenecks in high-speed data traffic. Data transfers for many systems are synchronized to a central clock with read and write enables. These free-running clocks may be input directly to a clocked FIFO with the same enables controlling its data transfer on the low-to-high transition of the clock.
Reducing the number of clocks keeps the interface simple and easy to manage. Extra logic is needed to produce a gated pulse when using a FIFO that accepts a clock only for a data transfer request. The generated clock signal is a derivative of the master clock with a margin of timing uncertainty. At high clock frequencies, this timing uncertainty is not tolerable, and costly adjustments are needed.
Additional logic is also conserved by implementing flag synchronization on the clocked FIFO. Tracking is done to generate flags that indicate when the memory is empty or full. In many applications, the input and output to the FIFO are asynchronous, and the flag signals must be synchronized for use as control. A read will not be completed on the FIFO if no data is ready, so the EMPTY signal is synchronized to the read clock. This synchronous output ready flag (OR) is useful for controlling read operations. Likewise, the FULL signal is synchronized to the write clock, producing the input ready flag (IR).

## Flag Synchronization

As previously explained, one of the advantages of the clocked FIFO is the on-board synchronization of the EMPTY and $\overline{\text { FULL }}$ status flags when the input and output are asynchronous. In one method of synchronization, a single flip-flop captures the asynchronous flag's value (see Figure 1). With this method, the rising transition of data may violate the flip-flop's set-up time and produce a metastable event (metastability is a malfunction of a flip-flop wherein the latch hangs between high and low states for an indefinite period of time).


Figure 1. Trlggering a Metastable Event With a One-Stage Synchronizer
Once a metastable event is triggered, the probability of the output recovering to a high or low level increases exponentially with increased resolve time $\left(\mathrm{t}_{\mathrm{r}}\right)$. The expected time until the output of a single flip-flop with asynchronous data has a metastable event that lasts $t_{r}$ or longer is characterized by the following mean time between failures (MTBF) equation:

$$
M T B F_{1}=\frac{\exp \left(\frac{t_{r}}{\tau}\right)}{t_{o} f_{c} f_{d}}
$$

where

$$
\begin{aligned}
& \mathrm{t}_{\mathrm{o}}=\text { flip-flop constant representing the time window during which changing data will invoke a failure } \\
& \mathrm{t}_{\mathrm{r}}=\text { resolve time allowed in excess of the normal propagation delay } \\
& \tau=\text { flip-flop constant related to the settling time of a metastable event } \\
& \mathbf{f}_{\mathrm{c}}=\text { clock frequency } \\
& \mathbf{f}_{\mathrm{d}}=\text { asynchronous data frequency. For OR flag analysis, it is the frequency at which data is written to } \\
& \text { empty memory. For IR flag analysis, it is the frequency at which data is read from full memory. }
\end{aligned}
$$

The MTBF decreases as clock and data frequency increase and as the time allowed for a metastable event to settle ( $\mathrm{t}_{\mathrm{r}}$ ) decreases.

Metastability failures are a formidable issue for short clock cycle times. Increasing the clock frequency linearly increases the number of metastable events triggered, but the shortened available resolve time exponentially increases the the failure rate. It is impossible to eliminate the possibility of a metastable event under these conditions, but solutions exist to reliably increase the expected time between failures.


Figure 2. Two-Stage Synchronizer

Texas Instruments increases the metastable MTBF by several orders of magnitude for IR and OR flags by employing two-stage synchronization (see Figure 2). For the output of the second stage to be metastable, the first stage must have a metastable event that lingers until it encroaches upon the setup time of the second stage. Adding another stage to a single flip-flop synchronizer is statistically equivalent to increasing its resolve time by the clock period minus its propagation delay. The mean time between failures for a two-stage synchronizer is given by:

$$
M T B F_{2}=\frac{\exp \left[\frac{t_{r}+\frac{1}{f_{c}}-t_{p}}{\tau}\right]}{t_{o} f_{c} f_{d}}
$$

where

$$
t_{p}=\text { propagation delay of the first flip-flop. }
$$



Figure 3. Storage Oscilloscope Plots Taken Over a 15-Hour Duration
Figure 3 compares the two synchronization methods discussed. Both plots were taken at room temperature and nominal $V_{C C}$ while each data transition violated set-up time. Figure 3(a) shows the performance of an EMPTY flag synchronizer using only one flip-flop, while Figure 3(b) is the IR flag of an SN74ACT7807 with the write clock operating at maximum frequency.

## Compact Packaging

Microprocessor bus widths have continuously doubled every few years to maximize their performance. Bus widths of 32 and 64 bits are commonplace today, whereas they were almost unheard of a few years ago. The downside to the increased bit count is that each subordinate device in the system must match this width with corresponding increases in board size.

New shrink packages for TI's clocked FIFOs provide a solution to this problem. Multiple-byte data paths can be buffered while covering only a fraction of the area of conventional packages. These new FIFO packages are presently available in 56-, 64-, and 80-pin configurations. Dubbed shrink quad flat pack (SQFP), the 64-pin package is used for 9-bit-wide FIFOs, and the 80 -pin package is used for 18 -bit-wide FIFOs. Both SQFP packages have a lead pitch of 0.5 mm . The 56 -pin shrink small-outline package has a 0.025 -inch lead pitch and also houses 18 -bit-wide FIFOs. A variety of TI's FIFOs are offered in these new packages (see Table 1).

Table 1. FIFOs Avallable In Space-Efficlent Packages

| DEVICE | CLOCKED | ORGANIZATION | CLOCK CYCLE <br> TME (ns) | PACKAGES |
| :---: | :---: | :---: | :---: | :---: |
| SN74ACT2235 | No | $1 \mathrm{~K} \times 9 \times 2$ | $20,3040,50$ | 64 SQFP <br> 44 PLCC |
| SN74ACT7802 | No | $1 \mathrm{~K} \times 18$ | $25,40,60$ | 80 SQFP <br> 68 PLCC |
| SN74ACT7811 | Yes | $1 \mathrm{~K} \times 18$ | $15,18,20,25$ | 80 SQFP <br> 68 PLCC |
| SN74ACT7803 <br> SN74ACT7805 <br> SN74ACT7813 | Yes | $512 \times 18$ <br> $256 \times 18$ <br> $64 \times 18$ | $15,20,25,40$ | 56 SSOP |
| SN74ACT7804 <br> SN74ACT806 | No | $512 \times 18$ <br> SN74AC77814 | $656 \times 18$ | $20,25,40$ |
| SN74ACT7807 | Yes | $2 K \times 9$ | $15,20,25,40$ | 56 SSOP |
| SN74ACT7808 | No | $2 K \times 9$ | $20,25,30,40$ | 64 SQFP <br> 44 PLCP |

Figure 4 compares the space savings of the new compact packages compared to competitive surface-mount solutions. Note that a four-byte path constructed with four clocked FIFOs in 32-pin PLCC packages consumes 1.16 in $^{2}$, while two 56 -pin SSOP packages cover only 0.59 in $^{2}$.


Figure 4. Surface-Mount Package Area Comparison

## New Clocked FIFOs

Four new CMOS clocked FIFOs from Texas Instruments offer a variety of memory depths. All four can match applications that require maximum clock frequencies of 67 MHz and access times of 12 ns . Suited for buffering long packets, the $2 \mathrm{~K} \times 9$ SN74ACT7807 is the deepest of the four and is available in the 44 -pin PLCC or 64 -pin SQFP. The SN74ACT7803, SN74ACT7805, and SN74ACT7813 are organized as $512 \times 18,256 \times 18$, and $64 \times 18$, respectively, and have the same pin arrangement in the 56 -pin SSOP. Every TI clocked FIFO is easily expanded in word width, and the SN74ACT7803/05/13 may also be arranged to form a bidirectional FIFO. With the two FIFOs connected as in Figure 1, no extra logic is needed for bidirectional operation.


Flgure 5. Bldirectional Configuration for the SN74ACT7803
Silicon is currently available for a bidirectional clocked FIFO fabricated in TI's Advanced BiCMOS (ABT) process. The SN74ABT7819 is organized as $512 \times 18 \times 2$ with two internal independent FIFOs. Each port has a continuous free-running clock, a chip select ( $\overline{\mathrm{CS}}$ ), a read/write select ( $\overline{\mathrm{R}} / \mathrm{W}$ ), and two separate read and write enables for control. It supports clock frequencies in excess of 80 MHz and a maximum access time below 10 ns . This device will be packaged in the 80-pin QFP and 80-pin SQFP.

## Conclusion

Several semiconductor manufacturers including Texas Instruments have responded to customer needs by providing clocked FIFOs whose synchronous interfaces conform to the requirements of many high-performance systems. Capitalizing on the available continuous system clocks, this architecture limits the amount of necessary glue logic and the number of timing constraints.

Flag synchronization is important for clocked FIFOs buffering between asynchronous systems. Flip-flop synchronizers used for this task have a metastable failure rate that grows exponentially with clock frequency. Texas Instruments employs two stages of synchronization that improve the flags' reliability significantly.

Finally, providing a FIFO buffer for wide buses has historically consumed large amounts of board area. Designers seeking relieffrom this problem can find it in the packaging options offered for Texas Instruments' FIFOs. Used to house 9 - and 18 -bit devices, these packages require only about $50 \%$ of the space required for conventional surface-mount packages.

# FIFO Surface-Mount Package Information 

FIFO Memory Applications

Jon E. Lyu<br>GPL Products - Semiconductor Group Texas Instruments

## FIFO Surface-Mount Package Information

## Introduction

Texas Instruments provides seven types of plastic surface-mount packages for CMOS FIFO memory devices. These packages and the data bus width that each package can provide are listed in Table 1.

Table 1. Plastlc Surface-Mount FIFO Packages

| PACKAGE | \# OF DATA BTTS |
| :---: | :---: |
| 44-pin PLCC | 9 |
| 64 -pin SQFP | 9 |
| 56 -pin SSOP | 18 |
| 68 -pin PLCC | 18 |
| 80 -pin SQFP | 18 |
| 80 -pin QFP | 18 |
| 120-pin SQFP | 32 or 36 |
| SSOP $=$ shrink small-outline package |  |
| PLCC $=$ plastic leaded chip carrier |  |
| SQFP $=$ shrink quad flat pack |  |
| QFP $=$ quad flat pack |  |

This application report discusses several topics concerning the FIFO packages listed in Table 1:

- The thermal resistance, R ®JA, and the chip junction temperature of the device.
- The need for dry packing to maintain safe moisture levels inside the package.
- The three methods used by Texas Instruments for shipping FIFOs to customers.
- The package dimensions, including two-dimensional drawings that show areas, heights, and lead pitches.
- The area comparison of surface-mount packages used for commercial FIFO memories.
- The test sockets available for surface-mount FIFO packages.


## Thermal Resistance

Thermal resistance is defined as the ability of a package to dissipate heat generated by an electronic device and is characterized by R ®JA. R gJa is the thermal resistance from the IC chip junction to the free air (ambient). Units for this parameter are in degrees Celsius per watt. Table 2 lists ReJA for SSOP, PLCC, SQFP, and QFP packages under five different air flow environments: $0,100,200,250$, and 500 linear feet/minute. The chip junction temperature ( $\mathrm{T}_{\mathrm{J}}$ ) can be determined using equation 1 .

$$
\begin{equation*}
\mathrm{T}_{\mathrm{J}}=\mathrm{R}_{\Theta \mathrm{JA}} \times \mathrm{P}_{\mathrm{T}}+\mathrm{T}_{\mathrm{A}} \tag{1}
\end{equation*}
$$

where
$\mathrm{T}_{\mathrm{J}}=$ chip junction temperature $\left({ }^{\circ} \mathrm{C}\right)$
$\mathrm{R}_{\text {©JA }}=$ thermal resistance, junction to free-air ( ${ }^{\circ} \mathrm{C} /$ watt $)$
$\mathrm{P}_{\mathrm{T}}=$ total power dissipation of the device (watts)
$\mathrm{T}_{\mathrm{A}}=$ free-air (ambient) temperature in the particular environment in which the device is operating ( ${ }^{\circ} \mathrm{C}$ )

Table 2. Thermal Resistance, R RJA , for FIFO Packages

| PACKAGE | $\begin{aligned} & \text { LEAD } \\ & \text { FRAME } \end{aligned}$ | $\mathrm{R}_{\text {eJa }}\left({ }^{\circ} \mathrm{C} / \mathrm{W}\right)$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 0 LFPM | 100 LFPM | 200 LFPM | 250 LFPM | 500 LFPM |
| 56-pin SSOP | Copper | 94.2 | 82.2 | N/A | 70 | 57.8 |
| 44-pin PLCC | Copper | 65 | N/A | N/A | N/A | N/A |
| 68-pin PLCC | Copper | 47.2 | 43.4 | N/A | 32.7 | 27.8 |
| 64-pin SQFP | Copper | 92.5 | 87.8 | N/A | 72.9 | 57.8 |
| 80-pin SQFP | Copper | 87.8 | 79.1 | N/A | 67.3 | 54.2 |
| 120-pin SQFP ${ }^{\dagger}$ | Copper | 49.6 | 44.3 | N/A | 38.3 | 28.6 |
| 80 -pin QFP | Alloy 42 | 80 | 67 | 61 | N/A | N/A |

${ }^{\dagger}$ Heat spreader molded inside the package
N/A = not available
Note that $\mathrm{R}_{\text {®JA }}$ generally increases with decreasing package size; however, this is not true with the 120 -pin SQFP package. A heat spreader molded inside the package absorbs a large amount of heat dissipated by the device. As a result, this package provides a relatively low $\mathrm{R}_{\boldsymbol{\Theta J A}}$. The 120 -pin SQFP $^{\text {is the only package in Table } 2 \text { that incorporates a heat }}$ spreader.

## Package Moisture Sensitivity

When a plastic surface-mount package is exposed to temperatures typical of furnace reflow, IR (infrared) soldering, or wave soldering ( $215^{\circ} \mathrm{Cor}$ higher), the moisture absorbed by the package will turn to steam and expand rapidly. The stress caused by this expanding moisture can result in internal and external cracking of the package which can lead to reliability failures. Possible damage includes the delamination of the plastic from the chip surface and lead frame, damaged bonds, cratering beneath the bonds, and external package cracks.
To prevent potential damage, packages that are susceptible to the effects of moisture expansion undergo a process called dry pack. This dry pack process helps to reduce moisture levels inside the package. The process consists of a 24 -hour bake at $125^{\circ} \mathrm{C}$ followed by sealing of the packages in moisture barrier bags with desiccant to prevent reabsorption of moisture during the shipping and storage processes. These moisture barrier bags allow a shelf storage of 12 months from the date of seal. Once the moisture barrier bag is opened, the devices in it must be handled by one of the following four methods, listed in order of preference:

1. The devices may be mounted within 48 hours in an atmospheric environment of less than $60 \%$ relative humidity and less than $30^{\circ} \mathrm{C}$.
2. The devices may be stored outside the moisture barrier bag in a dry atmospheric environment of less than $20 \%$ relative humidity until future use.
3. The devices may be resealed in the moisture barrier bag adding new fresh desiccant to the bag. When the bag is opened again, the devices should be used within the 48 -hour time limit or resealed again with fresh desiccant.
4. The devices may be resealed in the moisture barrier bag using the original desiccant. This method does not allow the floor life of the devices to be extended. The cumulative exposure time before reflow must not exceed a total of 48 hours.
All plastic surface-mount FIFO devices are tested for moisture sensitivity in accordance with Texas Instruments' IPC-SM-786 procedure.

## Shipping Methods/Quantities/Dry Pack

Three methods are used by Texas Instruments for shipping FIFOs to customers. These methods are tubes, tape/reel, and trays. The quantities for each of the shipping methods are listed in Table 3. The shipping quantity is defined as the maximum number of packages that can be packed in a single shipping unit (e.g., the maximum number of 56-pin SSOP packages that can be packed in a tube is 20 ). Whether or not the packages require dry pack before shipping is denoted by a yes or no in the DRY PACK column.

Table 3. Shlppling Methods and Quantities

| PACKAGE | SHIPPING METHOD $^{*}$ |  |  | DRY PACK |
| :--- | :---: | :---: | :---: | :---: |
|  | TUBE $^{\dagger}$ | TAPE/REEL | TRAYS |  |
|  |  |  |  |  |
| 56 -pin SSOP | 20 | 500 | N/A | No |
| 44 -pin PLCC | 27 | 500 | N/A | No |
| 68 -pin PLCC | $18 / 19^{\ddagger}$ | 250 | N/A | Yes |
| 64 -pin SQFP | N/A | N/A | 50 | Yes |
| 80 -pin SQFP | N/A | N/A | 50 | Yes |
| 120 -pin SQFP | N/A | N/A | $50 / 84^{\S}$ | Yes |
| 80 -pin SQFP | N/A | N/A | 50 | Yes |

${ }^{\dagger}$ Texas Instruments reserves the right to change any of the shipping quantities at any time without notice.
$\ddagger 18$ packages can be packed in a single tube when pin is used as a tap, or 19 packages can be packed in a tube when plug is used as a tap.
${ }^{\S}$ Depending on tray size
N/A = not applicable

## Package Dimensions and Area Comparison

Figure 1 contains two-dimensional drawings of the seven available surface-mount FIFO packages. For detailed mechanical drawings of these packages, please refer to the mechanical drawing section of the 1992 High-Performance FIFO Memories Data Book.



Area: $\quad 309.80 \mathrm{~mm}^{2}$
Helght: $\quad 4.37 \mathrm{~mm}$
Lead Pltch: 1.27 mm


Area: $\quad 635.04 \mathrm{~mm}^{2}$ Helght: $\quad 4.37 \mathrm{~mm}$ Lead Pitch: 1.27 mm



Figure 1. Package Dimenslons

Figure 2 shows the area comparison of surface-mount packages for FIFOs from Texas Instruments and other FIFO vendors.


Figure 2. Surface-Mount Package Area Comparison

## Test Sockets

For prototype development of a system, it is often an advantage to have sockets for surface-mount products. Test sockets available for use with Texas Instruments' FIFO packages are listed in Table 4. Only one manufacturer is listed for each socket type, although other vendors may offer comparable sockets.

Table 4. Table 4. Test Sockets for FIFO Packages

| PACKAGE | MANUFACTURER | NUMBER | DESCRIPTION |
| :--- | :--- | :--- | :--- |
| 56-pin SSOP | Yamaichi | IC51-0562-1387 | Solder through-hole |
| 44-pin PLCC | NEY | 6044 | Solder through-hole |
| 68-pin PLCC | NEY | 6068 | Solder through-hole |
| 64-pin SQFP | Yamaichi | IC51-0644-807 | Solder through-hole |
| 80-pin SQFP | Yamaichi | IC51-0804-808 | Solder through-hole |
| 120-pin SQFP | Yamaichi | In development (as of 6/92) | Solder through-hole |
| 80 -pin QFP | Yamaichi | IC51-0804-394 | Solder through-hole |

# Metastability Performance of Clocked FIFOs 

Author<br>Chris Wellheuser

# Metastability Performance of Clocked FIFOs 

## Introduction

This paper is intended to help the user understand more clearly the issues relating to the metastable performance of Texas Instruments' Clocked FIFOs in asynchronous system applications. It will discuss basic metastable operation theory, show the equations used to calculate metastable failure rates for one and two stages of synchronization, and describe the approach TI has used for synchronizing the status flags on its series of clocked FIFOs. Additionally, a test setup for measuring the failure rate of a device to determine its metastability parameters is shown, and results are given for both an advanced BiCMOS (ABT) FIFO and an advanced CMOS (ACT) FIFO. Using these parameters, calculations of MTBF under varying conditions are performed.

## Metastability

Metastability in digital systems occurs when two asynchronous signals combine in such a way that their resulting output goes to an indeterminate state. A common example of this is the case of data violating the setup and hold specifications of a latch or a flip-flop. In a synchronous system, the data will always have a fixed relationship with respect to the clock. As long as that relationship obeys the setup and hold requirements for the device, the output will go to a valid state within its specified propagation delay time. However, in an asynchronous system the relationship between data and clock is not fixed and, therefore, occasional violations of setup and hold times can occur. When this happens, the output may go to an intermediate level between its two valid states and remain there for an indefinite amount of time before resolving itself, or it may simply be delayed before making a normal transition ${ }^{1}$. In either case, a metastable event has occurred.

Metastable events can occur in a system without causing a problem, so it is necessary to define what constitutes a failure before attempting to calculate a failure rate. For a simple CMOS latch, as shown in Figure 1, valid data must be present on the input for a specified period of time before the clock signal arrives (setup time) and must remain valid for a specified period of time with respect to the clock transition (hold time) to guarantee the output will function predictably. This leaves a small window of time with respect to the clock ( $\mathrm{t}_{0}$ ) during which the data is not allowed to change. If a data edge does occur within this aperture, the output may go to an intermediate level and remain there for an indefinite amount of time before resolving itself either high or low, as illustrated in Figure 2. This metastable event can cause a failure only if the output has not resolved itself by the time that it must be valid for use (for example, as aninput to another stage). Therefore, the amount of resolve time allowed a device plays a large role in calculating its failure rate.


Flgure 1. SImple CMOS Latch


Figure 2. Output at Intermedlate Level Due to Data Edge Within $\mathrm{t}_{0}$ Aperture

The probability of a metastable state persisting longer than a time $t_{r}$ decreases exponentially as $t_{r}$ increases ${ }^{2}$. This relationship can be characterized by the equation

$$
\begin{equation*}
F\left(\mathbf{t}_{\mathbf{r}}\right)=\mathbf{e}^{\left(-\mathbf{t}_{\mathbf{r}} / \tau\right)} \tag{1}
\end{equation*}
$$

where the function $F\left(t_{r}\right)$ is the probability of nonresolution as a function of resolve time allowed, $t_{p}$ and the circuit time constant $\tau$ (which has also been shown to be inversely proportional to the gain-bandwidth product of the circuit) ${ }^{3,4}$.
For a single-stage synchronizer with a given clock frequency and an asynchronous data edge that has a uniform probability density within the clock period, the rate of generation of metastable events can be calculated by taking the ratio of the setup and hold time window described above to the time between clock edges and multiplying by the data edge frequency. This generation rate of metastable events coupled with the probability of nonresolution of an event as a function of the time allowed for resolution gives the failure rate for that set of conditions. The inverse of the failure rate is the mean time between failure (MTBF) of the device and is calculated with the formula shown below:

$$
\begin{equation*}
\frac{1}{\text { failure rate }}=\mathrm{MTBF}_{1}=\frac{e^{\left(\mathrm{t}_{\mathrm{r}} / \tau\right)}}{\mathrm{t}_{0} \mathrm{f}_{\mathrm{c}} \mathrm{f}_{\mathrm{d}}} \tag{2}
\end{equation*}
$$

where
$t_{r}=$ the resolve time allowed in excess of the normal propagation delay time of the device
$\tau=$ the metastability time constant for a flip-flop
$t_{0}=$ a constant related to the width of the time window or aperture wherein a data edge will trigger a metastable event
$f_{c}=$ the clock frequency
$f_{d}=$ the asynchronous data edge frequency

The parameters $t_{0}$ and $\tau$ are constants that are related to the electrical characteristics of the device in question. The simplest way to determine their values is to measure the failure rate of the device under specified conditions and solve for them directly. If the failure rate of a device is measured at different resolve times and plotted, the result is an exponentially decaying curve. When plotted on a semilogarithmic scale, this becomes a straight line the slope of which is equal to $\tau$. Therefore, two data points on the line are sufficient to calculate the value of $\tau$ using the formula below:

$$
\begin{equation*}
\tau=\frac{\mathrm{t}_{\mathrm{r} 2}-\mathrm{t}_{\mathrm{r} 1}}{\ln (\mathrm{~N} 1 / \mathrm{N} 2)} \tag{3}
\end{equation*}
$$

where
$\mathrm{t}_{\mathrm{r} 1}=$ resolve time 1
$\mathrm{t}_{\mathrm{r}} 2=$ resolve time 2
$\mathrm{N} 1=$ the number of failures relative to $\mathrm{t}_{\mathrm{r} 1}$
$\mathrm{N} 2=$ the number of failures relative to $\mathrm{t}_{\mathrm{r} 2}$

After determining the value for $\tau$, $t_{0}$ may be solved for directly.
The formula for calculating the MTBF of a two-stage synchronizer is merely an extension of equation $1^{5}$ :

$$
\begin{equation*}
\mathrm{MTBF}_{2}=\frac{e^{\left(t_{\mathrm{r} 1} / \tau\right)}}{\mathrm{t}_{0} \mathrm{f}_{\mathrm{c}} \mathrm{f}_{\mathrm{d}}} \times \mathrm{e}^{\left(\mathrm{t}_{\mathrm{r} 2} / \tau\right)} \tag{4}
\end{equation*}
$$

where
$\mathrm{t}_{\mathrm{r} 1}=$ the resolve time allowed for the first stage of the synchronizer
$\mathrm{t}_{\mathrm{r} 2}=$ the resolve time allowed in excess of the normal propagation delay external to the device $f_{c}, f_{d}, \tau$ and $t_{0}$ are as defined previously, with $\tau$ and $t_{0}$ assumed to be the same for both stages

The first term calculates the MTBF of the first stage of the synchronizer, which in effect becomes the generation rate of metastable events for the next stage. The second term then calculates the probability that the metastable event will be resolved based on the value of $t_{r}$, the resolve time allowed external to the synchronizer. The product of the two terms gives the overall MTBF for the two-stage synchronizer.

## TI Clocked FIFOs

TI's clocked FIFOs are designed to reduce the occurrence of metastable errors due to asynchronous operation. This is achieved through the use of two- and three-stage synchronizing circuits that generate the status flag outputs IR (input ready) and OR (output ready). In a typical application, words may be written to and then read from the FIFO at varying rates independent of one another, resulting in asynchronous flag signal generation (internally) at the boundary conditions of full and empty. For example, consider the operation when the FIFO is at the full boundary condition with writes taking place faster than and asynchronously to reads. The IR flag will be low, signifying that the FIFO is full and can accept no more words. When a read occurs, the FIFO is no longer completely full. This causes an internal flag signal to go high, allowing another write to take place. Since the exit from the full state happens asynchronously to the write clock of the FIFO, this flag is not useful as a system write enable signal. The solution is to synchronize this internal flag to the write
clock through two D-type flip-flop stages and output this synchronized signal as the IR flag (see Figure 3). The OR status flag is generated in a similar manner at the empty boundary condition and is synchronized to the read clock through a three-stage synchronizing circuit.


Figure 3. IR Flag Synchronlzer

The remainder of this discussion will pertain to the metastability performance of the two-stage IR synchronizer, which is the limiting case of the two in terms of MTBF characteristics. As mentioned above, the internal flag signal that goes high on a read and low on a write is synchronized to the write clock through two D-type flip-flop stages. Since this results in the IR flag status of the FIFO being delayed for two clock cycles, a predictive circuit is used to clock the status into the synchronizer at (full minus two) words so that the action of the IR flag going low coincides with the actual full status of the FIFO. However, once the FIFO is full and IR is low, a read that causes the internal flag to go high will not be reflected in the status of the IR flag until two write clocks have occurred.

With the FIFO full and the IR flag low, a read will cause the internal flag signal to go high. This signal will be clocked into the first stage of the two-stage synchronizer on the next write clock. Because these two signals are asynchronous to one another, the potential for the output of the first stage of the synchronizer to go to a metastable state exists. If this condition persists until the next write clock rising edge, a metastable condition could be generated in the second stage and reflected on the IR flag output. This metastable condition manifests itself as a delay in propagation time and is considered a failure only if it exceeds the maximum delay allowed in an application.

The effectiveness of the two-stage synchronizer becomes apparent when attempting to generate failures at a rate high enough to count in a reasonable period of time. As mentioned above, a metastable event generated in the first stage must persist until the next write clock, i.e., when that data is transferred to the second stage. Thus, the resolve time for the first stage is governed by the frequency or period of the write clock. At slower frequencies, the failure rate of the first stage is very low, resulting in a low metastable generation rate to the second stage. The second stage of the synchronizer further reduces the probability of a metastable failure based on the resolve time allowed at the output. The overall failure rate of the device may therefore be affected by increasing the initial asynchronous data generation rate (adding jitter to the data centered about the setup and hold window), by decreasing the resolve time of the first stage (increasing the write clock frequency), and also by reducing the external resolve time at the output.

## Test Setup for Measuring FIFO Flag Metastability

The failure rate of a device can be measured on a test fixture as depicted in Figure 4. The input waveforms used on this setup are also shown in Figure 4. Rising data is jittered asynchronously about the setup and hold aperture of the device under test (DUT) in a $+/-400$-ps window with respect to the device clock(WCLK). The output of the DUT is then latched into two separate flip-flops, FF1 and FF2, by two different clock signals, CLK1 and CLK2. The resolve time $\mathrm{t}_{\mathrm{r}}$ is set by the relationship between CLK1 and WCLK and is measured as the delta between the normal output transition time and the rising edge of CLK1 minus the setup time required for FF1. CLK2 occurs long enough after CLK1 to allow sufficient time for the DUT to have resolved itself to a valid state. The outputs of FF1 and FF2 are compared by the exclusive OR gate, the output state of which is latched into FF3 by CLK3. When a metastable failure occurs, the output of the exclusive OR gate goes high, caused by FF1 and FF2 having opposite data due to the DUT not having resolved itself by time $t_{r}$. On the next cycle, low data is clocked out of the DUT and into FF1 and FF2 in order to reset the status latch, FF3. Failures are counted for different resolve times, and $\tau$ is then calculated using equation 3.


Figure 4. Metastable Event Counter and Input Waveforms
Using the test setup described above, failure rates were measured for both an SN74ABT7819512 $\times 18 \times 2$ clocked FIFO and anSN74ACT7807 $2 \mathrm{~K} \times 9$ clocked FIFO. The device is initially written full to set IR low at the boundary condition. A read clock is generated to send the internal flag high, and a jitter signal is superimposed on it to sweep asynchronously with respect to the write clock in an envelope 800 ps wide and centered such that the IR flag goes high alternately on the second and third write clocks following the read clock. The nominal write clock frequency of the test setup is 40 MHz , but to increase the failure rate to an observable level, a pulse is injected into the write clock stream just after the read clock occurs such that the first and second write clocks (the ones that clock the status through the synchronizer) are only 5.24 ns apart. This increases the effective write clock frequency to 191 MHz , reducing the resolve time allowed the first stage and, thus, increasing the failure rate.

This test setup and these actions together create the necessary conditions to generate a metastable occurrence on the IR output that is seen after the second write clock and manifests itself as a delay in propagation time. In this instance, the write clock is the synchronizing clock, and the read clock generates the asynchronous internal data signal. CLK1 was adjusted to vary the external resolve time $\mathrm{t}_{\mathrm{r} 2}$, and the resulting failure rates were recorded.

Test Results
SN74ABT7819 Fallure Rates ${ }^{\dagger}$

| RESOLVE TIME, <br> $\mathbf{t}_{\mathbf{2}}$ (ns) | NUMBER OF <br> FAILURES/HOUR | NUMBER OF <br> FAILURES/SECOND | MTBF <br> (SECONDS) |
| :---: | :---: | :---: | :---: |
| 0.27 | 890 | 0.2472 | 4.04 |
| 0.39 | 609 | 0.1692 | 5.91 |
| 0.53 | 396 | 0.1101 | 9.08 |

$$
{ }^{\top} \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}
$$

After measuring the metastable performance of the $\mathrm{ABT7819}$, some assumptions must be made in order to calculate the parameters $\tau$ and $t_{0}$. Because the individual flip-flops comprising the two-stage synchronizer cannot be measured separately, it is first assumed that the values for $\tau$ and $t_{0}$ are the same for both. This is a safe assumption, as these constants are driven by the process technology and because the schematics are identical. The other assumption made involves determining the resolve time allowed in the first stage of the synchronizer ( $\mathrm{t}_{\mathrm{r} 1}$ ). The clock period is set at 5.24 ns , but the delay through the flip-flop and the setup time to the next stage must be subtracted from the clock period to arrive at the true value of $\mathrm{t}_{\mathrm{r} 1}$. These values could not be measured directly and were therefore estimated from SPICE analysis to be 1.3 ns .

Using equation 4 and the measured failure rates to calculate $\tau$ results in a value of 0.33 ns for the conditions given. The following values from the test setup must be used in order to solve for $\mathrm{t}_{0}$ :

$$
\begin{array}{ll}
\mathrm{t}_{\mathrm{r} 1} & =3.94 \mathrm{~ns}(5.24-\mathrm{ns} \text { clock period - 1.3-ns setup and delay time) } \\
\mathrm{t}_{\mathrm{r} 2} & =0.27 \mathrm{~ns} \text { (set externally at IR output by CLK1) } \\
\mathrm{f}_{\mathrm{c}} & =40 \mathrm{MHz} \\
\mathrm{f}_{\mathrm{d}} & =125 \mathrm{MHz} \text { (4-MHz input adjusted by } 25 / 0.8 \text { jitter ratio) } \\
\mathrm{MTBF}_{2} & =4.04 \mathrm{~s}
\end{array}
$$

Substituting these values into equation 4 and solving for $t_{0}$ yields a value of 16.9 ps .
The table below summarizes the results for the SN74ABT7819 and SN74ACT7807 clocked FIFOs. An internal setup and delay time of 1.8 ns was assumed for the SN74ACT7807.

Values of $\tau$ and $t_{0}$ for SN74ABT7819 and SN74ACT7807

| $T_{A}$ | $V_{\mathbf{C C}}$ | SN74ABT7819 |  | SN74ACT7007 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\tau(\mathrm{ns})$ | $\mathrm{t}_{0}(\mathrm{ps})$ | $\tau(\mathrm{ns})$ | $\mathrm{t}_{0}(\mathrm{ps})$ |
| $25^{\circ} \mathrm{C}$ | 4.5 V | 0.33 | 16.9 | 0.50 | 1.13 |
|  | 5.0 V | 0.30 | 7.0 | 0.40 | 2.05 |
|  | 5.5 V | 0.23 | 28.8 | 0.30 | 9.40 |

A word of caution: these numbers indicate the performance of only a few devices and are not intended to represent a fully characterized parameter. However, they should be valid for the purpose of relative performance comparisons, and the values do fall within the expected range given the circuit configuration and process technology in which the devices are fabricated.

## MTBF Comparison

With the constants $\tau$ and $t_{0}$ now known, calculations of the MTBF of the device under different operating conditions may be performed. First, however, consider an example of the metastability performance of a single-stage synchronizer using equation 2 and the circuit constants $\tau$ and $t_{0}$ from the measurements above. Assume an application running with a $33-\mathrm{MHz}$ write clock, an $8-\mathrm{MHz}$ read clock, a $9-\mathrm{ns}$ maximum propagation delay time for the IR path, and a $5-\mathrm{ns}$ setup time for IR to the next device. Therefore,

```
\(\mathrm{t}_{\mathrm{f}}=16 \mathrm{~ns}\left(30-\mathrm{ns}\right.\) clock period-9-ns propagation delay \(\left.-5-\mathrm{ns}_{\mathrm{su}}\right)\)
\(\mathrm{f}_{\mathrm{c}}=33 \mathrm{MHz}\)
\(\mathrm{f}_{\mathrm{d}}=8 \mathrm{MHz}\)
```

Using equation 2 to calculate the MTBF gives $2.55 \times 10^{17}$ seconds, or a little bit more than 8 billion years.

However, the reliability of a one-stage synchronizer degrades as operating frequency increases. With a $50-\mathrm{MHz}$ write clock, a $12-\mathrm{MHz}$ read clock, a $9-\mathrm{ns}$ maximum delay, and a $5-\mathrm{ns}$ setup time,

$$
\begin{aligned}
& \mathbf{t}_{\mathrm{r}}=6 \mathrm{~ns}\left(20-\mathrm{ns} \text { clock period }-9-\mathrm{ns} \text { propagation delay }-5-\mathrm{ns} \mathrm{t}_{\mathrm{su}}\right) \\
& \mathrm{f}_{\mathrm{c}}=50 \mathrm{MHz} \\
& \mathrm{f}_{\mathrm{d}}=12 \mathrm{MHz}
\end{aligned}
$$

Substituting these values into equation 2 yields an MTBF of about 2 hours. This performance is unacceptable, even with a device fabricated in the $0.8-\mu \mathrm{m} \mathrm{BiCMOS}$ process, which is more resistant to metastability than other processes.
The benefits of two-stage synchronization become evident with the next example. Assuming the same conditions stated in the previous case,

$$
\begin{aligned}
& \mathbf{t}_{\mathrm{r} 1}=18.7 \mathrm{~ns}(20-\mathrm{ns} \text { clock period }-1.3-\mathrm{ns} \text { setup and delay time }) \\
& \mathbf{t}_{\mathrm{r} 2}=6 \mathrm{~ns}\left(20-\mathrm{ns} \text { clock period }-9-\mathrm{ns} \text { propagation delay }-5-\mathrm{ns} \mathrm{t}_{\mathrm{su}}\right) \\
& \mathbf{f}_{\mathrm{c}}=50 \mathrm{MHz} \\
& \mathbf{f}_{\mathrm{d}}=12 \mathrm{MHz}
\end{aligned}
$$

Using equation 4 to calculate the MTBF gives $3.16 \times 10^{28}$ seconds, or $1.00 \times 10^{21}$ years.
The table below gives a performance summary of both one- and two-stage synchronizing solutions under different conditions.

MTBF Comparisonst

| CONDITIONS | ACT 1-STAGE | ABT 1-STAGE | ACT 2-STAGE | ABT 2-STAGE |
| :---: | :---: | :---: | :---: | :---: |
| $f_{c}=33 \mathrm{MHz}, \quad f_{d}=8 \mathrm{MHz}$ | 8400 years | $8.1 \times 10^{9}$ years | $2.62 \times 10^{28}$ years | $4.77 \times 10^{47}$ years |
| $f_{\mathrm{c}}=40 \mathrm{MHz}, \quad \mathrm{f}_{\mathrm{d}}=10 \mathrm{MHz}$ | 92 days | 1400 years | $3.56 \times 10^{19}$ years | $2.18 \times 10^{34}$ years |
| $f_{\mathrm{c}}=50 \mathrm{MHz}, \quad \mathrm{f}_{\mathrm{d}}=12 \mathrm{MHz}$ |  | 2 hours | $4.90 \times 10^{10}$ years | $1.00 \times 10^{21}$ years |
| $\mathrm{f}_{\mathrm{c}}=67 \mathrm{MHz}, \quad \mathrm{f}_{\mathrm{d}}=16 \mathrm{MHz}$ |  |  | 417 years | $1.28 \times 10^{9}$ years |
| $\mathrm{f}_{\mathrm{c}}=80 \mathrm{MHz}, \quad \mathrm{f}_{\mathrm{d}}=20 \mathrm{MHz}$ |  |  |  | 2900 years |

${ }^{\dagger}$ Assumptions for the MTBF comparisons:

1) The values for $t_{0}$ and $\tau$ are those given previously for both the $A B T$ and $A C T$ devices with $V_{C C}=4.5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
2) Flag propagation delay time (WCLK to IR) is assumed to be 9 ns .
3) Setup times to the next device are 5 ns (up to $50-\mathrm{MHz}$ operation), 4 ns (for $67-\mathrm{MHz}$ operation), and 3 ns (for $80-\mathrm{MHz}$ operation).

## Conclusion

In a digital system, asynchronous operation can cause random errors due to metastability failures under various conditions. Because of their nature, these errors can be very difficult to analyze, but their rate of occurrence (or MTBF of a device) may be predicted to give an indication of overall system reliability. Certain parameters of a device ( $\mathrm{t}_{0}$ and $\tau$ ) are necessary to perform these calculations and are provided herein for both the ABT and ACT families of clocked FIFOs.

Metastability failures in asynchronous systems become increasingly more prevalent at higher operating frequencies. The MTBF comparison clearly indicates the need for addressing these issues with respect to system reliability at operating frequencies in excess of 33 MHz .

With its series of clocked FIFOs, Texas Instruments provides a solution to this problem by synchronizing the boundary status flags with at least two stages to improve the metastable MTBF characteristics over one-stage synchronization. This architecture allows system designers to utilize the high-frequency performance of the device without adversely affecting system reliability due to inadequate synchronization methods.

## References

1. J. Horstmann, H. Eichel, and R. Coates, "Metastability Behavior of CMOS ASIC Flip-Flops in Theory and Test," IEEE Journal of Solid State Circuits, February 1989, p. 146.
2. H. Veendrick, "The Behavior of Flip-Flops Used as Synchronizers and Prediction of Their Failure Rate," IEEE Journal of Solid State Circuits, April 1980, p. 169.
3. S. T. Flannagan, "Synchronization Reliability in CMOS Technology," IEEE Journal of Solid State Circuits, August 1985, p. 880.
4. T. Kacprzak and A. Albicki, "Analysis of Metastable Operation in RS CMOS Flip-Flops," IEEE Journal of Solid State Circuits, February 1987, p. 59.
5. L. Kleeman and A. Cantoni, "Metastable Behavior in Digital Systems," IEEE Design and Test of Computers, December 1987, p. 4.

| Crameral Intornaton: | 1 |
| :---: | :---: |
| Indinecten mi Clockra Fifors | 2 |
| Indirectominflas | 3 |
| Elormetionil Cockeaffos: | 4 |
| E6IMmetonal | 5 |
| Pratict Previkul | 6 |
| Arteme and Appleation Matas | 7 |
| Mechanical Data | 8 |

## ORDERING INSTRUCTIONS

Electrical characteristics presented in this data book, unless otherwise noted, apply for the circuit type(s) listed in the page heading regardless of package. The availability of a circuit function in a particular package is denoted by an alphabetical reference above the pin-connection diagram(s). These alphabetical references refer to mechanical outline drawings shown in this section.

Factory orders for circuits described in this catalog should include a four-part type number as explained in the following example.

1. Prefix
Blank $=$ (Standard product)
SN $=$ Standard prefix
SNJ $=$ JEDEC Publication 101, Class B
JANB $=$ MIL-M-38510 Qualified
2. Unique CIrcult Description

Must contain nine or ten characters
(from individual data sheet)
3. Package

Must contain one to three letters:
DL, DW $\quad=$ plastic small-outline package
FN $\quad=$ plastic J-ieaded chip carrier
N, NT $\quad=$ plastic dual-in-line package
PBM, PH $=$ JEDEC metric plastic quad flatpack
PCB, PM, PN $=$ plastic shrink quad flatpack
$P Q \quad=J E D E C$ plastic quad flatpack
4. Tape and Reel Packaging

Must be designated by the letter $R$ and valid for surface-mount packages only.
All orders for tape and reel must be for whole reels.

## DL028, DL048, and DL056 plastic small-outline packages

Each of these small-outline packages consists of a circuit mounted on a lead frame and encapsulated within a plastic compound. The compound will withstand soldering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in inches with millimeters in parentheses.
B. Leads are within $0.0035(0,089)$ radius of true position at maximum material condition.
C. Lead tips are coplanar within $0.004(0,102)$.
D. Body dimensions do not include mold flash, protrusion, or qate burr.
E. Mold flash, protrusion, or qate burr shall not exceed $0.015(0,381)$
F. Interlead flash shall be controlled by TI statistical process control (additional information available through Tl field office).
G. Lead length is measured from the lead tip to a point $0.010(0,254)$ above the seating plane.

## DW016, DW020, DW024, and DW028 plastic small-outline packages

Each of these small-outline packages consists of a circuit mounted on a lead frame and encapsulated within a plastic compound. The compound will withstand soldering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. Leads require nc additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in inches with millimeters in parentheses.
B. Leads are within $0.005(0,127)$ radius of true position at maximum material condition.
C. Lead tips are coplanar within $0.004(0,102)$.
D. Body dimensions do not include mold flash or protrusion.
E. Mold protrusion shall not exceed $0.006(0,15)$.
F. Interlead flash controlled by TI Statistical Process Control (additional information available through local TI sales office).

## FN020, FN028, FNO44, FN052, FN068, and FN084 plastic J-leaded chip carriers

Each of these chip carrier packages consists of a circuit mounted on a lead frame and enncapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting on $1,27(0.050)$ centers. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All dimensions conform to JEDEC Specification MO-047AANAF. Dimensions and tolorancing are per ANSI Y14.5M - 1982.
B. Dimensions $\mathrm{D}_{1}$ and $\mathrm{E}_{1}$ do not include mold flash protrusion. Protrusion shall not exceed 0,25 ( 0.010 ) on any side. Centerline of center pin each side is within $0,10(0.004)$ of package centerline by dimension $B$. The lead contact points are planar within $0,10(0.004)$.
C. Datums $D-E$ and $F-G$ for center leads are determined at datum $-H-$.
D. Datum $-\mathrm{H}-$ is located at top of leads where they ext plastic body.
E. Location of datums $-\mathrm{A}-$ and $-\mathrm{B}-$ to be determined at datum $-\mathrm{H}-$.
F. Determined at seating plane $-\mathrm{C}-$.

FN020, FN028, FN044, FN052, FN068, and FN084 plastic J-leaded chip carriers (continued)

| JEDEC OUTLINE | NO. OF PINS | A |  | $\mathrm{A}_{1}$ |  | D, E |  | $\mathrm{D}_{1}, \mathrm{E}_{1}$ |  | $\mathrm{D}_{2}, \mathrm{E}_{2}$ |  | $\mathrm{D}_{3}, \mathrm{E}_{3}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | MIN | MAX | BASIC |
| MO-047AA | 20 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 4,57 \\ (0.180) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,05 \\ (0.120) \end{gathered}$ | $\begin{gathered} 9,78 \\ (0.385) \end{gathered}$ | $\begin{gathered} 10,03 \\ (0.395) \end{gathered}$ | $\begin{gathered} 8,89 \\ (0.350) \end{gathered}$ | $\begin{gathered} 9,04 \\ (0,356) \end{gathered}$ | $\begin{gathered} 7,37 \\ (0.290) \end{gathered}$ | $\begin{gathered} 8,38 \\ 90.330) \end{gathered}$ | $\begin{gathered} 5,08 \\ (0.200) \end{gathered}$ |
| HO-047AB | 28 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 4,57 \\ (0.180) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,05 \\ (0.120) \end{gathered}$ | $\begin{aligned} & 12,32 \\ & (0.485) \end{aligned}$ | $\begin{aligned} & 12,57 \\ & (0.435) \end{aligned}$ | $\begin{gathered} 11,43 \\ (0.450) \end{gathered}$ | $\begin{gathered} 11,58 \\ (0.456) \end{gathered}$ | $\begin{gathered} 9,91 \\ (0.390) \end{gathered}$ | $\begin{gathered} 10,92 \\ (0.430) \end{gathered}$ | $\begin{gathered} 7,62 \\ (0.300) \end{gathered}$ |
| MO-047AC | 44 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 4,57 \\ (0.180) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,05 \\ (0.120) \end{gathered}$ | $\begin{gathered} \hline 17,40 \\ (0.685) \end{gathered}$ | $\begin{aligned} & 17,65 \\ & (0.695) \end{aligned}$ | $\begin{gathered} 16,51 \\ (0.650) \end{gathered}$ | $\begin{gathered} \hline 16,66 \\ (0.656) \end{gathered}$ | $\begin{aligned} & 14,99 \\ & (0.590) \end{aligned}$ | $\begin{aligned} & 16,00 \\ & (0.630) \end{aligned}$ | $\begin{gathered} 12,70 \\ (0.500) \end{gathered}$ |
| MO-047AD | 52 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 5,08 \\ (0.200) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,30 \\ (0.130) \end{gathered}$ | $\begin{gathered} 19,94 \\ (0.785) \end{gathered}$ | $\begin{gathered} 20,19 \\ (0.795) \end{gathered}$ | $\begin{aligned} & 19,05 \\ & (0.750) \end{aligned}$ | $\begin{gathered} 19,20 \\ (0.756) \end{gathered}$ | $\begin{gathered} 17,53 \\ (0.690) \end{gathered}$ | $\begin{aligned} & 18,54 \\ & (0.730) \end{aligned}$ | $\begin{aligned} & 15,24 \\ & (0.600) \end{aligned}$ |
| MO-047AE | 68 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 5,08 \\ (0.200) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,30 \\ (0.130) \end{gathered}$ | $\begin{gathered} 25,02 \\ (0.985) \end{gathered}$ | $\begin{gathered} 25,27 \\ (0.995) \end{gathered}$ | $\begin{gathered} 24,13 \\ (0.950) \end{gathered}$ | $\begin{gathered} 24,33 \\ (0.958) \end{gathered}$ | $\begin{gathered} 22,61 \\ (0.890) \end{gathered}$ | $\begin{gathered} \hline 23,62 \\ (0.930) \end{gathered}$ | $\begin{gathered} 20,32 \\ (0,800) \end{gathered}$ |
| MO-047AF | 84 | $\begin{gathered} 4,19 \\ (0.165) \end{gathered}$ | $\begin{gathered} 5,08 \\ (0.200) \end{gathered}$ | $\begin{gathered} 2,29 \\ (0.090) \end{gathered}$ | $\begin{gathered} 3,30 \\ (0,130) \end{gathered}$ | $\begin{array}{r} 30,10 \\ (1,185) \\ \hline \end{array}$ | $\begin{gathered} 30,35 \\ (1,195) \end{gathered}$ | $\begin{gathered} 29,21 \\ (1,150) \end{gathered}$ | $\begin{gathered} 29,41 \\ (1,141) \end{gathered}$ | $\begin{gathered} 27,69 \\ (1.090) \end{gathered}$ | $\begin{gathered} 28,70 \\ (1.130) \end{gathered}$ | $\begin{gathered} 25,40 \\ (1,000) \end{gathered}$ |

NOTES: A. All dimensions conform to JEDEC Specification MO-O47AA/AF. Dimensions and tolerancing are per ANSI Y14.5M-1982.
F. Determined at seating plane $-\mathrm{C}-$.

## N014, N016, and N02O

## 300-mil plastic dual-in-line packages

These dual-in-line packages consist of a circuit mounted on a lead frame and encapsulated within a plastic compound. The compound will withstand soldering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. These packages are intended for insertion in mounting-hole rows on $0.300(7,62)$ centers (see Note B). Once the leads are compressed and inserted, sufficient tension is provided to secure the package in the board during soldering. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in inches with millimeters in parentheses.
B. Each pin centerline is located within $0.010(0,254)$ of its true longitudinal position.
C. This dimension does not apply for solder-dipped loads.
D. When solder dip is spécified, dipped area of the lead extends from the lead tip to at least $0.20(0,51)$ above seating plane.

## N028, N040, N048, and N052

## 600-mil plastic dual-in-line packages

These dual-in-line packages consist of a circuit mounted on a lead frame and encapsulated within a plastic compound. The compound will withstand soldering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. These packages are intended for insertion in mounting-hole rows on $0.600(15,24)$ centers (see Note B). Once the leads are compressed and inserted, sufficient tension is provided to secure the package in the board during soldering. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in inches with millimeters in parentheses.
B. Each pin centerline is located within $0.010(0,25)$ of its true longitudinal position.
C. This dimension does not apply for solder-dipped leads.
D. When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at least $0.020(0,51)$ above seating plane.

## NT024 and NT028

## 600-mil plastic dual-in-line packages

These dual-in-line packages consist of a circuit mounted on a lead frame and encapsulated within a plastic compound. The compound will withstand soldering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. These packages are intended for insertion in mounting-hole rows on $0.300(7,62)$ centers (see Note B). Once the leads are compressed and inserted, sufficient tension is provided to secure the package in the board during soldering. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in inches with millimeters in parentheses.
B. Each pin centerline is located within $0.010(0,254)$ of its true longitudinal position.
C. This dimension does not apply for solder-dipped leads.
D. When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at loast $0.020(0,51)$ above seating plane.

PBM120

## JEDEC metric plastic quad flatpack

This plastic package consists of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting, and leads are spaced on $0,80-\mathrm{mm}$ centers with an $0,80-\mathrm{mm}$ foot length. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. Maximum deviation from coplanarity is $0,1 \mathrm{~mm}$.
B. All dimensions and notes for JEDEC outline MO-x0000x apply.

## PCB120

## JEDEC metric plastic shrink quad flatpack

This plastic package consists of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting, and leads are spaced on 0,40-mm centers with a 0,535-mm foot length. Leads require no additional cleaning or processing when used in soldered assembly.

NOTES: A. All linear dimensions are in millimeters.
B. Datum plane H H- located at top of mold parting line and coincident with top of lead. Where lead exits plastic body.
C. Datum $A-B$ and $-\mathrm{D}-$ to be determined where center leads exit plastic body at datum plane $-\mathrm{H}-$.
D. Body dimensions ( $X$ and $Y$ ) do not Include moid protrusion. Allowable mold protrusion is $\mathbf{0 , 2 5 3 m m}$.


Texas

## PH080 <br> JEDEC metric plastic quad flatpack

This plastic package consists of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting, and leads are spaced on $0,80-\mathrm{mm}$ centers with a $0,80-\mathrm{mm}$ foot length. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. All linear dimensions are in millimeters.
B. Maximum deviation from coplanarity is $0,1 \mathrm{~mm}$.

PM64, PN80, and PZ100
JEDEC metric plastic shrink quad flatpacks
These plastic packages consists of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting, and leads are spaced on $0,50-\mathrm{mm}$ centers with a $0,50-\mathrm{mm}$ foot length. Leads require no additional cleaning or processing when used in soldered assembly.

NOTES: A. All linear dimensions are in millimeters.
B. Datum plane $-\mathrm{H}-$ located at top of mold parting line and coincident with top of lead. Where lead exits plastic body.
C. Datum $A-B$ and $-D-$ to be determined where center leads exit plastic body at datum plane $-\mathrm{H}-$.
D. Body dimensions ( X and Y axis) do not include mold protrusion. Allowable mold protrusion is $0,25 \mathrm{~mm}$.
E. When number of leads per side is even, datum are determined by adding half-pitch basic dimension to the centerline of the adjacent lead. When number of leads per side is odd, datum $A-B$ and $-D-$ are determined by the centerline of the center lead.


## PQ100, PQ132, and PQ164

## JEDEC plastic quad flatpacks

These plastic packages consist of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound withstands soldering temperatures with no deformation, and circuit performance characteristics remain stable when the devices are operated in high-humidity conditions. The package is intended for surface mounting and leads are spaced on 0,64 ( 0.025 ) centers with a 0,64 ( 0.025 ) foot length. Leads require no additional cleaning or processing when used in soldered assembly.


NOTES: A. Datums $A-B$ and $-D-$ to be determined where center leads exit plastic body at plane $H$.
B. Dimension to be determined at plane - - .
C. Dimension to be determined at plane -H
D. Dimension to be determined at plane H- ; dimension does not include 0,254 ( 0.010 ) maximum mold protrusion per side.
E. Dimensions and tolerance per ANSI Y14.5M-1982.
F. Tolerances: $X, X X \pm 0,12$
( $\mathrm{X} . \mathrm{XXX} \pm 0.005$ )
$X, X X X \pm 0,050$
( $\mathrm{X} . \mathrm{XXXX} \pm 0.002$ ) unless otherwise specified.

## PQ100, PQ132, and PQ164

JEDEC plastic quad flatpacks (continued)


|  |  | 100 | 132 | 164 |
| :---: | :---: | :---: | :---: | :---: |
| JEDEC OUTLNE |  | MO-69AD | MO-69AE | MO-69AF |
| D | MAX | 22,48 (0.885) | 27,56 (1.085) | 32,64 (1.285) |
|  | MIN | 22,23 (0.875 | 27,31 (1.075) | 32,39 (1.275) |
| D1 | MAX | 19,13 (0.753) | 24,21 (0.953) | 29,29 (1.153) |
|  | MIN | 18,97 (0.747) | 24,05 (0.947) | 29,13 (1.147) |
| D2 | MAX | 22,94 (0.903) | 28,01 (1.103) | 33,10 (1.303) |
|  | MIN | 22,78 (0.897) | 27,86 (1.097) | 32,94 (1.297) |
| D3 | NOM | $\begin{gathered} 24 @ 0,64(0.025) \\ =15,24(0.600) \end{gathered}$ | $\begin{gathered} 32 @ 0,635(0.025) \\ =20,32(0.800) \end{gathered}$ | $\begin{gathered} 40 @ 0,635(0.025) \\ =25,40(1.000) \end{gathered}$ |
| D4 | MAX | 9,60 (0.378) | 11,99 (0.472) | 14,53 (0.572) |
|  | MIN | 9,45 (0.372) | 12,14 (0.478) | 14,58 (0.578) |

## TI North American Sales Offices

ALABAMA: Humtsvile: (205) 837-7530 ARRONA: Phoenlx: (602) 995-1007 CALIFORIIA: Irvino: (714) 660-1200 Roevillio: (916) 786-9206 San Dlogo: (619) 278-9600
Santa Clara: (408) $980-9000$ Woodland Huls: (818) 704-8100 COLORADO: Aurora: (303) 360-8000 CONMECTICUT: Wallingtord: (203) 269-0074 FLORIDA: Alt monte Springs: (407) 260-2116 Fort Lauderdtele: (305) 973-8502 Tampa: (813) 882-0017
GEORGIA: Norrrose: (404) 662-7900 ILNOIS: Arllington Hoigitts: (708) 640-3000 INDIANA: Carmit: (317) 573-6400 Fort Wayne: (219) 482-3311 IOWA: Cedar Replds: (319) 395-9550 KANSAS: Overland Parke (913) 451-451 MARYLAND: Columblat (301) 964-2003 MASSACHUSEITS: Waltham: (617) 895-9100 MICHIGAN: FurmIngton HIlla: (313) 553-1500 LIINNESOTA: Eden Prainte: (612) 828-9300 LISSOURI: St. Loula: (314) 821-8400 NEW JERSEY: helln: (201) 750-1050 NEW MEXICO: Albuquerque: (505) 345-2555 NEW YORK: Eant Syracuse: (315) 463-9291 Flahkill: (914) 897-2900 Mohvilio: (516) $454-6600$ PTtsford: (716) 385-6770
NORTH CAROLINA: Charlots: (704) 527-0930 Ralolgh: (919) 876-2725
OHIO: Boactwrood: (216) 464-6100 Benvercreek: (513) 427-6200 OREGON: Benvorton: (503) 643-6758 PENNSYLVANLA: Blue Bell: (215) 825-9500 PUERTO RICO: Hato Rey: (809) 753-8700 TEXAS: ALsttn: (512) 250-6769 Dallas: (214) 917-1204
UTAH: Salt Lake Cty: (801) 466-8973 WASHMMGTON: Redmond: (206) 881-3080 WISCONSIN: Waukosha: (414) 798-1001 CANADA: Nepean: (813) 726-1970 Richmond Hille (416) 884-918 St. Laurent (514) 335-8392

## TI Regional Technology Centers

CALIFORNA: ITvine: (714) 660-8140 Santa Clara: (408) 748-2220 GEORGIA: Nortross: (404) 662-7950 ILLNOIS: Arlington Helghts: (708) 640-2909 INDLANA: Indlanapolis: (317) 573-6400 MASSACHUSETTS: Watham: (817) 895-9196 MEXICO: Moxko Clity: 491-70834 MINNESOTA: MInnospolis: (612) 828-9300 TEXAS: Dalles: (214) 917-3881 CANADA: Nopvan: (813) 726-1970

## Customer <br> Response Center

TOLL FREE: (800) 336-5236
OUTSIDE USA: (214) 995-6811
(8:00 a.m. - 5:00 p.m. CST)

## TI Authorized North American Distributors

Allance Eectronics, Inc. (military product only Alrnac/Arrow
Anthem Electronics
Arrow/Schweber
Future Electronics (Cansada)
GRS Electronics Co., Inc.
Hall-Mark Eloctronic
Marshall Industries
Newark Electronics
Rochester Electronics, Inc
(Obsolete product only (508) 462-9332)
Zous Components

## TI Distributors

ALABAMA: Artow/Schweber (205) 837-6955; Hall-Mark (205) 837-8700; Marshall (205) 881-9235.

ARZONA: Anthem (602) 966-6600; Arrow/Schweber (602) 437-0750; Hall-Mark (602) 431-0030; Marshall (602) 496-0290; Wyie (602) 437-2088.
CALIFORNLA: Los Angeles/Orange County: Arthem 818) 775-1333, (714) 768-4444; Arrow/Schweber (818) 380-9686, (714) 838-5422; Hal-Mark (818) 773-4500, (714) 727-6000; Marshall (818) 878-7000, (714) 458-5301; Wyle (818) 880-9000; (714) 863-9953; Zeus (714) 921-9000, (818) 889-3838;

Sacramento: Anthem (916) 624-9744; Hall-Mark (916) 624-9781; Marshall (916) 635-9700; Wyle (916) 638-5282; San Dlogo: Anthem (619) 453-9006; Arrow/Schweber (619) 565-4800; Hall-Mark (619) 268-1201; Marshall (619) 578-9600; Wyle (819) 565-9171; Zeus (619) 277-9681.
San Franclaco Bry Areat Anthem (408) 453-1200;
Arow/Sctweber (408) 441-9700, (408) 432-7171; Hall-Mark (408) 432-4000; Marshall (408) 942-4600; Wyle (408) 727-2500; Zeus (408) 629-4789.
COLORADO: Anthem (303) 790-4500; Arrow/Sciweber (303) 799-0258; Hall-Mark (303) 790-1662; Marshall (303) 51-8383; Whle (303) 457-9953.
CONNECTICUT: Anthem (203) 575-1575; Arrow/Sctwebe (203) 265-7741; Hall-Mark (203) 271-2844; Marshall (203) 265-3822.
FLORIDA: Fort Lauderdale: Arrow/Sctweber (305) 429-8200; Hall-Mark (305) 971-9280; Marshall (305) 977-4880
Orlando: Arrow/Schweber (407) 333-9300; Hall-Mark (407) 830-5855; Marshall (407) 767-8585; Zous (407) 365-3000. Tampa: Hall-Mark (813) 541-7440; Marshall (813) 5731399.

GEORGIA: Arrow/Schweber (404) 497-1300; Hall-Mark (404) 623-4400; Marshall (404) 923-5750.

LNOIS: Anthem (708) 884-0200; Arrow/Scrweber (708) 250-0500; Hail-Mark (708) 860-3800; Marshall (312) 490-0155; Newark (312)784-5100.
NDIANA: Artow/Sctweber (317) 299-2071; Hall-Mark (317) 872-8875; Marshall (317) 297-0483.

OWA: Arrow/Schweber (319) 395-7230.
KANSAS: Arrow/Schweber (913) 541-9542; Hall-Mark (913) 888-4747; Marshall (913) 492-3121.

MAFYLAND: Anthern (301) 995-6640; Arrow/Schweber (301) 596-7800; Hall-Mark (301) 988-9800; Marshall (301) 622-1118; Zous (301) 997-1118.
MASSACHUSETTS: Anthem (508) 657-5170; Arrow/Schwober (508) 658-0900; Hall-Mark (508) Zous (617) 246-8200

MICHIGAN: Detrolt: Arrow/Schweber (313) 462-2290 Hall-Mark (313) 462-1205; Marshall (313) 525-5850; Newark (313) 967-0600.
MINNESOTA: Anthem (612) 944-5454; Artow/Schweber (612) 941-5280; Hall-Mark (612) $941-2600$; Marshall (612) 559-2211.
MSS OURI: Arrow/Schweber (314) 567-6888; Hall-Mark (314) 291-5350; Marshall (314) 291-4650.

NEW JERSEY: Anthern (201) 227-7960; Arrow/Schweber (201) 227-7880, (609) 596-8000; Hal-Mark (201) 515-3000, (609) 235-1900; Marshall (201) 882-0320), (609) 234-9100

NEW MEXICO: Allance (505) 292-3360
NEW YORK: Long laland: Anthem (516) 864-6600 Arrow/Schweber (516) 231-1000; Hall-Mark (516) 737-0600; Marshal (516) 273-2424; Zeus (914) 937-7400. Rocheater: Arrow/Schweber (716) 427-0300; Hall-Mark (716) 425-3300; Marshall (716) 235-7620.

Syracuse: Marshall (607) 785-2345.
NORTH CAROLINA: ATOW/Schweber (919) 676-3132; Hall-Mark (919) 872-0712; Marshall (919) 878-9882. OHIO: Cleveland: Arrow/Schweber (216) 248-3990 Hall-Mark (216) 349-4632, Marshall (216) 248-1788 Columbus: Hall-Mark (614) 888-3313.
Dayton: Arrow/Sctweber (513) 435-5563; Marshall (513) 898-4480; Zeus (513) 293-6162.
OKLAHOMA: Arrow/Schweber (918) 252-7537; Hall-Mark (918) 254-6110.

OREGON: Almac/Antow (503) 629-8090; Anthem (503) 643-1114; Marshall (503) 644-5050; Wyle (503) 643-7900. PENHSYLVANLA: Anthem (215) 443-5150; Arrow/Schweber (215) 928-1800; GRS (215) 922-7037;
(609) 964-8560; Marsall (412) 788-0441 (609) 964-8560; Marshall (412) 788-0441.

TEXAS: Austin: Arrow/Schweber (512) 835-4180; Hall-Mark (512) 258-8848; Marshall (512) 837-1991; Wyle (512) 345-8853;

Dallas: Anthem 214) 238-7100; Arrow/Schweber (214) 380-6464; Halt-Mark (214) 553-4300; Marshall (214) 233-5200; Wyle (214) 235-9953; Zeus (214) 783-7010 Houston: Arrow/Sctweber (713) 530-4700; Hall-Mark (713) 781-6100; Marshall (713) 895-9200; Wyle (713) 879-9953.
UTAH: Anthem (801) 973-8555; Arow/Sctweber (801) 973-6913; Marshall (801) 973-2288; Wyle (801) 974-9953. WASHINGTON: Almac/Artow (206) 643-9992, (509) 924-9500; Anthem (206) 483-1700; Marshall (206) 486-5747; Wyle (206) 881-1150.
WISCONSIN: Arow/Schweber (414) 792-0150; Hal-Mark (414) 797-7844; Marshall (414) 797-8400.

CANADA: Calgary: Future (403) 235-5325;
Edmonton: Future (403) 438-2858;
Montreal: Arrow/Sctweber (514) 421-7411; Future (514) 694-7710; Marshall (514) 694-8142 Ottawa: Arrow/Schweber (613) 226-6903; Future (613) 820-8313.
Toronto: Arrow/Sctweber (416) 670-7769, Future (416) 612-9200; Marshall (416)458-8046. Vancouver: Arrow/Schweber (604) 421-2333; Future (604) 294-1166.

## TI Die Processors

Chip Supply
(407) 298-7100

Elmo Semiconductor
Minco Technology Labs
(512)

Texas
INSTRUMENTS

## TI Worldwide Sales Offices

ALABAMA: Huntsvillo: 4960 Corporate Drive, Suite N-150, Huntsvile, AL 35805-6202, (205) 837-7530.

ARIZONA: Phoenlx: 8825 N. 23rd Avenue, Suite 100, Phoenlx, AZ 85021, (602) 995-1007. CALIFORNIA: Irvine: 1920 Main Street, Suite 900, Invine, CA 92714, (714) 660-1200; Roseville: 1 Sierra Gate Plaza, Suite 255B, Roseville, CA 95678, (916) 786-9208; Rosevile, CA $95678,(916)$
San Dlego: 5625 Ruffin Road, Suite 100 San Dlego: 5625 Ruffin Road, Suite 100
San Diego, CA 92123, (619) 278-9600;
San Diego, CA 92123, (619) $278-9600$
Santa Clara: 5353 Betsy Ross Drive,
Santa Clara: 5353 Betsy Ross Drive,
Santa Clara, CA 95054, (408) 980-9000;
Woodland Hills: 21550 Oxnard Street, Suite 700, Woodland Hils, CA 91367, (818) 704-8100. COLORADO: Aurora: 1400 S. Potomac Street, Sulte 101, Aurora, CO 80012, (303) 368-8000. CONNECTICUT: Wallingford: 9 Barnes Industrial Park Road, Wallingford, CT 06492, (203) 269-0074. FLORIDA: Altamonte Springs: 370 S. North Lake Boulevard, Suite 1008, Altamonte Springs, FL 32701, (407) 260-2116;
Fort Laudordale: 2950 N.W. 62nd Street, Sulte 100, Fort Lauderdale, FL 33309,
(305) 973-8502; Tampa: 4803 George Road,

Suite 390, Tempa, FL 33634-6234, (813) 882-0017. GEORGLA: Norcross: 5515 Spalding Drive, Norcross, GA 30092, (404) 662-7900. ILLINOIS: Arlington Heights: 515 W. Algonquin, Arlington Heights, IL 60005, (703) 640-3000. INDIANA: Carmel: 550 Congressional Drive, Suite 100, Carmel, IN 46032, (317) 573.6400 ; Fort Wayne: 118 E. Ludwig Road, Suite 102, Fort Wayne, in 46825, (219) 482-3311.
IOWA: Codar Raplds: 373 Collins Road N.E., Suite 201, Cedar Rapids, IA 52402, (319) 395-9550.
KANSAS: Overland Park: 7300 Colloge Boulevard, Lighton Plaza, Suite 150, Overland Park, KS 66210, (913) 451-4511.
MARYLAND: Columbla: 8815 Centre Park Drive, Suite 100, Columbia, MD 21045, (301) 964-2003. MASSACHUSETTS: Waltham: 950 Winter Street, Suite 2800, Waltham, MA 02154, (617) 895-9100.
MICHIGAN: Farmington HIIls: 33737 W. 12 Mile Road, Farmington Hills, MI 48331, (313) 553-1500; MINNESOTA: Eden Prairle: 11000 W. 78th Street, Suite 100, Eden Prairie, MN 55344, (612) 828-9300.
MISSOURI: St. Louls: 12412 Powerscourt Drive, Suite 125, St. Louis, MO 63131, (314) 821-8400.
NEW JERSEY: Isolin: Parkway Towers, 485 E. Route 1 South, Iselin, NJ 08830 , (908) 750-1050.

NEW MEXCCO: Albuquerqua: 2709 Pan American Freeway, N.E., Albuquerque, NM 87107, (505) 345-2555.

NEW YORK: East Syracuse: 6365 Collamer Drive, East Syracuse, NY 13057, (315) 463-9291; Fishklll: 300 Westage Business Center, Suite 140, Fishkill, NY 12524, (914) 897-2900;
Molville: 1895 Watt Whitman Road, Melville, NY 11747, (516) 454-6600;
Plttsford: 2851 Clover Street, Pittsford, NY 14534, (716) 385-6770.

NORTH CAROLNA: Charlotte: 8 Woodlawn Green, Charlotte, NC 28217, (704) 527-0933; Raleigh: 2809 Highwoods Boulevard, Suite 100 , Raloigh: 2809 Highwoods Boulevar
Raleigh, NC 27625, (919) 876-2725.
OHIO: Beachwood: 23775 Commerce Park Road, Beactiwood, OH 44122, (216) 464-6100; Boavercrook: 4200 Coionel Gienn Highway, Suite 600, Beavercreek, OH 45431, (513) 427-6200.

OREGON: Beaverton: 6700 S.W. 105th Street, Suite 110, Beaverton, OR 97005, (503) 643-6758. PENNSYLVANLA: Blue Bell: 670 Sentry Parkway, Blue Bell, PA 19422, (215) 825-9500.

PUERTO RICO: Hato Rey: 615 Mercantil Plaza Building, Suite 505, Hato Rey, PR 00918, (809) 753-8700.

TEXAS: Austin: 12501 Research Boulevard, Austin, TX 78759, (512) 250-6769;
Dallas: 7839 Churchill Way, Dallas, TX 75251, (214) 917-1264; Houston: 9301 Southwest Freeway, Suite 360, Houston, TX 77074, (713) Freeway,
UTAH: Salt Lake CIty: 1800 S. West Temple Street, Suite 201, Salt Lake City, UT 84115 , (801) 466-8973

WASHINGTON: Redmond: 5010 148th Avenue N.E., Building B, Suite 107, Redmond, WA 98052 , (206) 881-3080.

WISCONSIN: Waukesha: 20825 Swenson Drive, Suite 900, Waukesha Wl 53186, (414) 798-1001. CANADA: Nepean: 301 Moodie Drive, Mallom Center, Nepean, Ontario, Canada K2H 9C4,
(613) 726-1970; Richmond Hill: 280 Centre Street (613) 726-1970; Richmond Hill: 280 Centre Stree
East, Richmond Hill, Ontario, Canada L.4C 1B1, East, Richmond Hill, Ontario, Canada L4C 1B1,
(416) $884-9181$; St. Laurent: 9460 Trans Canada (416) 884-9181; St. Laurent: 9460 Tran
Highway, St. Laurent, Quebec, Canada Highway, St. Laurent, Queb
H4S 1R7, (514) $335-8392$.

AUSTRALIA (\& NEW ZEALAND): Texas Instruments Australia L.td., 6-10 Talavera Road, North Ryde (Sydney), New South Wales, Australia 2113, 2-878-9000; 14th Floor, 380 Street, Kilda Road, Melboume, Victoria, Australia 3004, 3-696-1211; 171 Philip Highway, Elizabeth, South Australia 5112, 8 255-2066.
BELGIUM: S.A. Texas Instruments Belgium N.V., 11, Avenue Jules Bordetlaan 11, 1140 Brussels, 11, Avenue Jules Bordetla
Belgium, (02) 2423080 .
BRAZIL: Texas Instruments Electronicos do Brasil Lda., Av. Eng, Luiz Carlos Berrini, 1461-110, andar, 04571 Sao Paulo, SP, Brazil, 11-535-5133. DENMARK: Texas Instruments A/S, Borupvang 2D, DK-2750 Baləerup, Denmark, (45) 44687400. FINLAND: Texas Instruments OY, P.O. Box 86, 02321 Espoo, Finland, (0) 8026517.
FRANCE: Texas Instruments France, 8-10 Avenue Morane Saulnier-B.P. 67, 78141 Velizy Villacoublay cedex, France, (1) 30701003.
GERMANY: Texas Instruments Deutschland GmbH., Haggertystrasse 1, 8050 Freising, (08161) 80-0 od. Nbst; Kurfurstendamm 195-196, 1000 Berlin 15, (030) 8827365 ; Dusseldorfer Strasse 40, 6236 Eschbom 1, (06196) 8070 ; Kirchhorster Strasse 2, 3000 Hannover 51, (0511) 64 68-0; Maybachstrasse II, 7302 Ostfildern 2 (Nellingen), (0711) 3403257; Gildehofcenter, Hollestrasse 3, 4300 Essen 1, (201) 24 25-0.
HOLLAND: Texas Instruments Holland B.V., Hogehilweg 19, Postbus 12995, 1100 AZ Amsterdam-Zuidoost, Holland, (020) 5602911.


HONG KONG: Texas Instruments Hong Kong Ltd. 8th Floor, World Shipping Center, 7 Canton Road, Kowloon, Hong Kong, 7351223.
HUNGARY: Texas instruments International,
Budaorsi u.42, H-1112 Budapest, Hungary, (1) 1666617.

IRELAND: Texas Instruments Ireland Lid., $7 / 8$ Harcourt Street, Dublin 2, Ireland, (01) 481677.

TALY: Texas Instruments Halia S.p.A. Centro Direzionale Colleoni, Palazzo Perseo-Via Paracelso 12, 20041, Agrate Brianza (Mi), Italy (039)

63221 ; Via Castello della Magliana, 38, 00148 Rome, Italy (06) 6572651; Via Amendola, 17, 40100 Bologna, thaly (051) 554004.
JAPAN: Texas Instruments Japan Ltd., Aoyama Fuji Building 3-6-12 Kita-Aoyama Minato-ku, Tokyo, Japan 107, 03-3498-2111; MS Shibaura Building 9F, 4-13-23 Shibaura, Minato-ku, Tokyo, Japan 108, 03-3769-8700; Nissho-iwal Building 5F, 2-5-8 Imabashi, Chuou-ku, Osaka, Japan 541, 06-204-1881; Dai-ni Toyota Building Nishi-kan' 7F, 06-204-1881; Da-ni Koyota-Building Nishi-kan 7F, 4-10-27 Meieki, Nakamura-ku, Nagoya, Japan 052-583-8691; Kanazawa Oyama-cho Daiichi
Seimei Building 6F, 3-10 Oyama-cho, Kanazawa, Ishikawa, Japan 920, 0762-23-5471;
Matsumoto Showa Building 6F, 1-2-11 Fukashi, Matsumoto, Nagano, Japan 390, 0263-33-1060; Daiichi Olympic Tachikawa Building 6F, 1-25-12, Akebono-cho, Tachikawa, Tokyo, Japan 190, 0425-27-6760; Yokohama Business Park East Tower 10F, 134 Gondo-cho, Hodogava-ku, Yokohama, Kanaqawa 240, Japan, 045-338-1220; Nihon Seimei Kyoto Yasaka Building 5F, 843-2, Higashi Shiokohjicho, Higashi-iru, Nishinotoh-in,
Shiokohji-dori, Shirmogyo-ku, Kyoto, Japan 600, 075-341-7713; Sumitomo Seimei Kumagaya 075-341-7713; Sumitomo Seimei Kumagaya
Building 8F, 2-44 Yayoi, Kumagaya, Saitama, Building 8F, 2-44 Yayoi, Kumagaya, Saitama,
Japan 360, 0485-22-2240; 2597-1, Aza Harudai, Oaza Yasaka, Kitsuki, Oita, Japan 873, 09786-3-3211.
KOREA: Texas Instruments Korea Lid., 28th Floor, Trade Tower, 159-1, Samsung-Dong, Kangnam-ku Seoul, Korea, 25512800.
MALAYSIA: Texas Instruments, Malaysia, Sdn. Bhd., Asia Pacific, Lot 36.1 \#Box 93, Menara Maybank, 100 Jalan Tun Perak, 50050 Kuala Lumpur, Malaysia, 2306001.
MEXICO: Texas Instruments de Mexico S.A. de C.V., Alfonso Reyes 115, Col. Hipodromo Condesa, MExico, D.F., 06170, 5-515-6081.
NORWAY: Texas Instruments Norge A/S, PB 106, Refstad (Sinsenveien 53), 0513 Oslo 5, Norway, (02) 155090 .

PEOPLE'S REPUBLIC OF CHINA: Texas Instruments China Inc., Belijing Representative Office, 7-05 CTIC Building, 19 Jianguomenwai Dajie, Beijing, China, 500-2255, Ext. 3750.
PHILIPPINES: Texas Instruments Asia Lid., Philippines Branch, 14th Floor, Ba-Lepanto Building, Paseo de Roxas, Makati, Metro Manila, Philippines, 2-8176031.
PORTUGAL: Texas Instruments Equipamento Electronico (Portugal) LDA., 2650 Moreira Da Maia, 4470 Maia, Portugal (2) 9481003. SINGAPORE (\& INDIA, INDONESIA, THAILAND): Texas Instruments Singapore (PTE) Ltd., Asia Pacific Division, 101 Thomson Road, \#23-01, United Square, Singapore 1130,3508100.
SPAIN: Texas Instruments Espana S.A., c/Gobelas 43, Ctra de La Coruna km 14, La Florida, 28023, Madrid, Spain, (1) 372 8051; c/Diputacion, 279-3-5, 08007 Barcelona, Spain, (3) 3179180. SWEDEN: Texas Instruments International Trade Corporation (Sverigefilialen), Box 30, S-164 93 Kista, Sweden, (08) 7525800.
SWITZERLAND: Texas Instruments Switzerland AG, Riedstrasse 6, CH-8953 Dietikon, Switzerland, (01) 7442811.

TAIWAN: Texas Instruments Taiwan Limited, Taipei Branch, 10th Floor, Bank Tower, No. 205 Tung Hua N. Road, Taipei, Taiwan, Republic of China, 2-7139311.
UNTED KINGDOM: Texas Instruments Ltd., Manton Lane, Bedford, England, MK41 7PA, (0234) 270111.
(1)1992 Texas Instruments Incorporated


[^0]:    *Current out of a terminal is given as a negative value.

[^1]:    Widebus and OEC are trademarks of Texas Instruments Incorporated.

[^2]:    Widebus and OEC are trademarks of Texas Instruments Incorporated.

[^3]:    t To permit the clock pulse to be utilized for reset purposes.

[^4]:    ${ }^{\dagger}$ To permit the clock pulse to be utilized for reset purposes.

[^5]:    $\dagger$ Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

[^6]:    $\dagger$ Includes probe and test fixture capacitance.

[^7]:    $\ddagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{5}$ This is the supply current for each input that is at one of the specified $T L$ voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.

[^8]:    ${ }^{\dagger}$ This symbol is in accordance with ANSI/AEEE Std 91-1984 and IEC Publication 617-12.

[^9]:    $\ddagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    § This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{Cc}}$.

[^10]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ This is the increase in supply current for each input, excluding XI, that is at one of the specified TTL voltage levels rather OV or V cc.
    ${ }^{\S}$ This parameter is measured with $C_{L}=30 \mathrm{pF}$ (see Figure 4).

[^11]:    Widebus is a trademark of Texas Instruments Incorporated.

[^12]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

[^13]:    $\dagger$ The maximum possible clock frequency is 40 MHz . The maximum clock frequency when using a $50 \%$ duty cycle is 33.3 MHz .
    NOTE 1: To ensure proper operation, it is necessary to provide a clean signal to the LDCK and UNCK clock inputs. Any excessive noise or glitching on the clock inputs that violates limits for maximum $\mathrm{V}_{\mathrm{IL}}$, minimum $\mathrm{V}_{\mathrm{IH}}$, or minimum pulse duration can cause a false clock or improper operation of the internal read and write pointers.

[^14]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    \# The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

[^15]:    †This symbol is in accordance with ANSI/IEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but does not show the details of implementation; for these, see the logic diagram. The symbol represents the memory as if it were controlled by a single counter whose content is the number of words stored at the time. Output data is invalid when the counter content (CT) is 0 .

[^16]:    * All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

[^17]:    $\dagger$ To permit the clock pulse to be utilized for reset purposes.

[^18]:    $\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984.

[^19]:    IThese parameters are measured with the internal output state of the storage register opposite to that of the bus input.

[^20]:    $\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984.

[^21]:    I These parameters are measured with the internal output state of the storage register opposite to that of the bus input.

[^22]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.
    NOTE 2: Load circult and voltage waveforms are shown in Section 1 of the LSI Logic Data Book, 1986.

[^23]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ This is the supply current for each input that is at one of the specified TTL voltage levels rather 0 V or $\mathrm{V}_{\mathrm{CC}}$.

[^24]:    ${ }^{1}$ Advanced CMOS Logic Designer's Handbook, pages 3-1 through 3-12

